X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/487094a0d7759d37f0426f8433665972db7a6223..0938e8eee59ac038afc47771c7dd50399fc3b311:/options.c diff --git a/options.c b/options.c index 63919096..c704074f 100644 --- a/options.c +++ b/options.c @@ -145,7 +145,6 @@ char *log_format = NULL; char *password_file = NULL; char *rsync_path = RSYNC_PATH; char *backup_dir = NULL; -char *chmod_mode = NULL; char backup_dir_buf[MAXPATHLEN]; int rsync_port = 0; int compare_dest = 0; @@ -174,6 +173,7 @@ static int itemize_changes = 0; static int refused_delete, refused_archive_part, refused_compress; static int refused_partial, refused_progress, refused_delete_before; static int refused_inplace; +static char *chmod_mode = NULL; static char *max_size_arg, *min_size_arg; static char partialdir_for_delayupdate[] = ".~tmp~"; @@ -425,7 +425,7 @@ static struct poptOption long_options[] = { {"chmod", 0, POPT_ARG_STRING, &chmod_mode, 0, 0, 0 }, {"ignore-times", 'I', POPT_ARG_NONE, &ignore_times, 0, 0, 0 }, {"size-only", 0, POPT_ARG_NONE, &size_only, 0, 0, 0 }, - {"one-file-system", 'x', POPT_ARG_NONE, &one_file_system, 0, 0, 0 }, + {"one-file-system", 'x', POPT_ARG_NONE, 0, 'x', 0, 0 }, {"update", 'u', POPT_ARG_NONE, &update_only, 0, 0, 0 }, {"existing", 0, POPT_ARG_NONE, &ignore_non_existing, 0, 0, 0 }, {"ignore-non-existing",0,POPT_ARG_NONE, &ignore_non_existing, 0, 0, 0 }, @@ -891,6 +891,10 @@ int parse_arguments(int *argc, const char ***argv, int frommain) quiet++; break; + case 'x': + one_file_system++; + break; + case OPT_SENDER: if (!am_server) { usage(FERROR); @@ -1459,8 +1463,11 @@ void server_options(char **args,int *argc) argstr[x++] = 'I'; if (relative_paths) argstr[x++] = 'R'; - if (one_file_system) + if (one_file_system) { argstr[x++] = 'x'; + if (one_file_system > 1) + argstr[x++] = 'x'; + } if (sparse_files) argstr[x++] = 'S'; if (do_compression) @@ -1629,11 +1636,6 @@ void server_options(char **args,int *argc) } } - if (chmod_mode && !am_sender) { - args[ac++] = "--chmod"; - args[ac++] = chmod_mode; - } - if (files_from && (!am_sender || filesfrom_host)) { if (filesfrom_host) { args[ac++] = "--files-from";