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
"KDE 4 should not be enabled at the same time as KDE 5";
@ -120,7 +133,6 @@ in
kde5.kdecoration
kde5.kdeplasma-addons
kde5.kgamma5
kde5.khelpcenter
kde5.khotkeys
kde5.kinfocenter
kde5.kmenuedit
@ -133,7 +145,6 @@ in
kde5.libkscreen
kde5.libksysguard
kde5.milou
kde5.oxygen
kde5.plasma-integration
kde5.polkit-kde-agent
kde5.systemsettings
@ -142,12 +153,10 @@ in
kde5.plasma-workspace
kde5.plasma-workspace-wallpapers
kde5.dolphin
kde5.dolphin-plugins
kde5.ffmpegthumbs
kde5.kdegraphics-thumbnailers
kde5.kio-extras
kde5.konsole
kde5.print-manager
# Install Breeze icons if available
@ -179,6 +188,15 @@ in
++ lib.optional config.services.colord.enable pkgs.colord-kde
++ 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.etc = singleton {
@ -186,9 +204,9 @@ in
target = "X11/xkb";
};
# Enable GTK applications to load SVG icons
environment.variables =
{
# Enable GTK applications to load SVG icons
GST_PLUGIN_SYSTEM_PATH_1_0 =
lib.makeSearchPath "/lib/gstreamer-1.0"
(builtins.map (pkg: pkg.out) (with pkgs.gst_all_1; [
@ -229,6 +247,7 @@ in
security.pam.services.kde = { allowNullPassword = true; };
};
})
];
}

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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