Code

Merge branch 'db/length-as-hash' (early part) into db/svn-fe-code-purge
[git.git] / vcs-svn / fast_export.c
index f19db9ae8274e530250189d138616e18fbb071ba..32f0c8cfcc98ad3104ee9eca01ce98909bcbfff8 100644 (file)
@@ -121,15 +121,24 @@ static const char *get_response_line(void)
        die("unexpected end of fast-import feedback");
 }
 
+static void die_short_read(struct line_buffer *input)
+{
+       if (buffer_ferror(input))
+               die_errno("error reading dump file");
+       die("invalid dump: unexpected end of file");
+}
+
 void fast_export_data(uint32_t mode, uint32_t len, struct line_buffer *input)
 {
        if (mode == REPO_MODE_LNK) {
                /* svn symlink blobs start with "link " */
-               buffer_skip_bytes(input, 5);
                len -= 5;
+               if (buffer_skip_bytes(input, 5) != 5)
+                       die_short_read(input);
        }
        printf("data %"PRIu32"\n", len);
-       buffer_copy_bytes(input, len);
+       if (buffer_copy_bytes(input, len) != len)
+               die_short_read(input);
        fputc('\n', stdout);
 }