X-Git-Url: https://ruderich.org/simon/gitweb/?a=blobdiff_plain;ds=inline;f=bin%2Fsrsync-incremental;h=9ade4e454868570eeec7e021b779e53a28db29b5;hb=7c065655225e7e80c3aa11561b0d97daa2880ae4;hp=9ebf41949518ba541d2ee6cdedce24b38b2a44d0;hpb=392f7c624686e93ed5236648a612717d8c469c73;p=config%2Fdotfiles.git
diff --git a/bin/srsync-incremental b/bin/srsync-incremental
index 9ebf419..9ade4e4 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-2013 Simon Ruderich
+# Copyright (C) 2011-2017 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,6 +21,8 @@
# along with this program. If not, see .
+set -eu
+
if test "$#" -lt 2; then
echo "Usage: $0 " >&2
echo
@@ -28,26 +30,33 @@ if test "$#" -lt 2; then
exit 2
fi
-cd "$1" || exit 1
-shift
-dest=`echo backup-*`
-if test "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
+cd "$1"
+shift
-target=backup-`date '+%Y-%m-%d-%H-%M-%S'`
+# Get path to last backup directory.
+dest=./
+for x in backup-*; do
+ test -d "$x" || continue
+ dest="../$x" # relative to destination directory
+done
-if test -d current; then
- echo "Target directory 'current' already exists, aborting." >&2
- exit 1
-fi
+target="backup-$(date '+%Y-%m-%d-%H-%M-%S')"
+target_tmp="partial-$target"
-mkdir current
+mkdir "$target_tmp"
rsync \
--verbose --itemize-changes --human-readable \
- --archive --hard-links --numeric-ids --one-file-system \
+ --archive --acls --xattrs --hard-links --sparse --numeric-ids \
+ --one-file-system \
--link-dest="$dest" \
- "$@" current \
-&& mv current "$target"
+ "$@" "$target_tmp" \
+|| {
+ # Try to remove the target directory without changing the exit code. In
+ # case the connection failed without transferring any files, we want to
+ # remove the empty directory.
+ code=$?
+ rmdir "$target_tmp" 2>/dev/null || true
+ exit $code
+}
+mv "$target_tmp" "$target"