Skip to content

Commit

Permalink
Merge branch 'db/delta-applier' into db/text-delta
Browse files Browse the repository at this point in the history
* 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
  • Loading branch information
Jonathan Nieder committed Jun 15, 2011
2 parents 7a75e66 + fbdd4f6 commit 157415a
Show file tree
Hide file tree
Showing 4 changed files with 37 additions and 24 deletions.
54 changes: 32 additions & 22 deletions test-svn-fe.c
Original file line number Diff line number Diff line change
Expand Up @@ -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;
Expand All @@ -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);
}
2 changes: 1 addition & 1 deletion vcs-svn/fast_export.c
Original file line number Diff line number Diff line change
Expand Up @@ -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)))
Expand Down
2 changes: 2 additions & 0 deletions vcs-svn/sliding_window.c
Original file line number Diff line number Diff line change
Expand Up @@ -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) {
Expand Down
3 changes: 2 additions & 1 deletion vcs-svn/sliding_window.h
Original file line number Diff line number Diff line change
Expand Up @@ -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);

Expand Down

0 comments on commit 157415a

Please sign in to comment.