From 2b19c613bbb418da0fff6cddaa01a21b87271cb1 Mon Sep 17 00:00:00 2001 From: Carl Baldwin <cnb@ball.(none)> Date: Tue, 29 Nov 2005 10:00:16 -0700 Subject: [PATCH] Misc fixes to restore script. - Fix err function to output to standard err. - Use err function throughout script to make it more concise. - Add some more verbosity and examples to the Usage message to make it more clear how to use this script. - Don't output non-error messages to std-err. - Use -Z option to grep (Is this really necessary? I'm not sure) - Start grep pattern with ^ to only match the pattern at the beginning of the line --- scripts/restore-script.sh | 48 +++++++++++++++++---------------------- 1 file changed, 21 insertions(+), 27 deletions(-) diff --git a/scripts/restore-script.sh b/scripts/restore-script.sh index 66ac4fb..9d9baab 100755 --- a/scripts/restore-script.sh +++ b/scripts/restore-script.sh @@ -1,41 +1,35 @@ #!/bin/sh function err() { - echo 2>&1 "-E- $1" + echo >&2 "-E- $1" exit 1 } -if [ ! -z "$3" ]; then - mountdir=$3 -fi +[ -n "$3" ] && mountdir=$3 -if [ -z "$mountdir" ]; then - echo >&2 '$mountdir must be set' - exit 1 -fi - -if [ -z "$rundir" ]; then - echo >&2 '$rundir must be set' - exit 1 -fi +[ -z "$mountdir" ] && err '$mountdir must be set' +[ -z "$rundir" ] && err '$rundir must be set' export PATH=${rundir%%/}:/bin:/usr/bin:/sbin:/usr/sbin:/sw/bin -if [ ! -d "$1" -o ! -d "$2" ]; then - echo >&2 "Usage: $0 <source-dir> <target-dir> [<mnt-dir>]" - echo >&2 " source-dir - directory on backup disks to restore from" - echo >&2 " target-dir - directory to restore files to" - echo >&2 " mnt-dir - directory where backup disk is mounted (optional)" - echo >&2 "Example: $0 / / /mnt/cdrom" - exit 1 +if [ ! -d "$mountdir$1" -o ! -d "$2" ]; then + err " +Usage: $0 <source-dir> <relocate-dir> [<mnt-dir>] + source-dir - directory on backup disks to restore from (relative to $mountdir) + relocate-dir - base directory to restore files to (usually /) + mnt-dir - directory where backup disk is mounted (optional) + + Examples: + % $0 / / /mnt/cdrom # Restore everything from disks (explicitly specifying dvd mount point.) + % $0 / / # Restore everything from disks + % $0 /home / # Restore only files under /home on disks to /home on the system + % $0 /home /home # Restore files under /home on disks to /home/home on the system (probably not what you want.) +" fi device=$(mount | grep "on ${mountdir%%/} " | awk '{print$1}') -if [ -z "$device" ]; then - echo >&2 "Cannot determine cdrom device" - exit 1 -fi +[ -z "$device" ] && err "Cannot determine cdrom device" cp ${mountdir%%/}/backups.db ${mountdir%%/}/backup-status.txt $rundir dbfile=${rundir%%/}/backups.db @@ -47,8 +41,8 @@ for date in $dates; do while ! $success; do eject $device [ $? != 0 ] && err "Cannot eject the disk. Drive is busy. Run lsof $mountdir to see why." - echo >&2 "Please insert backup disk: $date" - echo >&2 "Press Enter to continue" + echo "Please insert backup disk: $date" + echo "Press Enter to continue" read bogus eject -t $device @@ -63,5 +57,5 @@ for date in $dates; do done rsyncopts="-W -H -S -l -p -t -g -o -0 --files-from=- --stats --progress" - cat $dbfile | files-from-date.sh $date | grep -z -e "${1}" | rsync $rsyncopts ${mountdir%%/}/ ${2%%/}/ + cat $dbfile | files-from-date.sh $date | grep -z -Z -e "^${1}" | rsync $rsyncopts ${mountdir%%/}/ ${2%%/}/ done -- 2.34.1