X-Git-Url: https://mattmccutchen.net/rsync/rsync-patches.git/blobdiff_plain/3ec54554b3ba5bfaba75f25c9f60b040ba30135c..7ac2aef2fd35ed0cffe2b558b69643f12662a03e:/date-only.diff diff --git a/date-only.diff b/date-only.diff index 496a248..42315fd 100644 --- a/date-only.diff +++ b/date-only.diff @@ -12,58 +12,84 @@ Again, thanks! Best Regards, Jeremy Bornstein -diff rsync-2.5.4/README rsync-2.5.4-patched/README -70a71 -> --date-only only use modification date when determining if a file should be transferred -Common subdirectories: rsync-2.5.4/doc and rsync-2.5.4-patched/doc -diff rsync-2.5.4/generator.c rsync-2.5.4-patched/generator.c -39a40 -> extern int date_only; -50a52,56 -> if (date_only) { -> return (cmp_modtime(st->st_mtime,file->modtime) == 0); -> } -> -> -Common subdirectories: rsync-2.5.4/lib and rsync-2.5.4-patched/lib -diff rsync-2.5.4/options.c rsync-2.5.4-patched/options.c -64a65 -> int date_only=0; -223a225 -> rprintf(F," --date-only only use modification date when determining if a file should be transferred\n"); -265c267 -< OPT_LOG_FORMAT, OPT_PASSWORD_FILE, OPT_SIZE_ONLY, OPT_ADDRESS, ---- -> OPT_LOG_FORMAT, OPT_PASSWORD_FILE, OPT_SIZE_ONLY, OPT_DATE_ONLY, OPT_ADDRESS, -278a281 -> {"date-only", 0, POPT_ARG_NONE, &date_only}, -704a708,710 -> -> if (date_only) -> args[ac++] = "--date-only"; -Common subdirectories: rsync-2.5.4/packaging and rsync-2.5.4-patched/packaging -Common subdirectories: rsync-2.5.4/popt and rsync-2.5.4-patched/popt -diff rsync-2.5.4/rsync.1 rsync-2.5.4-patched/rsync.1 -289a290 -> --date-only only use modification date when determining if a file should be transferred -363a365,371 -> .IP -> .IP "\fB--date-only\fP" -> Normally rsync will skip any files that are -> already the same length and have the same time-stamp\&. With the -> --date-only option files will be skipped if they have the same timestamp, -> regardless of size\&. This may be useful when the remote files have passed -> through a size-changing filter, e.g. for encryption\&. -diff rsync-2.5.4/rsync.yo rsync-2.5.4-patched/rsync.yo -260a261 -> --date-only only use modification date when determining if a file should be transferred -326a328,333 -> -> dit(bf(--date-only)) Normally rsync will skip any files that are -> already the same length and have the same time-stamp. With the -> --date-only option files will be skipped if they have the same -> timestamp, regardless of size. This may be useful when the remote -> files have passed through a size-changing filter, e.g. for encryption. -Common subdirectories: rsync-2.5.4/testhelp and rsync-2.5.4-patched/testhelp -Common subdirectories: rsync-2.5.4/testsuite and rsync-2.5.4-patched/testsuite -Common subdirectories: rsync-2.5.4/zlib and rsync-2.5.4-patched/zlib + +[Patched update to have context and apply to latest CVS source.] + +--- old/generator.c ++++ new/generator.c +@@ -61,6 +61,7 @@ extern int append_mode; + extern int make_backups; + extern int csum_length; + extern int ignore_times; ++extern int date_only; + extern int size_only; + extern OFF_T max_size; + extern OFF_T min_size; +@@ -379,6 +380,8 @@ void itemize(struct file_struct *file, i + /* Perform our quick-check heuristic for determining if a file is unchanged. */ + int unchanged_file(char *fn, struct file_struct *file, STRUCT_STAT *st) + { ++ if (date_only) ++ return cmp_time(st->st_mtime, file->modtime) == 0; + if (st->st_size != file->length) + return 0; + +--- old/options.c ++++ new/options.c +@@ -99,6 +99,7 @@ int keep_partial = 0; + int safe_symlinks = 0; + int copy_unsafe_links = 0; + int size_only = 0; ++int date_only = 0; + int daemon_bwlimit = 0; + int bwlimit = 0; + int fuzzy_basis = 0; +@@ -332,6 +333,7 @@ void usage(enum logcode F) + rprintf(F," --timeout=TIME set I/O timeout in seconds\n"); + rprintf(F," -I, --ignore-times don't skip files that match in size and mod-time\n"); + rprintf(F," --size-only skip files that match in size\n"); ++ rprintf(F," --date-only skip files that match in mod-time\n"); + rprintf(F," --modify-window=NUM compare mod-times with reduced accuracy\n"); + rprintf(F," -T, --temp-dir=DIR create temporary files in directory DIR\n"); + rprintf(F," -y, --fuzzy find similar file for basis if no dest file\n"); +@@ -443,6 +445,7 @@ static struct poptOption long_options[] + {"chmod", 0, POPT_ARG_STRING, 0, OPT_CHMOD, 0, 0 }, + {"ignore-times", 'I', POPT_ARG_NONE, &ignore_times, 0, 0, 0 }, + {"size-only", 0, POPT_ARG_NONE, &size_only, 0, 0, 0 }, ++ {"date-only", 0, POPT_ARG_NONE, &date_only, 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 }, +@@ -1647,6 +1650,9 @@ void server_options(char **args,int *arg + args[ac++] = "--size-only"; + } + ++ if (date_only) ++ args[ac++] = "--date-only"; ++ + if (modify_window_set) { + if (asprintf(&arg, "--modify-window=%d", modify_window) < 0) + goto oom; +--- old/rsync.yo ++++ new/rsync.yo +@@ -355,6 +355,7 @@ to the detailed description below for a + --timeout=TIME set I/O timeout in seconds + -I, --ignore-times don't skip files that match size and time + --size-only skip files that match in size ++ --date-only skip files that match in mod-time + --modify-window=NUM compare mod-times with reduced accuracy + -T, --temp-dir=DIR create temporary files in directory DIR + -y, --fuzzy find similar file for basis if no dest file +@@ -460,6 +461,12 @@ regardless of timestamp. This is useful + after using another mirroring system which may not preserve timestamps + exactly. + ++dit(bf(--date-only)) Normally rsync will skip any files that are ++already the same size and have the same modification time-stamp. With the ++--date-only option, files will be skipped if they have the same ++timestamp, regardless of size. This may be useful when the remote ++files have passed through a size-changing filter, e.g. for encryption. ++ + dit(bf(--modify-window)) When comparing two timestamps, rsync treats the + timestamps as being equal if they differ by no more than the modify-window + value. This is normally 0 (for an exact match), but you may find it useful