Add a trigger to (un)register shells from /etc/shells.

--HG--
extra : convert_revision : 6f82e9b19f880b388d5e800e1d159f4f3287ab26
This commit is contained in:
Juan RP 2009-03-14 07:32:01 +01:00
parent fdffaf481b
commit c2228d084b
2 changed files with 62 additions and 3 deletions

View File

@ -1,6 +1,6 @@
# Template file for 'xbps-base-dirs'
pkgname=xbps-base-dirs
version=0.4
version=0.5
build_style=custom-install
short_desc="xbps base system directories"
maintainer="Juan RP <xtraeme@gmail.com>"
@ -51,7 +51,8 @@ do_install()
cd $DESTDIR/usr && ln -s lib lib64
fi
for f in $(find $XBPS_TRIGGERSDIR -type f -perm 755); do
install -D -m 755 $f $DESTDIR/var/db/xbps/triggers/$(basename $f)
for f in info-files initramfs-tools register-shell; do
install -D -m 755 $XBPS_TRIGGERSDIR/$f \
$DESTDIR/var/db/xbps/triggers/$(basename $f)
done
}

58
triggers/register-shell Executable file
View File

@ -0,0 +1,58 @@
#!/bin/sh
#
# Registers or unregisters a shell in /etc/shells.
#
# Arguments: $1 = action [run/targets]
# $2 = target [post-install]
# $3 = pkgname
# $4 = version
#
trigger="register-shell"
shells_file="./var/db/xbps/metadata/$3/shells"
case "$1" in
targets)
echo "post-install post-remove"
;;
run)
[ "$2" != "post-install" -a "$2" != "post-remove" ] && exit 1
[ ! -f ${shells_file} ] && exit 1
echo "Running $trigger trigger..."
case "$2" in
post-install)
if [ ! -f ./etc/shells ]; then
cat ${shells_file} | while read line; do
echo $line >> ./etc/shells
echo "Registered $line into /etc/shells."
done
chmod 644 ./etc/shells
else
cat ${shells_file} | while read line; do
if ! grep -q $line ./etc/shells; then
echo $line >> ./etc/shells
echo "Registered $line into /etc/shells."
fi
done
fi
;;
post-remove)
if [ -f ./etc/shells ]; then
cat ${shells_file} | while read line; do
if grep -q $line ./etc/shells; then
shell=$(echo $line | sed "s|\\/|\\\/|g")
sed -i -e "/$shell/d" ./etc/shells
echo "Unregistered $line from /etc/shells."
fi
done
fi
;;
esac
;;
*)
exit 1
;;
esac
exit 0