X-Git-Url: https://git.grml.org/?p=grml-autoconfig.git;a=blobdiff_plain;f=bin%2Fsave-config;h=f7ef85dc2818c39cd29101e4496a46e3a9dc9c52;hp=63483c016c942f4f553250010f7f85b7370d8a45;hb=02c0126afa706977c2c7941945b24c487a13bd57;hpb=2153d1e36c5834064f9c0b2455e2d601eef1762d diff --git a/bin/save-config b/bin/save-config index 63483c0..f7ef85d 100755 --- a/bin/save-config +++ b/bin/save-config @@ -4,7 +4,6 @@ # Authors: grml-team (grml.org), (c) Michael Prokop # Bug-Reports: see http://grml.org/bugs/ # License: This file is licensed under the GPL v2. -# Latest change: Son Mai 13 11:46:44 CEST 2007 [mika] ################################################################################ # some zsh-stuff {{{ @@ -15,18 +14,27 @@ # }}} # set variables {{{ - - # old linuxrc version: - [ -d /cdrom ] && OLDLAYOUT=1 || OLDLAYOUT='' - # new initramfs layout: - [ -d /live/image ] && NEWLAYOUT=1 || NEWLAYOUT='' - LANG=C LC_ALL=C - [[ $(id -u) != 0 ]] && runas='sudo' # important for /etc + [[ $UID != 0 ]] && runas='sudo' # important for /etc + + if [ -d /live/overlay ] ; then + CHANGE_DIR='/live/overlay' + elif [ -d /live/image ] ; then # old version + CHANGE_DIR='/live/image' + else + echo "Error: no overlay directories found (neither /live/overlay nor /live/image)." >&2 + bailout; exit 1 + fi + + if [ -d /live/rofs ] ; then + ORIG_DIR="$(find /live/rofs/ -maxdepth 1 -name \*.squashfs | head -1)" + else # old version + ORIG_DIR="/GRML" + fi - check4progs mutt || echo "Warning, mutt not available for mail handling.">&2 - check4progs findchanged tar || { echo "Sorry, can't continue. Exiting.">&2 ; exit 1 } + check4progs mutt &>/dev/null || echo "Warning, mutt not available for mail handling.">&2 + check4progs tar || { echo "Sorry, can't continue. Exiting.">&2 ; bailout ; exit 1 } CONFIG=/etc/grml/saveconfig [ -r "$CONFIG" ] && . $CONFIG @@ -37,10 +45,11 @@ GRML_VERSION=$(awk '{print $1}' /etc/grml_version 2>/dev/null || print "not a grml system") KERNEL=$(uname -a) - TMPDIR=/tmp - MAILFILE="$TMPDIR/mail.txt" + TMPDIR='/tmp' + MAILFILE="${TMPDIR}/mail.txt" [ -n "$FILELIST" ] || FILELIST=$(mktemp $TMPDIR/filelist.XXXXXX) +# }}} # functions {{{ debug(){ @@ -57,6 +66,16 @@ bailout(){ } trap bailout 1 2 3 15 + +findchanged() { + if [ -d "$1" ]; then + for i in `(cd "$1"; find . -type f 2>/dev/null | sed 's,^\./,,g' | grep -v ' ' )`; do + cmp -s "$1/$i" "$2/$i" || echo "$1/$i" + done + elif [ -e "$1" ]; then + cmp -s "$1" "$2" || echo "$1" + fi +} # }}} # usage information {{{ @@ -122,32 +141,37 @@ save_grmlhome(){ save_etc(){ debug "save etc" if [ -n "$NEWLAYOUT" ] ; then - $runas find /live/cow/etc | sed -e 's#/live/cow## ; /etc$/d' >> $FILELIST + $runas find "${CHANGE_DIR}/etc" | sed -e "s#${CHANGE_DIR}## ; /etc$/d" >> $FILELIST else - $runas findchanged /etc /GRML/etc >> $FILELIST + $runas findchanged /etc "${ORIG_DIR}/etc" >> $FILELIST fi } save_configdir(){ debug "save configdir" if [ -d $HOME/config ] ; then - ls $HOME/config/* >> $FILELIST 2>/dev/null + ls $HOME/config/* >> $FILELIST 2>/dev/null ls $HOME/config/.* >> $FILELIST 2>/dev/null fi } +# }}} # create configuration file {{{ create_config(){ if ! [ -r "$FILELIST" ]; then - echo "Sorry, filelist $FILELIST could not be read." >&2 - echo "Error when generating $FILENAME." >&2 + echo "Filelist $FILELIST could not be read." >&2 + echo "Error when generating $FILENAME." >&2 + bailout ; exit 1 else - # GNU tar sucks so much, really. Avoid the "file changed as we read it": - tar cf /dev/null /etc - # now really execute the according tar command: - BZIP2=-9 $runas tar -T - -cpPjf "$FILENAME" <"$FILELIST" && \ - echo "Successfully stored configuration in file $FILENAME" || \ - echo "Error when generating $FILENAME." >&2 + # GNU tar sucks so much, really. Avoid the "file changed as we read it": + tar cf /dev/null /etc + # now really execute the according tar command: + if BZIP2=-9 $runas tar -T - -cpPjf "$FILENAME" <"$FILELIST" ; then + echo "Successfully stored configuration in file $FILENAME" + else + echo "Error when generating $FILENAME." >&2 + bailout ; exit 1 + fi fi } # }}} @@ -213,6 +237,7 @@ parse_options() parse_options $* # }}} +# execution wrapper {{{ runit(){ if [[ $SAVE_HOME == "yes" ]]; then debug "running save_home" @@ -235,9 +260,11 @@ runit(){ SETSAVE=1 fi if [ -z $SETSAVE ] ; then - echo "Sorry, you did not select any configuration which should be saved. Exiting." ; exit 1 + echo "Sorry, you did not select any configuration which should be saved. Exiting." + bailout ; exit 1 fi } +# }}} # now run it runit