X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/96d910c770b9443e204e183d3f3a8720c346a79c..9f004a9ea97dd456dced1c4607da76924aa47870:/receiver.c diff --git a/receiver.c b/receiver.c index 9e40fcbf..3ce55286 100644 --- a/receiver.c +++ b/receiver.c @@ -65,10 +65,6 @@ static void delete_one(char *fn, int is_dir) rprintf(FINFO, "deleting %s\n", safe_fname(fn)); } else { if (do_rmdir(fn) != 0) { - if (errno == ENOTDIR && keep_dirlinks) { - delete_one(fn, 0); - return; - } if (errno != ENOTEMPTY && errno != EEXIST) { rsyserr(FERROR, errno, "delete_one: rmdir %s failed", @@ -438,6 +434,11 @@ int recv_files(int f_in, struct file_list *flist, char *local_name) } else fnamecmp = partialptr = fname; + if (inplace && make_backups) { + if (!(fnamecmp = get_backup_name(fname))) + fnamecmp = partialptr; + } + /* open the file */ fd1 = do_open(fnamecmp, O_RDONLY, 0); @@ -489,10 +490,10 @@ int recv_files(int f_in, struct file_list *flist, char *local_name) /* We now check to see if we are writing file "inplace" */ if (inplace) { - fd2 = do_open(fnamecmp, O_WRONLY|O_CREAT, 0); + fd2 = do_open(fname, O_WRONLY|O_CREAT, 0); if (fd2 == -1) { rsyserr(FERROR, errno, "open %s failed", - full_fname(fnamecmp)); + full_fname(fname)); discard_receive_data(f_in, file->length); if (fd1 != -1) close(fd1);