X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/31937d363b3e622f045781d410a5d718e87fa867..f5db09933011a8b4014336a09ece12690d8ba280:/generator.c diff --git a/generator.c b/generator.c index bbe70fb0..52daa7cd 100644 --- a/generator.c +++ b/generator.c @@ -240,6 +240,7 @@ static void recv_generator(char *fname, struct file_list *flist, struct file_struct *file, int ndx, int f_out, int f_out_name) { + static int missing_below = -1; int fd = -1, f_copy = -1; STRUCT_STAT st, partial_st; struct file_struct *back_file = NULL; @@ -251,8 +252,10 @@ static void recv_generator(char *fname, struct file_list *flist, if (list_only) return; - if (verbose > 2) - rprintf(FINFO, "recv_generator(%s,%d)\n", safe_fname(fname), ndx); + if (verbose > 2) { + rprintf(FINFO, "recv_generator(%s,%d)\n", + safe_fname(fname), ndx); + } if (server_filter_list.head && check_filter(&server_filter_list, fname, @@ -264,6 +267,10 @@ static void recv_generator(char *fname, struct file_list *flist, return; } + if (dry_run && missing_below >= 0 && file->dir.depth <= missing_below) { + dry_run--; + missing_below = -1; + } if (dry_run > 1) { statret = -1; stat_errno = ENOENT; @@ -301,6 +308,10 @@ static void recv_generator(char *fname, struct file_list *flist, delete_file(fname, DEL_TERSE); statret = -1; } + if (dry_run && statret != 0 && missing_below < 0) { + missing_below = file->dir.depth; + dry_run++; + } if (statret != 0 && do_mkdir(fname,file->mode) != 0 && errno != EEXIST) { if (!relative_paths || errno != ENOENT || create_directory_path(fname, orig_umask) < 0 @@ -318,8 +329,10 @@ static void recv_generator(char *fname, struct file_list *flist, delete_in_dir(flist, fname, file); return; } else if (max_size && file->length > max_size) { - if (verbose > 1) - rprintf(FINFO, "%s is over max-size\n", fname); + if (verbose > 1) { + rprintf(FINFO, "%s is over max-size\n", + safe_fname(fname)); + } return; } @@ -327,8 +340,10 @@ static void recv_generator(char *fname, struct file_list *flist, #if SUPPORT_LINKS if (safe_symlinks && unsafe_symlink(file->u.link, fname)) { if (verbose) { - rprintf(FINFO, "ignoring unsafe symlink %s -> \"%s\"\n", - full_fname(fname), file->u.link); + rprintf(FINFO, + "ignoring unsafe symlink %s -> \"%s\"\n", + full_fname(fname), + safe_fname(file->u.link)); } return; } @@ -446,7 +461,7 @@ static void recv_generator(char *fname, struct file_list *flist, if (verbose) { rsyserr(FINFO, errno, "link %s => %s", - fnamecmpbuf, + full_fname(fnamecmpbuf), safe_fname(fname)); } fnamecmp = fnamecmpbuf; @@ -519,12 +534,12 @@ prepare_to_open: statret = 0; } - if (dry_run || whole_file > 0) { + if (dry_run || read_batch) + goto notify_others; + if (whole_file > 0) { statret = -1; goto notify_others; } - if (read_batch) - goto notify_others; /* open the file */ fd = do_open(fnamecmp, O_RDONLY, 0); @@ -593,7 +608,7 @@ notify_others: set_perms(backupptr, back_file, NULL, 0); if (verbose > 1) { rprintf(FINFO, "backed up %s to %s\n", - fname, backupptr); + safe_fname(fname), safe_fname(backupptr)); } free(back_file); }