Merge pull request #21466 from abbradar/kde-wrapper

Flatten nested kdeWrappers
This commit is contained in:
Thomas Tuegel 2017-01-03 08:21:39 -06:00 committed by GitHub
commit 0723aa8108
24 changed files with 312 additions and 238 deletions

View File

@ -31,12 +31,25 @@ in
''; '';
}; };
extraPackages = mkOption {
type = types.listOf types.package;
default = [];
description = ''
KDE packages that need to be installed system-wide.
'';
};
}; };
}; };
config = mkIf (xcfg.enable && cfg.enable) { config = mkMerge [
(mkIf (cfg.extraPackages != []) {
environment.systemPackages = [ (kde5.kdeWrapper cfg.extraPackages) ];
})
(mkIf (xcfg.enable && cfg.enable) {
warnings = optional config.services.xserver.desktopManager.kde4.enable warnings = optional config.services.xserver.desktopManager.kde4.enable
"KDE 4 should not be enabled at the same time as KDE 5"; "KDE 4 should not be enabled at the same time as KDE 5";
@ -120,7 +133,6 @@ in
kde5.kdecoration kde5.kdecoration
kde5.kdeplasma-addons kde5.kdeplasma-addons
kde5.kgamma5 kde5.kgamma5
kde5.khelpcenter
kde5.khotkeys kde5.khotkeys
kde5.kinfocenter kde5.kinfocenter
kde5.kmenuedit kde5.kmenuedit
@ -133,7 +145,6 @@ in
kde5.libkscreen kde5.libkscreen
kde5.libksysguard kde5.libksysguard
kde5.milou kde5.milou
kde5.oxygen
kde5.plasma-integration kde5.plasma-integration
kde5.polkit-kde-agent kde5.polkit-kde-agent
kde5.systemsettings kde5.systemsettings
@ -142,12 +153,10 @@ in
kde5.plasma-workspace kde5.plasma-workspace
kde5.plasma-workspace-wallpapers kde5.plasma-workspace-wallpapers
kde5.dolphin
kde5.dolphin-plugins kde5.dolphin-plugins
kde5.ffmpegthumbs kde5.ffmpegthumbs
kde5.kdegraphics-thumbnailers kde5.kdegraphics-thumbnailers
kde5.kio-extras kde5.kio-extras
kde5.konsole
kde5.print-manager kde5.print-manager
# Install Breeze icons if available # Install Breeze icons if available
@ -179,6 +188,15 @@ in
++ lib.optional config.services.colord.enable pkgs.colord-kde ++ lib.optional config.services.colord.enable pkgs.colord-kde
++ lib.optionals config.services.samba.enable [ kde5.kdenetwork-filesharing pkgs.samba ]; ++ lib.optionals config.services.samba.enable [ kde5.kdenetwork-filesharing pkgs.samba ];
services.xserver.desktopManager.kde5.extraPackages =
[
kde5.khelpcenter
kde5.oxygen
kde5.dolphin
kde5.konsole
];
environment.pathsToLink = [ "/share" ]; environment.pathsToLink = [ "/share" ];
environment.etc = singleton { environment.etc = singleton {
@ -186,9 +204,9 @@ in
target = "X11/xkb"; target = "X11/xkb";
}; };
# Enable GTK applications to load SVG icons
environment.variables = environment.variables =
{ {
# Enable GTK applications to load SVG icons
GST_PLUGIN_SYSTEM_PATH_1_0 = GST_PLUGIN_SYSTEM_PATH_1_0 =
lib.makeSearchPath "/lib/gstreamer-1.0" lib.makeSearchPath "/lib/gstreamer-1.0"
(builtins.map (pkg: pkg.out) (with pkgs.gst_all_1; [ (builtins.map (pkg: pkg.out) (with pkgs.gst_all_1; [
@ -229,6 +247,7 @@ in
security.pam.services.kde = { allowNullPassword = true; }; security.pam.services.kde = { allowNullPassword = true; };
}; })
];
} }

View File

@ -60,8 +60,9 @@ let
}; };
}; };
in in
kdeWrapper unwrapped kdeWrapper
{ {
inherit unwrapped;
targets = [ "bin/kile" ]; targets = [ "bin/kile" ];
paths = [ konsole.unwrapped ]; paths = [ konsole.unwrapped ];
} }

View File

@ -55,9 +55,9 @@ let
in in
kdeWrapper unwrapped kdeWrapper
{ {
inherit unwrapped;
targets = [ "bin/yakuake" ]; targets = [ "bin/yakuake" ];
paths = [ konsole.unwrapped ]; paths = [ konsole.unwrapped ];
} }

View File

@ -75,7 +75,8 @@ let
homepage = https://konversation.kde.org; homepage = https://konversation.kde.org;
}; };
}; };
in kdeWrapper unwrapped { in kdeWrapper {
inherit unwrapped;
targets = [ "bin/konversation" ]; targets = [ "bin/konversation" ];
} }

