X-Git-Url: https://ruderich.org/simon/gitweb/?a=blobdiff_plain;f=bin%2Fsrsync-incremental;h=0ae1e56c208e562b839628862e11ab32bb2fcc19;hb=9df13622741df2a99bd4067157486098638610b8;hp=aa2c977c056a2898c7ad0c7ac90acd947c6c202f;hpb=71bd44e6c82a82f3f0ca868c93217f6c522b5d22;p=config%2Fdotfiles.git diff --git a/bin/srsync-incremental b/bin/srsync-incremental index aa2c977..0ae1e56 100755 --- a/bin/srsync-incremental +++ b/bin/srsync-incremental @@ -5,7 +5,7 @@ # Thanks to http://www.sanitarium.net/golug/rsync_backups_2010.html for the # idea. -# Copyright (C) 2011-2012 Simon Ruderich +# Copyright (C) 2011-2014 Simon Ruderich # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -21,25 +21,28 @@ # along with this program. If not, see . -if [ $# -lt 2 ]; then +set -eu + +if test "$#" -lt 2; then echo "Usage: $0 " >&2 echo echo "Note: The target directory is the _first_ argument!" >&2 exit 2 fi -cd "$1" || exit 1 + +cd "$1" shift -dest=`echo backup-*` -if [ "x$dest" != 'xbackup-*' ]; then - # -F and grep is used to list only directories, zsh's *(/) would be great. - dest="`pwd`/`ls -1dF backup-* | grep / | tail -n1`" -fi +# Get absolute path to last backup directory. +for x in backup-*; do + test -d "$x" || continue + dest="../$x" # relative to destination directory +done target=backup-`date '+%Y-%m-%d-%H-%M-%S'` -if [ -d current ]; then +if test -d current; then echo "Target directory 'current' already exists, aborting." >&2 exit 1 fi @@ -47,7 +50,15 @@ fi mkdir current rsync \ --verbose --itemize-changes --human-readable \ - --archive --hard-links --numeric-ids --one-file-system \ + --archive --hard-links --sparse --numeric-ids --one-file-system \ --link-dest="$dest" \ "$@" current \ -&& mv current "$target" +|| { + # Try to remove "current" without changing the exit code. In case the + # connection failed without transferring any files, we want the next + # backup to be able to run. + code=$? + rmdir current 2>/dev/null || true + exit $code +} +mv current "$target"