commit
70bf43dcce
@ -4,6 +4,9 @@
|
|||||||
|
|
||||||
with lib;
|
with lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
gnome3 = config.environment.gnome3.packageSet;
|
||||||
|
in
|
||||||
{
|
{
|
||||||
|
|
||||||
###### interface
|
###### interface
|
||||||
@ -30,9 +33,9 @@ with lib;
|
|||||||
|
|
||||||
config = mkIf config.services.gnome3.at-spi2-core.enable {
|
config = mkIf config.services.gnome3.at-spi2-core.enable {
|
||||||
|
|
||||||
environment.systemPackages = [ pkgs.gnome3.at_spi2_core ];
|
environment.systemPackages = [ gnome3.at_spi2_core ];
|
||||||
|
|
||||||
services.dbus.packages = [ pkgs.gnome3.at_spi2_core ];
|
services.dbus.packages = [ gnome3.at_spi2_core ];
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -4,6 +4,9 @@
|
|||||||
|
|
||||||
with pkgs.lib;
|
with pkgs.lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
gnome3 = config.environment.gnome3.packageSet;
|
||||||
|
in
|
||||||
{
|
{
|
||||||
|
|
||||||
###### interface
|
###### interface
|
||||||
@ -30,9 +33,9 @@ with pkgs.lib;
|
|||||||
|
|
||||||
config = mkIf config.services.gnome3.gnome-documents.enable {
|
config = mkIf config.services.gnome3.gnome-documents.enable {
|
||||||
|
|
||||||
environment.systemPackages = [ pkgs.gnome3.gnome-documents ];
|
environment.systemPackages = [ gnome3.gnome-documents ];
|
||||||
|
|
||||||
services.dbus.packages = [ pkgs.gnome3.gnome-documents ];
|
services.dbus.packages = [ gnome3.gnome-documents ];
|
||||||
|
|
||||||
services.gnome3.gnome-online-accounts.enable = true;
|
services.gnome3.gnome-online-accounts.enable = true;
|
||||||
|
|
||||||
|
@ -4,6 +4,9 @@
|
|||||||
|
|
||||||
with pkgs.lib;
|
with pkgs.lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
gnome3 = config.environment.gnome3.packageSet;
|
||||||
|
in
|
||||||
{
|
{
|
||||||
|
|
||||||
###### interface
|
###### interface
|
||||||
@ -31,9 +34,9 @@ with pkgs.lib;
|
|||||||
|
|
||||||
config = mkIf config.services.gnome3.gnome-keyring.enable {
|
config = mkIf config.services.gnome3.gnome-keyring.enable {
|
||||||
|
|
||||||
environment.systemPackages = [ pkgs.gnome3.gnome_keyring ];
|
environment.systemPackages = [ gnome3.gnome_keyring ];
|
||||||
|
|
||||||
services.dbus.packages = [ pkgs.gnome3.gnome_keyring ];
|
services.dbus.packages = [ gnome3.gnome_keyring ];
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -4,6 +4,9 @@
|
|||||||
|
|
||||||
with pkgs.lib;
|
with pkgs.lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
gnome3 = config.environment.gnome3.packageSet;
|
||||||
|
in
|
||||||
{
|
{
|
||||||
|
|
||||||
###### interface
|
###### interface
|
||||||
@ -30,9 +33,9 @@ with pkgs.lib;
|
|||||||
|
|
||||||
config = mkIf config.services.gnome3.gnome-online-accounts.enable {
|
config = mkIf config.services.gnome3.gnome-online-accounts.enable {
|
||||||
|
|
||||||
environment.systemPackages = [ pkgs.gnome3.gnome_online_accounts ];
|
environment.systemPackages = [ gnome3.gnome_online_accounts ];
|
||||||
|
|
||||||
services.dbus.packages = [ pkgs.gnome3.gnome_online_accounts ];
|
services.dbus.packages = [ gnome3.gnome_online_accounts ];
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -4,6 +4,9 @@
|
|||||||
|
|
||||||
with pkgs.lib;
|
with pkgs.lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
gnome3 = config.environment.gnome3.packageSet;
|
||||||
|
in
|
||||||
{
|
{
|
||||||
|
|
||||||
###### interface
|
###### interface
|
||||||
@ -30,9 +33,9 @@ with pkgs.lib;
|
|||||||
|
|
||||||
config = mkIf config.services.gnome3.gnome-online-miners.enable {
|
config = mkIf config.services.gnome3.gnome-online-miners.enable {
|
||||||
|
|
||||||
environment.systemPackages = [ pkgs.gnome3.gnome-online-miners ];
|
environment.systemPackages = [ gnome3.gnome-online-miners ];
|
||||||
|
|
||||||
services.dbus.packages = [ pkgs.gnome3.gnome-online-miners ];
|
services.dbus.packages = [ gnome3.gnome-online-miners ];
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -4,6 +4,9 @@
|
|||||||
|
|
||||||
with pkgs.lib;
|
with pkgs.lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
gnome3 = config.environment.gnome3.packageSet;
|
||||||
|
in
|
||||||
{
|
{
|
||||||
|
|
||||||
###### interface
|
###### interface
|
||||||
@ -30,9 +33,9 @@ with pkgs.lib;
|
|||||||
|
|
||||||
config = mkIf config.services.gnome3.gnome-user-share.enable {
|
config = mkIf config.services.gnome3.gnome-user-share.enable {
|
||||||
|
|
||||||
environment.systemPackages = [ pkgs.gnome3.gnome-user-share ];
|
environment.systemPackages = [ gnome3.gnome-user-share ];
|
||||||
|
|
||||||
services.xserver.displayManager.sessionCommands = with pkgs.gnome3; ''
|
services.xserver.displayManager.sessionCommands = with gnome3; ''
|
||||||
# Don't let gnome-control-center depend upon gnome-user-share
|
# Don't let gnome-control-center depend upon gnome-user-share
|
||||||
export XDG_DATA_DIRS=$XDG_DATA_DIRS''${XDG_DATA_DIRS:+:}${gnome-user-share}/share/gsettings-schemas/${gnome-user-share.name}
|
export XDG_DATA_DIRS=$XDG_DATA_DIRS''${XDG_DATA_DIRS:+:}${gnome-user-share}/share/gsettings-schemas/${gnome-user-share.name}
|
||||||
'';
|
'';
|
||||||
|
@ -4,6 +4,9 @@
|
|||||||
|
|
||||||
with pkgs.lib;
|
with pkgs.lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
gnome3 = config.environment.gnome3.packageSet;
|
||||||
|
in
|
||||||
{
|
{
|
||||||
|
|
||||||
###### interface
|
###### interface
|
||||||
@ -29,9 +32,9 @@ with pkgs.lib;
|
|||||||
|
|
||||||
config = mkIf config.services.gnome3.seahorse.enable {
|
config = mkIf config.services.gnome3.seahorse.enable {
|
||||||
|
|
||||||
environment.systemPackages = [ pkgs.gnome3.seahorse ];
|
environment.systemPackages = [ gnome3.seahorse ];
|
||||||
|
|
||||||
services.dbus.packages = [ pkgs.gnome3.seahorse ];
|
services.dbus.packages = [ gnome3.seahorse ];
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -4,6 +4,9 @@
|
|||||||
|
|
||||||
with lib;
|
with lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
gnome3 = config.environment.gnome3.packageSet;
|
||||||
|
in
|
||||||
{
|
{
|
||||||
|
|
||||||
###### interface
|
###### interface
|
||||||
@ -29,9 +32,9 @@ with lib;
|
|||||||
|
|
||||||
config = mkIf config.services.gnome3.sushi.enable {
|
config = mkIf config.services.gnome3.sushi.enable {
|
||||||
|
|
||||||
environment.systemPackages = [ pkgs.gnome3.sushi ];
|
environment.systemPackages = [ gnome3.sushi ];
|
||||||
|
|
||||||
services.dbus.packages = [ pkgs.gnome3.sushi ];
|
services.dbus.packages = [ gnome3.sushi ];
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -4,6 +4,9 @@
|
|||||||
|
|
||||||
with pkgs.lib;
|
with pkgs.lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
gnome3 = config.environment.gnome3.packageSet;
|
||||||
|
in
|
||||||
{
|
{
|
||||||
|
|
||||||
###### interface
|
###### interface
|
||||||
@ -30,9 +33,9 @@ with pkgs.lib;
|
|||||||
|
|
||||||
config = mkIf config.services.gnome3.tracker.enable {
|
config = mkIf config.services.gnome3.tracker.enable {
|
||||||
|
|
||||||
environment.systemPackages = [ pkgs.gnome3.tracker ];
|
environment.systemPackages = [ gnome3.tracker ];
|
||||||
|
|
||||||
services.dbus.packages = [ pkgs.gnome3.tracker ];
|
services.dbus.packages = [ gnome3.tracker ];
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -4,6 +4,9 @@
|
|||||||
|
|
||||||
with lib;
|
with lib;
|
||||||
|
|
||||||
|
let
|
||||||
|
cfg = config.services.upower;
|
||||||
|
in
|
||||||
{
|
{
|
||||||
|
|
||||||
###### interface
|
###### interface
|
||||||
@ -21,6 +24,15 @@ with lib;
|
|||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
|
package = mkOption {
|
||||||
|
type = types.package;
|
||||||
|
default = pkgs.upower;
|
||||||
|
example = lib.literalExample "pkgs.upower";
|
||||||
|
description = ''
|
||||||
|
Which upower package to use.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
};
|
};
|
||||||
@ -28,13 +40,13 @@ with lib;
|
|||||||
|
|
||||||
###### implementation
|
###### implementation
|
||||||
|
|
||||||
config = mkIf config.services.upower.enable {
|
config = mkIf cfg.enable {
|
||||||
|
|
||||||
environment.systemPackages = [ pkgs.upower ];
|
environment.systemPackages = [ cfg.package ];
|
||||||
|
|
||||||
services.dbus.packages = [ pkgs.upower ];
|
services.dbus.packages = [ cfg.package ];
|
||||||
|
|
||||||
services.udev.packages = [ pkgs.upower ];
|
services.udev.packages = [ cfg.package ];
|
||||||
|
|
||||||
systemd.services.upower =
|
systemd.services.upower =
|
||||||
{ description = "Power Management Daemon";
|
{ description = "Power Management Daemon";
|
||||||
@ -42,7 +54,7 @@ with lib;
|
|||||||
serviceConfig =
|
serviceConfig =
|
||||||
{ Type = "dbus";
|
{ Type = "dbus";
|
||||||
BusName = "org.freedesktop.UPower";
|
BusName = "org.freedesktop.UPower";
|
||||||
ExecStart = "@${pkgs.upower}/libexec/upowerd upowerd";
|
ExecStart = "@${cfg.package}/libexec/upowerd upowerd";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -4,13 +4,13 @@ with lib;
|
|||||||
|
|
||||||
let
|
let
|
||||||
cfg = config.services.xserver.desktopManager.gnome3;
|
cfg = config.services.xserver.desktopManager.gnome3;
|
||||||
gnome3 = pkgs.gnome3;
|
gnome3 = config.environment.gnome3.packageSet;
|
||||||
|
|
||||||
# Remove packages of ys from xs, based on their names
|
# Remove packages of ys from xs, based on their names
|
||||||
removePackagesByName = xs: ys:
|
removePackagesByName = xs: ys:
|
||||||
let
|
let
|
||||||
pkgName = drv: (builtins.parseDrvName drv.name).name;
|
pkgName = drv: (builtins.parseDrvName drv.name).name;
|
||||||
ysNames = map pkgName ys;
|
ysNames = map pkgName ys;
|
||||||
res = (filter (x: !(builtins.elem (pkgName x) ysNames)) xs);
|
res = (filter (x: !(builtins.elem (pkgName x) ysNames)) xs);
|
||||||
in
|
in
|
||||||
filter (x: !(builtins.elem (pkgName x) ysNames)) xs;
|
filter (x: !(builtins.elem (pkgName x) ysNames)) xs;
|
||||||
@ -35,6 +35,12 @@ in {
|
|||||||
description = "Enable Gnome 3 desktop manager.";
|
description = "Enable Gnome 3 desktop manager.";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
environment.gnome3.packageSet = mkOption {
|
||||||
|
default = pkgs.gnome3;
|
||||||
|
example = literalExample "pkgs.gnome3_12";
|
||||||
|
description = "Which Gnome 3 package set to use.";
|
||||||
|
};
|
||||||
|
|
||||||
environment.gnome3.excludePackages = mkOption {
|
environment.gnome3.excludePackages = mkOption {
|
||||||
default = [];
|
default = [];
|
||||||
example = "[ pkgs.gnome3.totem ]";
|
example = "[ pkgs.gnome3.totem ]";
|
||||||
@ -64,6 +70,7 @@ in {
|
|||||||
services.telepathy.enable = mkDefault true;
|
services.telepathy.enable = mkDefault true;
|
||||||
networking.networkmanager.enable = true;
|
networking.networkmanager.enable = true;
|
||||||
services.upower.enable = config.powerManagement.enable;
|
services.upower.enable = config.powerManagement.enable;
|
||||||
|
services.upower.package = gnome3.upower;
|
||||||
|
|
||||||
fonts.fonts = [ pkgs.dejavu_fonts ];
|
fonts.fonts = [ pkgs.dejavu_fonts ];
|
||||||
|
|
||||||
@ -80,7 +87,7 @@ in {
|
|||||||
|
|
||||||
# Don't let epiphany depend upon gnome-shell
|
# Don't let epiphany depend upon gnome-shell
|
||||||
# Override default mimeapps
|
# Override default mimeapps
|
||||||
export XDG_DATA_DIRS=$XDG_DATA_DIRS''${XDG_DATA_DIRS:+:}${pkgs.gnome3.gnome_shell}/share/gsettings-schemas/${pkgs.gnome3.gnome_shell.name}:${mimeAppsList}/share
|
export XDG_DATA_DIRS=$XDG_DATA_DIRS''${XDG_DATA_DIRS:+:}${gnome3.gnome_shell}/share/gsettings-schemas/${gnome3.gnome_shell.name}:${mimeAppsList}/share
|
||||||
|
|
||||||
# Let gnome-control-center find gnome-shell search providers
|
# Let gnome-control-center find gnome-shell search providers
|
||||||
export GNOME_SEARCH_PROVIDERS_DIR=${config.system.path}/share/gnome-shell/search-providers/
|
export GNOME_SEARCH_PROVIDERS_DIR=${config.system.path}/share/gnome-shell/search-providers/
|
||||||
|
30
nixos/tests/gnome3_12.nix
Normal file
30
nixos/tests/gnome3_12.nix
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
import ./make-test.nix {
|
||||||
|
|
||||||
|
machine =
|
||||||
|
{ config, pkgs, ... }:
|
||||||
|
|
||||||
|
{ imports = [ ./common/user-account.nix ];
|
||||||
|
|
||||||
|
services.xserver.enable = true;
|
||||||
|
|
||||||
|
services.xserver.displayManager.auto.enable = true;
|
||||||
|
services.xserver.displayManager.auto.user = "alice";
|
||||||
|
services.xserver.desktopManager.gnome3.enable = true;
|
||||||
|
environment.gnome3.packageSet = pkgs.gnome3_12;
|
||||||
|
};
|
||||||
|
|
||||||
|
testScript =
|
||||||
|
''
|
||||||
|
$machine->waitForX;
|
||||||
|
$machine->sleep(15);
|
||||||
|
|
||||||
|
# Check that logging in has given the user ownership of devices.
|
||||||
|
$machine->succeed("getfacl /dev/snd/timer | grep -q alice");
|
||||||
|
|
||||||
|
$machine->succeed("su - alice -c 'DISPLAY=:0.0 gnome-terminal &'");
|
||||||
|
$machine->waitForWindow(qr/Terminal/);
|
||||||
|
$machine->sleep(10);
|
||||||
|
$machine->screenshot("screen");
|
||||||
|
'';
|
||||||
|
|
||||||
|
}
|
@ -1,7 +1,7 @@
|
|||||||
{ callPackage, self, pkgs }:
|
{ callPackage, self, pkgs }:
|
||||||
|
|
||||||
rec {
|
rec {
|
||||||
inherit (pkgs) glib gtk2 gtk3 gnome2;
|
inherit (pkgs) glib gtk2 gtk3 gnome2 upower;
|
||||||
gtk = gtk3; # just to be sure
|
gtk = gtk3; # just to be sure
|
||||||
libcanberra = pkgs.libcanberra_gtk3; # just to be sure
|
libcanberra = pkgs.libcanberra_gtk3; # just to be sure
|
||||||
inherit (pkgs.gnome2) ORBit2;
|
inherit (pkgs.gnome2) ORBit2;
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user