View File

@ -36,7 +36,8 @@ let
}; };
}; };
in in
kdeWrapper unwrapped kdeWrapper
{ {
inherit unwrapped;
targets = [ "bin/ark" ]; targets = [ "bin/ark" ];
} }

View File

@ -24,8 +24,9 @@ let
]; ];
}; };
in in
kdeWrapper unwrapped kdeWrapper
{ {
inherit unwrapped;
targets = [ "bin/dolphin" ]; targets = [ "bin/dolphin" ];
paths = [ dolphin-plugins konsole.unwrapped ]; paths = [ dolphin-plugins konsole.unwrapped ];
} }

View File

@ -18,4 +18,7 @@ let
]; ];
}; };
in in
kdeWrapper unwrapped { targets = [ "bin/filelight" ]; } kdeWrapper {
inherit unwrapped;
targets = [ "bin/filelight" ];
}

View File

@ -20,7 +20,8 @@ let
]; ];
}; };
in in
kdeWrapper unwrapped { kdeWrapper {
inherit unwrapped;
targets = [ "bin/gwenview" ]; targets = [ "bin/gwenview" ];
paths = [ kipi-plugins ]; paths = [ kipi-plugins ];
} }

View File

@ -24,8 +24,9 @@ let
]; ];
}; };
in in
kdeWrapper unwrapped kdeWrapper
{ {
inherit unwrapped;
targets = [ "bin/kate" "bin/kwrite" ]; targets = [ "bin/kate" "bin/kwrite" ];
paths = [ konsole.unwrapped ]; paths = [ konsole.unwrapped ];
} }

View File

@ -18,4 +18,7 @@ let
]; ];
}; };
in in
kdeWrapper unwrapped { targets = [ "bin/kcalc" ]; } kdeWrapper {
inherit unwrapped;
targets = [ "bin/kcalc" ];
}

View File

@ -15,4 +15,7 @@ let
propagatedBuildInputs = [ ki18n kwidgetsaddons kxmlgui ]; propagatedBuildInputs = [ ki18n kwidgetsaddons kxmlgui ];
}; };
in in
kdeWrapper unwrapped { targets = [ "bin/kcolorchooser" ]; } kdeWrapper {
inherit unwrapped;
targets = [ "bin/kcolorchooser" ];
}

View File

@ -74,8 +74,9 @@ unwrapped = kdeApp {
}; };
}; };
in in
kdeWrapper unwrapped kdeWrapper
{ {
inherit unwrapped;
targets = [ "bin/kdenlive" ]; targets = [ "bin/kdenlive" ];
paths = [ kinit ]; paths = [ kinit ];
} }

View File

@ -18,4 +18,7 @@ let
]; ];
}; };
in in
kdeWrapper unwrapped { targets = [ "bin/kdf" ]; } kdeWrapper {
inherit unwrapped;
targets = [ "bin/kdf" ];
}

View File

@ -16,4 +16,7 @@ let
]; ];
}; };
in in
kdeWrapper unwrapped { targets = [ "bin/khelpcenter" ]; } kdeWrapper {
inherit unwrapped;
targets = [ "bin/khelpcenter" ];
}

View File

@ -15,4 +15,7 @@ let
]; ];
}; };
in in
kdeWrapper unwrapped { targets = [ "bin/kompare" ]; } kdeWrapper {
inherit unwrapped;
targets = [ "bin/kompare" ];
}

View File

@ -24,4 +24,7 @@ let
]; ];
}; };
in in
kdeWrapper unwrapped { targets = [ "bin/konsole" ]; } kdeWrapper {
inherit unwrapped;
targets = [ "bin/konsole" ];
}

View File

@ -30,6 +30,7 @@ let
kxmlgui kxmlgui
]; ];
}; };
in kdeWrapper unwrapped { in kdeWrapper {
inherit unwrapped;
targets = ["bin/kwalletmanager5"]; targets = ["bin/kwalletmanager5"];
} }

View File

@ -18,7 +18,8 @@ let
enableParallelBuilding = true; enableParallelBuilding = true;
}; };
in in
kdeWrapper unwrapped { kdeWrapper {
inherit unwrapped;
targets = [ "bin/marble-qt" ]; targets = [ "bin/marble-qt" ];
paths = [ unwrapped ]; paths = [ unwrapped ];
} }

View File

@ -25,6 +25,7 @@ let
}; };
}; };
in in
kdeWrapper unwrapped { kdeWrapper {
inherit unwrapped;
targets = [ "bin/okular" ]; targets = [ "bin/okular" ];
} }

View File

