Skip to content

Commit 157415a

Browse files
committed
Merge branch 'db/delta-applier' into db/text-delta
* 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
2 parents 7a75e66 + fbdd4f6 commit 157415a

File tree

4 files changed

+37
-24
lines changed

4 files changed

+37
-24
lines changed

test-svn-fe.c

Lines changed: 32 additions & 22 deletions
Original file line numberDiff line numberDiff line change
@@ -8,10 +8,37 @@
88
#include "vcs-svn/sliding_window.h"
99
#include "vcs-svn/line_buffer.h"
1010

11+
static const char test_svnfe_usage[] =
12+
"test-svn-fe (<dumpfile> | [-d] <preimage> <delta> <len>)";
13+
14+
static int apply_delta(int argc, char *argv[])
15+
{
16+
struct line_buffer preimage = LINE_BUFFER_INIT;
17+
struct line_buffer delta = LINE_BUFFER_INIT;
18+
struct sliding_view preimage_view = SLIDING_VIEW_INIT(&preimage, -1);
19+
20+
if (argc != 5)
21+
usage(test_svnfe_usage);
22+
23+
if (buffer_init(&preimage, argv[2]))
24+
die_errno("cannot open preimage");
25+
if (buffer_init(&delta, argv[3]))
26+
die_errno("cannot open delta");
27+
if (svndiff0_apply(&delta, (off_t) strtoull(argv[4], NULL, 0),
28+
&preimage_view, stdout))
29+
return 1;
30+
if (buffer_deinit(&preimage))
31+
die_errno("cannot close preimage");
32+
if (buffer_deinit(&delta))
33+
die_errno("cannot close delta");
34+
buffer_reset(&preimage);
35+
strbuf_release(&preimage_view.buf);
36+
buffer_reset(&delta);
37+
return 0;
38+
}
39+
1140
int main(int argc, char *argv[])
1241
{
13-
static const char test_svnfe_usage[] =
14-
"test-svn-fe (<dumpfile> | [-d] <preimage> <delta> <len>)";
1542
if (argc == 2) {
1643
if (svndump_init(argv[1]))
1744
return 1;
@@ -20,25 +47,8 @@ int main(int argc, char *argv[])
2047
svndump_reset();
2148
return 0;
2249
}
23-
if (argc == 5 && !strcmp(argv[1], "-d")) {
24-
struct line_buffer preimage = LINE_BUFFER_INIT;
25-
struct line_buffer delta = LINE_BUFFER_INIT;
26-
struct sliding_view preimage_view = SLIDING_VIEW_INIT(&preimage);
27-
if (buffer_init(&preimage, argv[2]))
28-
die_errno("cannot open preimage");
29-
if (buffer_init(&delta, argv[3]))
30-
die_errno("cannot open delta");
31-
if (svndiff0_apply(&delta, (off_t) strtoull(argv[4], NULL, 0),
32-
&preimage_view, stdout))
33-
return 1;
34-
if (buffer_deinit(&preimage))
35-
die_errno("cannot close preimage");
36-
if (buffer_deinit(&delta))
37-
die_errno("cannot close delta");
38-
buffer_reset(&preimage);
39-
strbuf_release(&preimage_view.buf);
40-
buffer_reset(&delta);
41-
return 0;
42-
}
50+
51+
if (argc >= 2 && !strcmp(argv[1], "-d"))
52+
return apply_delta(argc, argv);
4353
usage(test_svnfe_usage);
4454
}

vcs-svn/fast_export.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -187,7 +187,7 @@ static long apply_delta(off_t len, struct line_buffer *input,
187187
{
188188
long ret;
189189
off_t preimage_len = 0;
190-
struct sliding_view preimage = SLIDING_VIEW_INIT(&report_buffer);
190+
struct sliding_view preimage = SLIDING_VIEW_INIT(&report_buffer, -1);
191191
FILE *out;
192192

193193
if (init_postimage() || !(out = buffer_tmpfile_rewind(&postimage)))

vcs-svn/sliding_window.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -54,6 +54,8 @@ int move_window(struct sliding_view *view, off_t off, size_t width)
5454
return -1;
5555
if (off < view->off || off + width < view->off + view->width)
5656
return error("invalid delta: window slides left");
57+
if (view->max_off >= 0 && view->max_off < off + width)
58+
return error("delta preimage ends early");
5759

5860
file_offset = view->off + view->buf.len;
5961
if (off < file_offset) {

vcs-svn/sliding_window.h

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -7,10 +7,11 @@ struct sliding_view {
77
struct line_buffer *file;
88
off_t off;
99
size_t width;
10+
off_t max_off; /* -1 means unlimited */
1011
struct strbuf buf;
1112
};
1213

13-
#define SLIDING_VIEW_INIT(input) { (input), 0, 0, STRBUF_INIT }
14+
#define SLIDING_VIEW_INIT(input, len) { (input), 0, 0, (len), STRBUF_INIT }
1415

1516
extern int move_window(struct sliding_view *view, off_t off, size_t width);
1617

0 commit comments

Comments
 (0)