X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/7e9059d60fcead9a5e0108032da35fada4587fbb..da9f59264f3487b9c79b1ad2c95e8fd8625c1619:/generator.c diff --git a/generator.c b/generator.c index 7727e1f3..92954d4f 100644 --- a/generator.c +++ b/generator.c @@ -505,7 +505,7 @@ static int find_fuzzy(struct file_struct *file, struct file_list *dirlist) { int fname_len, fname_suf_len; const char *fname_suf, *fname = file->basename; - uint32 lowest_dist = 0x7FFFFFFF; + uint32 lowest_dist = 25 << 16; /* ignore a distance greater than 25 */ int j, lowest_j = -1; fname_len = strlen(fname); @@ -1221,9 +1221,18 @@ void generate_files(int f_out, struct file_list *flist, char *local_name) write_int(f_out, -1); - /* Read post-redo-phase MSG_DONE and any prior messages. */ + /* Read MSG_DONE for the redo phase (and any prior messages). */ get_redo_num(itemizing, code); + if (protocol_version >= 29) { + phase++; + if (verbose > 2) + rprintf(FINFO, "generate_files phase=%d\n", phase); + write_int(f_out, -1); + /* Read MSG_DONE for delay-update phase & prior messages. */ + get_redo_num(itemizing, code); + } + if (delete_after && !local_name && flist->count > 0) do_delete_pass(flist); @@ -1239,9 +1248,8 @@ void generate_files(int f_out, struct file_list *flist, char *local_name) continue; if (!need_retouch_dir_times && file->mode & S_IWUSR) continue; - recv_generator(local_name ? local_name : f_name(file), - file, i, itemizing, maybe_PERMS_REPORT, - code, -1); + recv_generator(f_name(file), file, i, itemizing, + maybe_PERMS_REPORT, code, -1); if (allowed_lull && !(j++ % lull_mod)) maybe_send_keepalive(); }