X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/bc363ea983a5b5db44c71bf0cb8310fddb740dc8..7a55d06e0d6771625ed2041f08470f2cdbd25965:/clientserver.c diff --git a/clientserver.c b/clientserver.c index 41b8dfa8..82c25def 100644 --- a/clientserver.c +++ b/clientserver.c @@ -1,6 +1,7 @@ /* -*- c-file-style: "linux"; -*- - Copyright (C) 1998-2000 by Andrew Tridgell + Copyright (C) 1998-2001 by Andrew Tridgell + Copyright (C) 2001 by Martin Pool This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -28,7 +29,6 @@ extern int rsync_port; char *auth_user; int sanitize_paths = 0; - /* * Run a client connected to an rsyncd. The alternative to this * function for remote-shell connections is do_cmd. @@ -44,7 +44,8 @@ int start_socket_client(char *host, char *path, int argc, char *argv[]) extern int am_sender; extern struct in_addr socket_address; extern char *shell_cmd; - + extern int kludge_around_eof; + if (argc == 0 && !am_sender) { extern int list_only; list_only = 1; @@ -63,7 +64,7 @@ int start_socket_client(char *host, char *path, int argc, char *argv[]) } if (*path == '/') { - rprintf(FERROR,"ERROR: The remote path must start with a module name\n"); + rprintf(FERROR,"ERROR: The remote path must start with a module name not a /\n"); return -1; } @@ -107,6 +108,10 @@ int start_socket_client(char *host, char *path, int argc, char *argv[]) if (p) *p = '/'; while (1) { + /* Old servers may just drop the connection here, + rather than sending a proper EXIT command. Yuck. */ + kludge_around_eof= True; + if (!read_line(fd, line, sizeof(line)-1)) { return -1; } @@ -117,8 +122,12 @@ int start_socket_client(char *host, char *path, int argc, char *argv[]) } if (strcmp(line,"@RSYNCD: OK") == 0) break; + + if (strcmp(line,"@RSYNCD: EXIT") == 0) exit(0); + rprintf(FINFO,"%s\n", line); } + kludge_around_eof = False; for (i=0;i 1) verbose = 1; #endif - argc -= optind; - argp = argv + optind; - optind = 0; - if (remote_version < 23) { if (remote_version == 22 || (remote_version > 17 && am_sender)) io_start_multiplex_out(fd); } - + + /* For later protocol versions, we don't start multiplexing + * until we've configured nonblocking in start_server. That + * means we're in a sticky situation now: there's no way to + * convey errors to the client. */ + + /* FIXME: Hold off on reporting option processing errors until + * we've set up nonblocking and multiplexed IO and can get the + * message back to them. */ if (!ret) { - option_error(); + option_error(); + exit_cleanup(RERR_UNSUPPORTED); } if (lp_timeout(i)) { @@ -368,6 +390,8 @@ static void send_listing(int fd) for (i=0;i