X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/66203a982b3d249bafda9b9272c4c103c19e4a9b..45a8354004ecbc1c0b03d6e880b512854ed9439a:/rsync.c diff --git a/rsync.c b/rsync.c index 039e1cd5..44d54dac 100644 --- a/rsync.c +++ b/rsync.c @@ -43,7 +43,7 @@ void free_sums(struct sum_struct *s) /* - * delete a file or directory. If force_delet is set then delete + * delete a file or directory. If force_delete is set then delete * recursively */ int delete_file(char *fname) @@ -56,19 +56,17 @@ int delete_file(char *fname) int ret; extern int recurse; - if (robust_unlink(fname) == 0 || errno == ENOENT) return 0; - #if SUPPORT_LINKS ret = do_lstat(fname, &st); #else ret = do_stat(fname, &st); #endif if (ret) { - rprintf(FERROR,"stat(%s) : %s\n", fname, strerror(errno)); return -1; } if (!S_ISDIR(st.st_mode)) { + if (robust_unlink(fname) == 0 || errno == ENOENT) return 0; rprintf(FERROR,"unlink(%s) : %s\n", fname, strerror(errno)); return -1; } @@ -164,7 +162,7 @@ int set_perms(char *fname,struct file_struct *file,STRUCT_STAT *st, } if (preserve_times && !S_ISLNK(st->st_mode) && - st->st_mtime != file->modtime) { + cmp_modtime(st->st_mtime, file->modtime) != 0) { /* don't complain about not setting times on directories because some filesystems can't do it */ if (set_modtime(fname,file->modtime) != 0 &&