diff options
author | Giancarlo Razzolini <grazzolini@archlinux.org> | 2019-10-29 14:40:58 +0100 |
---|---|---|
committer | Giancarlo Razzolini <grazzolini@archlinux.org> | 2019-10-29 14:40:58 +0100 |
commit | 7f81f51a5b813343fe55253f60a865e75f42be52 (patch) | |
tree | be882a1dc6994eb353b33a9255e34cd0866c7067 /libalpm/scripts/mkinitcpio-remove | |
parent | 9ae6b1f928ef11e277437740908871ab535b655d (diff) | |
parent | c0ae6a74f30a586c91fb4a4f2ad773f1c018d8b6 (diff) | |
download | mkinitcpio-7f81f51a5b813343fe55253f60a865e75f42be52.tar.gz mkinitcpio-7f81f51a5b813343fe55253f60a865e75f42be52.tar.xz |
Merge branch 'alpm-hook'v27
Diffstat (limited to 'libalpm/scripts/mkinitcpio-remove')
-rw-r--r-- | libalpm/scripts/mkinitcpio-remove | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/libalpm/scripts/mkinitcpio-remove b/libalpm/scripts/mkinitcpio-remove new file mode 100644 index 0000000..86838e4 --- /dev/null +++ b/libalpm/scripts/mkinitcpio-remove @@ -0,0 +1,39 @@ +#!/bin/bash -e + +package=0 + +while read -r line; do + if [[ $line != */vmlinuz ]]; then + # triggers when it's a change to usr/lib/initcpio/* + package=1 + continue + fi + + if ! read -r pkgbase > /dev/null 2>&1 < "${line%/vmlinuz}/pkgbase"; then + # if the kernel has no pkgbase, we skip it + continue + fi + + # remove the actual kernel and images for the package being removed + kernel="/boot/vmlinuz-${pkgbase}" + preset="/etc/mkinitcpio.d/${pkgbase}.preset" + initramfs="/boot/initramfs-${pkgbase}.img" + fallback_initramfs="/boot/initramfs-${pkgbase}-fallback.img" + if [[ -e $kernel ]]; then + # remove the installed kernel + rm $kernel + fi + if [[ -e $preset ]]; then + # remove the preset + rm $preset + fi + if [[ -e $initramfs && -e $fallback_initramfs ]]; then + # remove the images + rm $initramfs $fallback_initramfs + fi +done + +if (( package )) && compgen -G /etc/mkinitcpio.d/"*.preset" > /dev/null; then + # remove all presets + rm /etc/mkinitcpio.d/*.preset +fi |