- always flush the IO write buffer when reading
[rsync/rsync.git] / match.c
diff --git a/match.c b/match.c
index 0d8bc31..333f0cf 100644 (file)
--- a/match.c
+++ b/match.c
@@ -103,9 +103,6 @@ static void matched(int f,struct sum_struct *s,struct map_struct *buf,
        send_token(f,i,buf,last_match,n,i<0?0:s->sums[i].len);
        data_transfer += n;
 
-       if (n > 0)
-               write_flush(f);
-
        if (i >= 0)
                n += s->sums[i].len;
   
@@ -131,7 +128,6 @@ static void hash_search(int f,struct sum_struct *s,
        char sum2[SUM_LENGTH];
        uint32 s1, s2, sum; 
        schar *map;
-       extern int do_compression;
 
        if (verbose > 2)
                rprintf(FINFO,"hash search b=%d len=%d\n",s->n,(int)len);
@@ -214,21 +210,15 @@ static void hash_search(int f,struct sum_struct *s,
                        --k;
                }
 
-               if (!do_compression) {
-                       /* By matching early we avoid re-reading the
-                          data 3 times in the case where a token
-                          match comes a long way after last
-                          match. The 3 reads are caused by the
-                          running match, the checksum update and the
-                          literal send.
-
-                          we don't enable this for the compressed
-                          case yet as the deflated token code can't
-                          handle it. Paul is working on it */
-                       if (offset-last_match >= CHUNK_SIZE+s->n && 
-                           (end-offset > CHUNK_SIZE)) {
-                               matched(f,s,buf,offset - s->n, -2);
-                       }
+               /* By matching early we avoid re-reading the
+                  data 3 times in the case where a token
+                  match comes a long way after last
+                  match. The 3 reads are caused by the
+                  running match, the checksum update and the
+                  literal send. */
+               if (offset-last_match >= CHUNK_SIZE+s->n && 
+                   (end-offset > CHUNK_SIZE)) {
+                       matched(f,s,buf,offset - s->n, -2);
                }
        } while (++offset < end);