@ -18,7 +18,8 @@ let
]; ];
}; };
in in
kdeWrapper unwrapped { kdeWrapper {
inherit unwrapped;
targets = [ "bin/spectacle" ]; targets = [ "bin/spectacle" ];
paths = [ kipi-plugins ]; paths = [ kipi-plugins ];
} }

View File

@ -15,6 +15,7 @@ let
]; ];
}; };
in in
kdeWrapper unwrapped { kdeWrapper {
inherit unwrapped;
targets = [ "bin/oxygen-demo5" "bin/oxygen-settings5" ]; targets = [ "bin/oxygen-demo5" "bin/oxygen-settings5" ];
} }

View File

@ -1,31 +1,47 @@
{ stdenv, lib, makeWrapper, buildEnv }: { stdenv, lib, makeWrapper, buildEnv }:
drv: packages:
{ targets, paths ? [] }:
let let
packages_ = if builtins.isList packages then packages else [packages];
unwrapped = lib.concatMap (p: if builtins.isList p.unwrapped then p.unwrapped else [p.unwrapped]) packages_;
targets = lib.concatMap (p: p.targets) packages_;
paths = lib.concatMap (p: p.paths or []) packages_;
name =
if builtins.length unwrapped == 1
then (lib.head unwrapped).name
else "kde-application";
meta =
if builtins.length unwrapped == 1
then (lib.head unwrapped).meta
else {};
env = buildEnv { env = buildEnv {
inherit (drv) name meta; inherit name meta;
paths = builtins.map lib.getBin ([drv] ++ paths); paths = builtins.map lib.getBin (unwrapped ++ paths);
pathsToLink = [ "/bin" "/share" "/lib/qt5" "/etc/xdg" ]; pathsToLink = [ "/bin" "/share" "/lib/qt5" "/etc/xdg" ];
}; };
in in
stdenv.mkDerivation { stdenv.mkDerivation {
inherit (drv) name meta; inherit name meta;
preferLocalBuild = true; preferLocalBuild = true;
paths = builtins.map lib.getBin ([drv] ++ paths); inherit unwrapped env targets;
inherit drv env targets;
passthru = { unwrapped = drv; }; passthru = {
inherit targets paths;
unwrapped = if builtins.length unwrapped == 1 then lib.head unwrapped else unwrapped;
};
nativeBuildInputs = [ makeWrapper ]; nativeBuildInputs = [ makeWrapper ];
builder = builtins.toFile "builder.sh" '' buildCommand = ''
. $stdenv/setup
for t in $targets; do for t in $targets; do
good=""
for drv in $unwrapped; do
if [ -a "$drv/$t" ]; then if [ -a "$drv/$t" ]; then
makeWrapper "$drv/$t" "$out/$t" \ makeWrapper "$drv/$t" "$out/$t" \
--argv0 '"$0"' \ --argv0 '"$0"' \
@ -35,19 +51,23 @@ stdenv.mkDerivation {
--set QML_IMPORT_PATH "$env/lib/qt5/imports" \ --set QML_IMPORT_PATH "$env/lib/qt5/imports" \
--set QML2_IMPORT_PATH "$env/lib/qt5/qml" \ --set QML2_IMPORT_PATH "$env/lib/qt5/qml" \
--set QT_PLUGIN_PATH "$env/lib/qt5/plugins" --set QT_PLUGIN_PATH "$env/lib/qt5/plugins"
else good="1"
echo "no such file or directory: $drv/$t" break
fi
done
if [ -z "$good" ]; then
echo "file or directory not found in derivations: $t"
exit 1 exit 1
fi fi
done done
if [ -a "$drv/share" ]; then ln -s "$env/share" "$out"
ln -s "$drv/share" "$out"
fi
for drv in $unwrapped; do
if [ -a "$drv/nix-support/propagated-user-env-packages" ]; then if [ -a "$drv/nix-support/propagated-user-env-packages" ]; then
mkdir -p "$out/nix-support" mkdir -p "$out/nix-support"
ln -s "$drv/nix-support/propagated-user-env-packages" "$out/nix-support/" cat "$drv/nix-support/propagated-user-env-packages" >> "$out/nix-support/propagated-user-env-packages"
fi fi
done
''; '';
} }

View File

@ -23,6 +23,7 @@ let
propagatedBuildInputs = [ kconfig kinit ]; propagatedBuildInputs = [ kconfig kinit ];
}; };
in in
kdeWrapper unwrapped { kdeWrapper {
inherit unwrapped;
targets = [ "bin/kronometer" ]; targets = [ "bin/kronometer" ];
} }

View File

@ -37,6 +37,7 @@ let
}; };
in kdeWrapper unwrapped { in kdeWrapper {
inherit unwrapped;
targets = [ "bin/peruse" ]; targets = [ "bin/peruse" ];
} }