From ee1df1ccae77a2820b223088b017a4f86a77a279 Mon Sep 17 00:00:00 2001 From: Wayne Davison Date: Fri, 21 May 2004 08:43:03 +0000 Subject: [PATCH] If --backup was specified without a --backup-dir, don't preserve the directory timestamps. --- rsync.c | 11 +++++++---- 1 file changed, 7 insertions(+), 4 deletions(-) diff --git a/rsync.c b/rsync.c index 7af64e7e..a9119fca 100644 --- a/rsync.c +++ b/rsync.c @@ -30,7 +30,10 @@ extern int am_sender; extern int am_generator; extern int preserve_uid; extern int preserve_gid; +extern int force_delete; +extern int recurse; extern int make_backups; +extern char *backup_dir; /* @@ -52,10 +55,8 @@ int delete_file(char *fname) DIR *d; struct dirent *di; char buf[MAXPATHLEN]; - extern int force_delete; STRUCT_STAT st; int ret; - extern int recurse; #if SUPPORT_LINKS ret = do_lstat(fname, &st); @@ -127,7 +128,8 @@ int set_perms(char *fname,struct file_struct *file,STRUCT_STAT *st, STRUCT_STAT st2; int change_uid, change_gid; - if (dry_run) return 0; + if (dry_run) + return 0; if (!st) { if (link_stat(fname,&st2) != 0) { @@ -138,7 +140,8 @@ int set_perms(char *fname,struct file_struct *file,STRUCT_STAT *st, st = &st2; } - if (!preserve_times || S_ISLNK(st->st_mode)) + if (!preserve_times || S_ISLNK(st->st_mode) + || (make_backups && !backup_dir && S_ISDIR(st->st_mode))) flags |= PERMS_SKIP_MTIME; if (!(flags & PERMS_SKIP_MTIME) && cmp_modtime(st->st_mtime, file->modtime) != 0) { -- 2.34.1