Skip to content

Commit

Permalink
If --backup was used with --inplace, we don't limit the basis-file
Browse files Browse the repository at this point in the history
matches (as we normally would) because the receiver is using the
backup-file as the basis-file.
  • Loading branch information
Wayne Davison committed Sep 7, 2004
1 parent cd6aa5b commit 3bb400c
Showing 1 changed file with 4 additions and 3 deletions.
7 changes: 4 additions & 3 deletions match.c
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,7 @@ extern int am_server;
extern int do_progress;
extern int checksum_seed;
extern int inplace;
extern int make_backups;

typedef unsigned short tag;

Expand Down Expand Up @@ -204,7 +205,7 @@ static void hash_search(int f,struct sum_struct *s,

/* inplace: ensure chunk's offset is either >= our
* offset or that the data didn't move. */
if (inplace && s->sums[i].offset < offset
if (inplace && !make_backups && s->sums[i].offset < offset
&& !(s->sums[i].flags & SUMFLG_SAME_OFFSET))
continue;

Expand All @@ -226,7 +227,7 @@ static void hash_search(int f,struct sum_struct *s,
/* If inplace is enabled, the best possible match is
* one with an identical offset, so we prefer that over
* the following want_i optimization. */
if (inplace) {
if (inplace && !make_backups) {
do {
size_t i2 = targets[j].i;
if (s->sums[i2].offset != offset)
Expand All @@ -249,7 +250,7 @@ static void hash_search(int f,struct sum_struct *s,
/* we've found a match, but now check to see
* if want_i can hint at a better match. */
if (i != want_i && want_i < s->count
&& (!inplace || s->sums[want_i].offset >= offset
&& (!inplace || make_backups || s->sums[want_i].offset >= offset
|| s->sums[want_i].flags & SUMFLG_SAME_OFFSET)
&& sum == s->sums[want_i].sum1
&& memcmp(sum2, s->sums[want_i].sum2, s->s2length) == 0) {
Expand Down

0 comments on commit 3bb400c

Please sign in to comment.