Code

Merge branch 'db/delta-applier' into db/text-delta
authorJonathan Nieder <jrnieder@gmail.com>
Wed, 15 Jun 2011 07:31:35 +0000 (02:31 -0500)
committerJonathan Nieder <jrnieder@gmail.com>
Wed, 15 Jun 2011 07:31:35 +0000 (02:31 -0500)
* db/delta-applier:
  vcs-svn: cap number of bytes read from sliding view
  test-svn-fe: split off "test-svn-fe -d" into a separate function

test-svn-fe.c
vcs-svn/fast_export.c
vcs-svn/sliding_window.c
vcs-svn/sliding_window.h

index 66bd04022dab32e894c5e6ca18702b69ad0a0ed0..332a5f711df8f3e3fea3305eb5ecb10de5581033 100644 (file)
@@ -8,10 +8,37 @@
 #include "vcs-svn/sliding_window.h"
 #include "vcs-svn/line_buffer.h"
 
+static const char test_svnfe_usage[] =
+       "test-svn-fe (<dumpfile> | [-d] <preimage> <delta> <len>)";
+
+static int apply_delta(int argc, char *argv[])
+{
+       struct line_buffer preimage = LINE_BUFFER_INIT;
+       struct line_buffer delta = LINE_BUFFER_INIT;
+       struct sliding_view preimage_view = SLIDING_VIEW_INIT(&preimage, -1);
+
+       if (argc != 5)
+               usage(test_svnfe_usage);
+
+       if (buffer_init(&preimage, argv[2]))
+               die_errno("cannot open preimage");
+       if (buffer_init(&delta, argv[3]))
+               die_errno("cannot open delta");
+       if (svndiff0_apply(&delta, (off_t) strtoull(argv[4], NULL, 0),
+                                       &preimage_view, stdout))
+               return 1;
+       if (buffer_deinit(&preimage))
+               die_errno("cannot close preimage");
+       if (buffer_deinit(&delta))
+               die_errno("cannot close delta");
+       buffer_reset(&preimage);
+       strbuf_release(&preimage_view.buf);
+       buffer_reset(&delta);
+       return 0;
+}
+
 int main(int argc, char *argv[])
 {
-       static const char test_svnfe_usage[] =
-               "test-svn-fe (<dumpfile> | [-d] <preimage> <delta> <len>)";
        if (argc == 2) {
                if (svndump_init(argv[1]))
                        return 1;
@@ -20,25 +47,8 @@ int main(int argc, char *argv[])
                svndump_reset();
                return 0;
        }
-       if (argc == 5 && !strcmp(argv[1], "-d")) {
-               struct line_buffer preimage = LINE_BUFFER_INIT;
-               struct line_buffer delta = LINE_BUFFER_INIT;
-               struct sliding_view preimage_view = SLIDING_VIEW_INIT(&preimage);
-               if (buffer_init(&preimage, argv[2]))
-                       die_errno("cannot open preimage");
-               if (buffer_init(&delta, argv[3]))
-                       die_errno("cannot open delta");
-               if (svndiff0_apply(&delta, (off_t) strtoull(argv[4], NULL, 0),
-                                       &preimage_view, stdout))
-                       return 1;
-               if (buffer_deinit(&preimage))
-                       die_errno("cannot close preimage");
-               if (buffer_deinit(&delta))
-                       die_errno("cannot close delta");
-               buffer_reset(&preimage);
-               strbuf_release(&preimage_view.buf);
-               buffer_reset(&delta);
-               return 0;
-       }
+
+       if (argc >= 2 && !strcmp(argv[1], "-d"))
+               return apply_delta(argc, argv);
        usage(test_svnfe_usage);
 }
index 005674d8c18d43c61c69ee64a134883d2391fcdf..edc658d4fe9567f3fdf5ebc5d7c7fd7ef174d5c3 100644 (file)
@@ -187,7 +187,7 @@ static long apply_delta(off_t len, struct line_buffer *input,
 {
        long ret;
        off_t preimage_len = 0;
-       struct sliding_view preimage = SLIDING_VIEW_INIT(&report_buffer);
+       struct sliding_view preimage = SLIDING_VIEW_INIT(&report_buffer, -1);
        FILE *out;
 
        if (init_postimage() || !(out = buffer_tmpfile_rewind(&postimage)))
index 1b8d9875ed8831a98d0107db71e0ba1c3083a714..1bac7a4c7f0df0ccee7755d9d441ebb26d96c323 100644 (file)
@@ -54,6 +54,8 @@ int move_window(struct sliding_view *view, off_t off, size_t width)
                return -1;
        if (off < view->off || off + width < view->off + view->width)
                return error("invalid delta: window slides left");
+       if (view->max_off >= 0 && view->max_off < off + width)
+               return error("delta preimage ends early");
 
        file_offset = view->off + view->buf.len;
        if (off < file_offset) {
index ed0bfdd65c0c7285eebdfd5c163f769db7bb66e2..b43a825cbabe92b8b9da7d1ff2856763fe26fc29 100644 (file)
@@ -7,10 +7,11 @@ struct sliding_view {
        struct line_buffer *file;
        off_t off;
        size_t width;
+       off_t max_off;  /* -1 means unlimited */
        struct strbuf buf;
 };
 
-#define SLIDING_VIEW_INIT(input)       { (input), 0, 0, STRBUF_INIT }
+#define SLIDING_VIEW_INIT(input, len)  { (input), 0, 0, (len), STRBUF_INIT }
 
 extern int move_window(struct sliding_view *view, off_t off, size_t width);