X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/6eee13cf580ef3270539098eead19259192aa497..c5b6e57a136d5bdc1eff9ef11e69c7093065920e:/compat.c diff --git a/compat.c b/compat.c index b090c2ad..52bba804 100644 --- a/compat.c +++ b/compat.c @@ -23,31 +23,39 @@ #include "rsync.h" int remote_protocol = 0; -int flist_extra_cnt = 0; /* count of file-list extras that everyone gets */ +int file_extra_cnt = 0; /* count of file-list extras that everyone gets */ +int incremental = 0; extern int verbose; extern int am_server; extern int am_sender; extern int inplace; +extern int recurse; extern int fuzzy_basis; extern int read_batch; extern int max_delete; +extern int delay_updates; extern int checksum_seed; extern int basis_dir_cnt; extern int prune_empty_dirs; extern int protocol_version; +extern int preserve_uid; +extern int preserve_gid; +extern int preserve_hard_links; +extern int need_messages_from_generator; +extern int delete_mode, delete_before, delete_during, delete_after; extern char *dest_option; void setup_protocol(int f_out,int f_in) { if (am_sender) - flist_extra_cnt += PTR_EXTRA_LEN; + file_extra_cnt += PTR_EXTRA_LEN; else - flist_extra_cnt++; + file_extra_cnt++; if (preserve_uid) - preserve_uid = ++flist_extra_cnt; + preserve_uid = ++file_extra_cnt; if (preserve_gid) - preserve_gid = ++flist_extra_cnt; + preserve_gid = ++file_extra_cnt; if (remote_protocol == 0) { if (!read_batch) @@ -97,6 +105,13 @@ void setup_protocol(int f_out,int f_in) } } + if (delete_mode && !(delete_before+delete_during+delete_after)) { + if (protocol_version < 30) + delete_before = 1; + else + delete_during = 1; + } + if (protocol_version < 29) { if (fuzzy_basis) { rprintf(FERROR, @@ -129,6 +144,11 @@ void setup_protocol(int f_out,int f_in) protocol_version); exit_cleanup(RERR_PROTOCOL); } + } else if (protocol_version >= 30) { + if (recurse && !preserve_hard_links && !delete_before + && !delete_after && !delay_updates && !prune_empty_dirs) + incremental = 1; + need_messages_from_generator = 1; } if (am_server) {