mirror of
git://slackware.nl/current.git
synced 2025-01-18 22:27:20 +01:00
32 lines
817 B
Bash
32 lines
817 B
Bash
|
config() {
|
||
|
NEW="$1"
|
||
|
OLD="`dirname $NEW`/`basename $NEW .new`"
|
||
|
# If there's no config file by that name, mv it over:
|
||
|
if [ ! -r $OLD ]; then
|
||
|
mv $NEW $OLD
|
||
|
elif [ "`cat $OLD | md5sum`" = "`cat $NEW | md5sum`" ]; then # toss the redundant copy
|
||
|
rm $NEW
|
||
|
fi
|
||
|
# Otherwise, we leave the .new copy for the admin to consider...
|
||
|
}
|
||
|
for file in etc/cups/*.new ; do
|
||
|
config $file
|
||
|
done
|
||
|
|
||
|
if [ -r etc/pam.d/cups.new ]; then
|
||
|
config etc/pam.d/cups.new
|
||
|
fi
|
||
|
|
||
|
# Leave any new rc.cups with the same permissions as the old one:
|
||
|
# This is a kludge, but it's because there's no --reference option
|
||
|
# on busybox's 'chmod':
|
||
|
if [ -e etc/rc.d/rc.cups ]; then
|
||
|
if [ -x etc/rc.d/rc.cups ]; then
|
||
|
chmod 755 etc/rc.d/rc.cups.new
|
||
|
else
|
||
|
chmod 644 etc/rc.d/rc.cups.new
|
||
|
fi
|
||
|
fi
|
||
|
# Then config() it:
|
||
|
config etc/rc.d/rc.cups.new
|