127c928c23
The renaming of options define the original value for the new attribute path. This works well if there is only *one* target, but if there are more, we end up recursing into the attribute set of the option definition itself. We now check for that within the parent recursion node (we can't check that from the subnode, because we lack that information about whether it's defined multiple times) and if the subnode consist entirely of a list of definitions, we use mkMerge on it. Signed-off-by: aszlig <aszlig@redmoonstudios.org>
175 lines
5.7 KiB
Nix
175 lines
5.7 KiB
Nix
{ config, lib, pkgs, ... }:
|
||
|
||
with lib;
|
||
|
||
let
|
||
|
||
xcfg = config.services.xserver;
|
||
cfg = xcfg.desktopManager.kde4;
|
||
xorg = pkgs.xorg;
|
||
kde_workspace = config.services.xserver.desktopManager.kde4.kdeWorkspacePackage;
|
||
|
||
# Disable Nepomuk and Strigi by default. As of KDE 4.7, they don't
|
||
# really work very well (e.g. searching files often fails to find
|
||
# files), segfault sometimes and consume significant resources.
|
||
# They can be re-enabled in the KDE System Settings under "Desktop
|
||
# Search".
|
||
nepomukConfig = pkgs.writeTextFile
|
||
{ name = "nepomuk-config";
|
||
destination = "/share/config/nepomukserverrc";
|
||
text =
|
||
''
|
||
[Basic Settings]
|
||
Start Nepomuk=false
|
||
|
||
[Service-nepomukstrigiservice]
|
||
autostart=false
|
||
'';
|
||
};
|
||
|
||
phononBackends = {
|
||
gstreamer = [
|
||
pkgs.phonon_backend_gstreamer
|
||
pkgs.gst_all.gstPluginsBase
|
||
pkgs.gst_all.gstPluginsGood
|
||
pkgs.gst_all.gstPluginsUgly
|
||
pkgs.gst_all.gstPluginsBad
|
||
pkgs.gst_all.gstFfmpeg # for mp3 playback
|
||
pkgs.gst_all.gstreamer # needed?
|
||
];
|
||
|
||
vlc = [pkgs.phonon_backend_vlc];
|
||
};
|
||
|
||
phononBackendPackages = flip concatMap cfg.phononBackends
|
||
(name: attrByPath [name] (throw "unknown phonon backend `${name}'") phononBackends);
|
||
|
||
in
|
||
|
||
{
|
||
options = {
|
||
|
||
services.xserver.desktopManager.kde4 = {
|
||
enable = mkOption {
|
||
type = types.bool;
|
||
default = false;
|
||
description = "Enable the KDE 4 desktop environment.";
|
||
};
|
||
|
||
phononBackends = mkOption {
|
||
type = types.listOf types.str;
|
||
default = ["gstreamer"];
|
||
example = ["gstreamer" "vlc"];
|
||
description = "Which phonon multimedia backend kde should use";
|
||
};
|
||
|
||
kdeWorkspacePackage = mkOption {
|
||
internal = true;
|
||
default = pkgs.kde4.kde_workspace;
|
||
type = types.package;
|
||
description = "Custom kde-workspace, used for NixOS rebranding.";
|
||
};
|
||
};
|
||
};
|
||
|
||
|
||
config = mkIf (xcfg.enable && cfg.enable) {
|
||
|
||
# If KDE 4 is enabled, make it the default desktop manager (unless
|
||
# overridden by the user's configuration).
|
||
# !!! doesn't work yet ("Multiple definitions. Only one is allowed
|
||
# for this option.")
|
||
# services.xserver.desktopManager.default = mkOverride 900 "kde4";
|
||
|
||
services.xserver.desktopManager.session = singleton
|
||
{ name = "kde4";
|
||
bgSupport = true;
|
||
start =
|
||
''
|
||
# The KDE icon cache is supposed to update itself
|
||
# automatically, but it uses the timestamp on the icon
|
||
# theme directory as a trigger. Since in Nix the
|
||
# timestamp is always the same, this doesn't work. So as
|
||
# a workaround, nuke the icon cache on login. This isn't
|
||
# perfect, since it may require logging out after
|
||
# installing new applications to update the cache.
|
||
# See http://lists-archives.org/kde-devel/26175-what-when-will-icon-cache-refresh.html
|
||
rm -fv $HOME/.kde/cache-*/icon-cache.kcache
|
||
|
||
# Qt writes a weird ‘libraryPath’ line to
|
||
# ~/.config/Trolltech.conf that causes the KDE plugin
|
||
# paths of previous KDE invocations to be searched.
|
||
# Obviously using mismatching KDE libraries is potentially
|
||
# disastrous, so here we nuke references to the Nix store
|
||
# in Trolltech.conf. A better solution would be to stop
|
||
# Qt from doing this wackiness in the first place.
|
||
if [ -e $HOME/.config/Trolltech.conf ]; then
|
||
sed -e '/nix\\store\|nix\/store/ d' -i $HOME/.config/Trolltech.conf
|
||
fi
|
||
|
||
# Start KDE.
|
||
exec ${kde_workspace}/bin/startkde
|
||
'';
|
||
};
|
||
|
||
security.setuidOwners = singleton
|
||
{ program = "kcheckpass";
|
||
source = "${kde_workspace}/lib/kde4/libexec/kcheckpass";
|
||
owner = "root";
|
||
group = "root";
|
||
setuid = true;
|
||
};
|
||
|
||
environment.systemPackages =
|
||
[ pkgs.kde4.kdelibs
|
||
|
||
pkgs.kde4.kde_baseapps # Splitted kdebase
|
||
kde_workspace
|
||
pkgs.kde4.kde_runtime
|
||
pkgs.kde4.konsole
|
||
pkgs.kde4.kate
|
||
|
||
pkgs.kde4.kde_wallpapers # contains kdm's default background
|
||
pkgs.kde4.oxygen_icons
|
||
pkgs.virtuoso # to enable Nepomuk to find Virtuoso
|
||
|
||
# Starts KDE's Polkit authentication agent.
|
||
pkgs.kde4.polkit_kde_agent
|
||
|
||
# Miscellaneous runtime dependencies.
|
||
pkgs.kde4.qt4 # needed for qdbus
|
||
pkgs.shared_mime_info
|
||
xorg.xmessage # so that startkde can show error messages
|
||
xorg.xset # used by startkde, non-essential
|
||
xorg.xauth # used by kdesu
|
||
pkgs.shared_desktop_ontologies # used by nepomuk
|
||
pkgs.strigi # used by nepomuk
|
||
pkgs.kde4.akonadi
|
||
pkgs.mysql # used by akonadi
|
||
pkgs.kde4.kdepim_runtime
|
||
]
|
||
++ lib.optional config.hardware.pulseaudio.enable pkgs.kde4.kmix # Perhaps this should always be enabled
|
||
++ lib.optional config.hardware.bluetooth.enable pkgs.kde4.bluedevil
|
||
++ lib.optional config.networking.networkmanager.enable pkgs.kde4.plasma-nm
|
||
++ [ nepomukConfig ] ++ phononBackendPackages;
|
||
|
||
environment.pathsToLink = [ "/share" ];
|
||
|
||
environment.profileRelativeEnvVars = mkIf (lib.elem "gstreamer" cfg.phononBackends) {
|
||
GST_PLUGIN_SYSTEM_PATH = [ "/lib/gstreamer-0.10" ];
|
||
};
|
||
|
||
environment.etc = singleton
|
||
{ source = "${pkgs.xkeyboard_config}/etc/X11/xkb";
|
||
target = "X11/xkb";
|
||
};
|
||
|
||
# Enable helpful DBus services.
|
||
services.udisks2.enable = true;
|
||
services.upower.enable = config.powerManagement.enable;
|
||
|
||
security.pam.services.kde = { allowNullPassword = true; };
|
||
|
||
};
|
||
|
||
}
|