2 * Compatibility routines for older rsync protocol versions.
4 * Copyright (C) Andrew Tridgell 1996
5 * Copyright (C) Paul Mackerras 1996
6 * Copyright (C) 2004-2007 Wayne Davison
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License version 2 as
10 * published by the Free Software Foundation.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License along
18 * with this program; if not, write to the Free Software Foundation, Inc.,
19 * 51 Franklin Street - Fifth Floor, Boston, MA 02110-1301, USA.
24 int remote_protocol = 0;
25 int file_extra_cnt = 0; /* count of file-list extras that everyone gets */
33 extern int fuzzy_basis;
34 extern int read_batch;
35 extern int max_delete;
36 extern int delay_updates;
37 extern int checksum_seed;
38 extern int basis_dir_cnt;
39 extern int prune_empty_dirs;
40 extern int protocol_version;
41 extern int preserve_uid;
42 extern int preserve_gid;
43 extern int preserve_hard_links;
44 extern int need_messages_from_generator;
45 extern int delete_mode, delete_before, delete_during, delete_after;
46 extern char *dest_option;
48 void setup_protocol(int f_out,int f_in)
51 file_extra_cnt += PTR_EXTRA_LEN;
55 preserve_uid = ++file_extra_cnt;
57 preserve_gid = ++file_extra_cnt;
59 if (remote_protocol == 0) {
61 write_int(f_out, protocol_version);
62 remote_protocol = read_int(f_in);
63 if (protocol_version > remote_protocol)
64 protocol_version = remote_protocol;
66 if (read_batch && remote_protocol > protocol_version) {
67 rprintf(FERROR, "The protocol version in the batch file is too new (%d > %d).\n",
68 remote_protocol, protocol_version);
69 exit_cleanup(RERR_PROTOCOL);
73 rprintf(FINFO, "(%s) Protocol versions: remote=%d, negotiated=%d\n",
74 am_server? "Server" : "Client", remote_protocol, protocol_version);
76 if (remote_protocol < MIN_PROTOCOL_VERSION
77 || remote_protocol > MAX_PROTOCOL_VERSION) {
78 rprintf(FERROR,"protocol version mismatch -- is your shell clean?\n");
79 rprintf(FERROR,"(see the rsync man page for an explanation)\n");
80 exit_cleanup(RERR_PROTOCOL);
82 if (remote_protocol < OLD_PROTOCOL_VERSION) {
83 rprintf(FINFO,"%s is very old version of rsync, upgrade recommended.\n",
84 am_server? "Client" : "Server");
86 if (protocol_version < MIN_PROTOCOL_VERSION) {
87 rprintf(FERROR, "--protocol must be at least %d on the %s.\n",
88 MIN_PROTOCOL_VERSION, am_server? "Server" : "Client");
89 exit_cleanup(RERR_PROTOCOL);
91 if (protocol_version > PROTOCOL_VERSION) {
92 rprintf(FERROR, "--protocol must be no more than %d on the %s.\n",
93 PROTOCOL_VERSION, am_server? "Server" : "Client");
94 exit_cleanup(RERR_PROTOCOL);
97 if (protocol_version < 30) {
98 if (max_delete == 0 && am_sender) {
100 "--max-delete=0 requires protocol 30 or higher"
101 " (negotiated %d).\n",
103 exit_cleanup(RERR_PROTOCOL);
107 if (delete_mode && !(delete_before+delete_during+delete_after)) {
108 if (protocol_version < 30)
114 if (protocol_version < 29) {
117 "--fuzzy requires protocol 29 or higher"
118 " (negotiated %d).\n",
120 exit_cleanup(RERR_PROTOCOL);
123 if (basis_dir_cnt && inplace) {
125 "%s with --inplace requires protocol 29 or higher"
126 " (negotiated %d).\n",
127 dest_option, protocol_version);
128 exit_cleanup(RERR_PROTOCOL);
131 if (basis_dir_cnt > 1) {
133 "Using more than one %s option requires protocol"
134 " 29 or higher (negotiated %d).\n",
135 dest_option, protocol_version);
136 exit_cleanup(RERR_PROTOCOL);
139 if (prune_empty_dirs) {
141 "--prune-empty-dirs requires protocol 29 or higher"
142 " (negotiated %d).\n",
144 exit_cleanup(RERR_PROTOCOL);
146 } else if (protocol_version >= 30) {
147 if (recurse && !preserve_hard_links && !delete_before
148 && !delete_after && !delay_updates && !prune_empty_dirs)
150 need_messages_from_generator = 1;
155 checksum_seed = time(NULL);
156 write_int(f_out, checksum_seed);
158 checksum_seed = read_int(f_in);