Promoted to rsync.
[rsync.git/patches.git] / date-only.diff
index 9af3fb1777b85c85f198daa080f5af49ce238c44..042a29fc9f719c517ad687e3a140a0a4a02d2c70 100644 (file)
@@ -14,11 +14,11 @@ To use this patch, run these commands for a successful build:
     ./configure                                 (optional if already run)
     make
 
-based-on: 2a87d78f693f10fe5ad13af0bb9311bd3714077d
+based-on: db5bfe67a5d022f9ad25340db6bc2cca2cbbdb65
 diff --git a/generator.c b/generator.c
 --- a/generator.c
 +++ b/generator.c
-@@ -64,6 +64,7 @@ extern int append_mode;
+@@ -67,6 +67,7 @@ extern int append_mode;
  extern int make_backups;
  extern int csum_length;
  extern int ignore_times;
@@ -26,20 +26,20 @@ diff --git a/generator.c b/generator.c
  extern int size_only;
  extern OFF_T max_size;
  extern OFF_T min_size;
-@@ -577,6 +578,9 @@ void itemize(const char *fnamecmp, struct file_struct *file, int ndx, int statre
- /* 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 time_diff(st, file) == 0;
-+
-       if (st->st_size != F_LENGTH(file))
-               return 0;
+@@ -621,6 +622,9 @@ int quick_check_ok(enum filetype ftype, const char *fn, struct file_struct *file
+               if (st->st_size != F_LENGTH(file))
+                       return 0;
  
++              if (date_only)
++                      return !mtime_differs(st, file);
++
+               /* If always_checksum is set then we use the checksum instead
+                * of the file mtime to determine whether to sync. */
+               if (always_checksum > 0) {
 diff --git a/options.c b/options.c
 --- a/options.c
 +++ b/options.c
-@@ -110,6 +110,7 @@ int safe_symlinks = 0;
+@@ -119,6 +119,7 @@ int safe_symlinks = 0;
  int copy_unsafe_links = 0;
  int munge_symlinks = 0;
  int size_only = 0;
@@ -47,15 +47,7 @@ diff --git a/options.c b/options.c
  int daemon_bwlimit = 0;
  int bwlimit = 0;
  int fuzzy_basis = 0;
-@@ -761,6 +762,7 @@ void usage(enum logcode F)
-   rprintf(F," -I, --ignore-times          don't skip files that match in size and mod-time\n");
-   rprintf(F," -M, --remote-option=OPTION  send OPTION to the remote side only\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     set the accuracy for mod-time comparisons\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");
-@@ -919,6 +921,7 @@ static struct poptOption long_options[] = {
+@@ -688,6 +689,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 },
@@ -63,7 +55,7 @@ diff --git a/options.c b/options.c
    {"one-file-system", 'x', POPT_ARG_NONE,   0, 'x', 0, 0 },
    {"no-one-file-system",0, POPT_ARG_VAL,    &one_file_system, 0, 0, 0 },
    {"no-x",             0,  POPT_ARG_VAL,    &one_file_system, 0, 0, 0 },
-@@ -2711,6 +2714,9 @@ void server_options(char **args, int *argc_p)
+@@ -2830,6 +2832,9 @@ void server_options(char **args, int *argc_p)
        else if (missing_args == 1 && !am_sender)
                args[ac++] = "--ignore-missing-args";
  
@@ -73,27 +65,29 @@ diff --git a/options.c b/options.c
        if (modify_window_set && am_sender) {
                char *fmt = modify_window < 0 ? "-@%d" : "--modify-window=%d";
                if (asprintf(&arg, fmt, modify_window) < 0)
-diff --git a/rsync.yo b/rsync.yo
---- a/rsync.yo
-+++ b/rsync.yo
-@@ -421,6 +421,7 @@ to the detailed description below for a complete description.  verb(
     --contimeout=SECONDS    set daemon connection 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     set the accuracy for mod-time comparisons
 -T, --temp-dir=DIR          create temporary files in directory DIR
 -y, --fuzzy                 find similar file for basis if no dest file
-@@ -615,6 +616,12 @@ time to just looking for files that have changed in size.  This is useful
- when starting to use rsync after using another mirroring system which may
not preserve timestamps exactly.
+diff --git a/rsync.1.md b/rsync.1.md
+--- a/rsync.1.md
++++ b/rsync.1.md
+@@ -468,6 +468,7 @@ has its own detailed description later in this manpage.
--contimeout=SECONDS     set daemon connection timeout in seconds
--ignore-times, -I       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, -@  set the accuracy for mod-time comparisons
--temp-dir=DIR, -T       create temporary files in directory DIR
--fuzzy, -y              find similar file for basis if no dest file
+@@ -737,6 +738,14 @@ expand it.
+     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.
++0.  `--date-only`
 +
- 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.  The default is 0, which matches just integer seconds.  If you specify a
++    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.
++
+ 0.  `--modify-window=NUM`, `-@`
+     When comparing two timestamps, rsync treats the timestamps as being equal