db41c787f4
Since #81475 this caused the wrapper to be empty of entries from wrapGAppsHook because the wrapGAppsHook function doesn't add them anymore, and was moved to gappsWrapperArgsHook. Instead of just running that in postBuild it's more future proof to make this use stdenv.mkDerivation because we want to mess around with the generic builder.
60 lines
1.1 KiB
Nix
60 lines
1.1 KiB
Nix
{ lib
|
|
, wrapGAppsHook
|
|
, glib
|
|
, stdenv
|
|
, xorg
|
|
, wingpanel
|
|
, wingpanelIndicators
|
|
, switchboard-with-plugs
|
|
, indicators ? null
|
|
# Only useful to disable for development testing.
|
|
, useDefaultIndicators ? true
|
|
}:
|
|
|
|
let
|
|
selectedIndicators =
|
|
if indicators == null then wingpanelIndicators
|
|
else indicators ++ (lib.optionals useDefaultIndicators wingpanelIndicators);
|
|
in
|
|
stdenv.mkDerivation rec {
|
|
name = "${wingpanel.name}-with-indicators";
|
|
|
|
src = null;
|
|
|
|
paths = [
|
|
wingpanel
|
|
] ++ selectedIndicators;
|
|
|
|
passAsFile = [ "paths" ];
|
|
|
|
nativeBuildInputs = [
|
|
glib
|
|
wrapGAppsHook
|
|
];
|
|
|
|
buildInputs = lib.forEach selectedIndicators (x: x.buildInputs)
|
|
++ selectedIndicators;
|
|
|
|
dontUnpack = true;
|
|
dontConfigure = true;
|
|
dontBuild = true;
|
|
|
|
preferLocalBuild = true;
|
|
allowSubstitutes = false;
|
|
|
|
installPhase = ''
|
|
mkdir -p $out
|
|
for i in $(cat $pathsPath); do
|
|
${xorg.lndir}/bin/lndir -silent $i $out
|
|
done
|
|
'';
|
|
|
|
preFixup = ''
|
|
gappsWrapperArgs+=(
|
|
--set WINGPANEL_INDICATORS_PATH "$out/lib/wingpanel"
|
|
--set SWITCHBOARD_PLUGS_PATH "${switchboard-with-plugs}/lib/switchboard"
|
|
)
|
|
'';
|
|
|
|
inherit (wingpanel) meta;
|
|
}
|