mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-07-13 21:50:33 +03:00
nixos/plymouth: use new runtime paths for plugins and themes
This commit is contained in:
parent
5220b6e2e0
commit
ef0c0d5c2f
1 changed files with 32 additions and 15 deletions
|
@ -134,6 +134,13 @@ in
|
||||||
# XXX: Needed because we supply a different set of plugins in initrd.
|
# XXX: Needed because we supply a different set of plugins in initrd.
|
||||||
environment.etc."plymouth/plugins".source = "${plymouth}/lib/plymouth";
|
environment.etc."plymouth/plugins".source = "${plymouth}/lib/plymouth";
|
||||||
|
|
||||||
|
systemd.tmpfiles.rules = [
|
||||||
|
"d /run/plymouth 0755 root root 0 -"
|
||||||
|
"L+ /run/plymouth/plymouthd.defaults - - - - /etc/plymouth/plymouthd.defaults"
|
||||||
|
"L+ /run/plymouth/themes - - - - /etc/plymouth/themes"
|
||||||
|
"L+ /run/plymouth/plugins - - - - /etc/plymouth/plugins"
|
||||||
|
];
|
||||||
|
|
||||||
systemd.packages = [ plymouth ];
|
systemd.packages = [ plymouth ];
|
||||||
|
|
||||||
systemd.services.plymouth-kexec.wantedBy = [ "kexec.target" ];
|
systemd.services.plymouth-kexec.wantedBy = [ "kexec.target" ];
|
||||||
|
@ -160,8 +167,8 @@ in
|
||||||
contents = {
|
contents = {
|
||||||
# Files
|
# Files
|
||||||
"/etc/plymouth/plymouthd.conf".source = configFile;
|
"/etc/plymouth/plymouthd.conf".source = configFile;
|
||||||
"/etc/plymouth/plymouthd.defaults".source = "${plymouth}/share/plymouth/plymouthd.defaults";
|
|
||||||
"/etc/plymouth/logo.png".source = cfg.logo;
|
"/etc/plymouth/logo.png".source = cfg.logo;
|
||||||
|
"/etc/plymouth/plymouthd.defaults".source = "${plymouth}/share/plymouth/plymouthd.defaults";
|
||||||
# Directories
|
# Directories
|
||||||
"/etc/plymouth/plugins".source = pkgs.runCommand "plymouth-initrd-plugins" {} ''
|
"/etc/plymouth/plugins".source = pkgs.runCommand "plymouth-initrd-plugins" {} ''
|
||||||
# Check if the actual requested theme is here
|
# Check if the actual requested theme is here
|
||||||
|
@ -174,8 +181,8 @@ in
|
||||||
|
|
||||||
mkdir -p $out/renderers
|
mkdir -p $out/renderers
|
||||||
# module might come from a theme
|
# module might come from a theme
|
||||||
cp ${themesEnv}/lib/plymouth/{text,details,label,$moduleName}.so $out
|
cp ${themesEnv}/lib/plymouth/*.so $out
|
||||||
cp ${plymouth}/lib/plymouth/renderers/{drm,frame-buffer}.so $out/renderers
|
cp ${plymouth}/lib/plymouth/renderers/*.so $out/renderers
|
||||||
'';
|
'';
|
||||||
"/etc/plymouth/themes".source = pkgs.runCommand "plymouth-initrd-themes" {} ''
|
"/etc/plymouth/themes".source = pkgs.runCommand "plymouth-initrd-themes" {} ''
|
||||||
# Check if the actual requested theme is here
|
# Check if the actual requested theme is here
|
||||||
|
@ -184,19 +191,24 @@ in
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
mkdir $out
|
mkdir -p $out/${cfg.theme}
|
||||||
cp -r ${themesEnv}/share/plymouth/themes/${cfg.theme} $out
|
cp -r ${themesEnv}/share/plymouth/themes/${cfg.theme}/* $out/${cfg.theme}
|
||||||
# Copy more themes if the theme depends on others
|
# Copy more themes if the theme depends on others
|
||||||
for theme in $(grep -hRo '/etc/plymouth/themes/.*$' $out | xargs -n1 basename); do
|
for theme in $(grep -hRo '/share/plymouth/themes/.*$' $out | xargs -n1 basename); do
|
||||||
if [[ -d "${themesEnv}/share/plymouth/themes/$theme" ]]; then
|
if [[ -d "${themesEnv}/share/plymouth/themes/$theme" ]]; then
|
||||||
if [[ ! -d "$out/$theme" ]]; then
|
if [[ ! -d "$out/$theme" ]]; then
|
||||||
echo "Adding dependent theme: $theme"
|
echo "Adding dependent theme: $theme"
|
||||||
cp -r "${themesEnv}/share/plymouth/themes/$theme" $out
|
mkdir -p "$out/$theme"
|
||||||
|
cp -r "${themesEnv}/share/plymouth/themes/$theme"/* "$out/$theme"
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
echo "Missing theme dependency: $theme"
|
echo "Missing theme dependency: $theme"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
# Fixup references
|
||||||
|
for theme in $out/*/*.plymouth; do
|
||||||
|
sed -i "s,${builtins.storeDir}/.*/share/plymouth/themes,$out," "$theme"
|
||||||
|
done
|
||||||
'';
|
'';
|
||||||
|
|
||||||
# Fonts
|
# Fonts
|
||||||
|
@ -225,6 +237,11 @@ in
|
||||||
plymouth-switch-root-initramfs.wantedBy = [ "halt.target" "kexec.target" "plymouth-switch-root-initramfs.service" "poweroff.target" "reboot.target" ];
|
plymouth-switch-root-initramfs.wantedBy = [ "halt.target" "kexec.target" "plymouth-switch-root-initramfs.service" "poweroff.target" "reboot.target" ];
|
||||||
plymouth-switch-root.wantedBy = [ "initrd-switch-root.target" ];
|
plymouth-switch-root.wantedBy = [ "initrd-switch-root.target" ];
|
||||||
};
|
};
|
||||||
|
# Link in runtime files before starting
|
||||||
|
services.plymouth-start.preStart = ''
|
||||||
|
mkdir -p /run/plymouth
|
||||||
|
ln -sf /etc/plymouth/{plymouthd.defaults,themes,plugins} /run/plymouth/
|
||||||
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
# Insert required udev rules. We take stage 2 systemd because the udev
|
# Insert required udev rules. We take stage 2 systemd because the udev
|
||||||
|
@ -249,8 +266,8 @@ in
|
||||||
|
|
||||||
mkdir -p $out/lib/plymouth/renderers
|
mkdir -p $out/lib/plymouth/renderers
|
||||||
# module might come from a theme
|
# module might come from a theme
|
||||||
cp ${themesEnv}/lib/plymouth/{text,details,label,$moduleName}.so $out/lib/plymouth
|
cp ${themesEnv}/lib/plymouth/*.so $out/lib/plymouth
|
||||||
cp ${plymouth}/lib/plymouth/renderers/{drm,frame-buffer}.so $out/lib/plymouth/renderers
|
cp ${plymouth}/lib/plymouth/renderers/*.so $out/lib/plymouth/renderers
|
||||||
|
|
||||||
mkdir -p $out/share/plymouth/themes
|
mkdir -p $out/share/plymouth/themes
|
||||||
cp ${plymouth}/share/plymouth/plymouthd.defaults $out/share/plymouth
|
cp ${plymouth}/share/plymouth/plymouthd.defaults $out/share/plymouth
|
||||||
|
@ -267,7 +284,7 @@ in
|
||||||
chmod -R +w themes
|
chmod -R +w themes
|
||||||
find themes -type f | while read file
|
find themes -type f | while read file
|
||||||
do
|
do
|
||||||
sed -i "s,/nix/.*/share/plymouth/themes,$out/share/plymouth/themes,g" $file
|
sed -i "s,${builtins.storeDir}/.*/share/plymouth/themes,$out/share/plymouth/themes,g" $file
|
||||||
done
|
done
|
||||||
|
|
||||||
# Install themes
|
# Install themes
|
||||||
|
@ -275,7 +292,7 @@ in
|
||||||
|
|
||||||
# Install logo
|
# Install logo
|
||||||
mkdir -p $out/etc/plymouth
|
mkdir -p $out/etc/plymouth
|
||||||
cp -r -L ${themesEnv}/etc/plymouth $out
|
cp -r -L ${themesEnv}/etc/plymouth $out/etc
|
||||||
|
|
||||||
# Setup font
|
# Setup font
|
||||||
mkdir -p $out/share/fonts
|
mkdir -p $out/share/fonts
|
||||||
|
@ -304,11 +321,11 @@ in
|
||||||
boot.initrd.preLVMCommands = mkIf (!config.boot.initrd.systemd.enable) (mkAfter ''
|
boot.initrd.preLVMCommands = mkIf (!config.boot.initrd.systemd.enable) (mkAfter ''
|
||||||
mkdir -p /etc/plymouth
|
mkdir -p /etc/plymouth
|
||||||
mkdir -p /run/plymouth
|
mkdir -p /run/plymouth
|
||||||
|
ln -s $extraUtils/etc/plymouth/logo.png /etc/plymouth/logo.png
|
||||||
ln -s ${configFile} /etc/plymouth/plymouthd.conf
|
ln -s ${configFile} /etc/plymouth/plymouthd.conf
|
||||||
ln -s $extraUtils/share/plymouth/plymouthd.defaults /etc/plymouth/plymouthd.defaults
|
ln -s $extraUtils/share/plymouth/plymouthd.defaults /run/plymouth/plymouthd.defaults
|
||||||
ln -s $extraUtils/share/plymouth/logo.png /etc/plymouth/logo.png
|
ln -s $extraUtils/share/plymouth/themes /run/plymouth/themes
|
||||||
ln -s $extraUtils/share/plymouth/themes /etc/plymouth/themes
|
ln -s $extraUtils/lib/plymouth /run/plymouth/plugins
|
||||||
ln -s $extraUtils/lib/plymouth /etc/plymouth/plugins
|
|
||||||
ln -s $extraUtils/etc/fonts /etc/fonts
|
ln -s $extraUtils/etc/fonts /etc/fonts
|
||||||
|
|
||||||
plymouthd --mode=boot --pid-file=/run/plymouth/pid --attach-to-session
|
plymouthd --mode=boot --pid-file=/run/plymouth/pid --attach-to-session
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue