X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/e7c67065c060d500eba8d073da9568db2c658aad..c5b6e57a136d5bdc1eff9ef11e69c7093065920e:/compat.c diff --git a/compat.c b/compat.c index 475a1fe4..52bba804 100644 --- a/compat.c +++ b/compat.c @@ -23,20 +23,40 @@ #include "rsync.h" int remote_protocol = 0; +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) + file_extra_cnt += PTR_EXTRA_LEN; + else + file_extra_cnt++; + if (preserve_uid) + preserve_uid = ++file_extra_cnt; + if (preserve_gid) + preserve_gid = ++file_extra_cnt; + if (remote_protocol == 0) { if (!read_batch) write_int(f_out, protocol_version); @@ -75,6 +95,23 @@ void setup_protocol(int f_out,int f_in) exit_cleanup(RERR_PROTOCOL); } + if (protocol_version < 30) { + if (max_delete == 0 && am_sender) { + rprintf(FERROR, + "--max-delete=0 requires protocol 30 or higher" + " (negotiated %d).\n", + protocol_version); + exit_cleanup(RERR_PROTOCOL); + } + } + + 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, @@ -107,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) {