diff options
author | Nicolas Pitre <nico@fluxnic.net> | 2010-10-22 06:02:27 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2010-10-22 07:23:34 +0200 |
commit | c50c4316e1eed362bee387e4cbfbe1138957f75b (patch) | |
tree | e35756783e663a7e51bdf6599372df4284e08056 /diff.c | |
parent | Git 1.7.0 (diff) | |
download | git-c50c4316e1eed362bee387e4cbfbe1138957f75b.tar.xz git-c50c4316e1eed362bee387e4cbfbe1138957f75b.zip |
diff: don't presume empty file when corresponding object is missing
The low-level diff code will happily produce totally bogus diff output
with a broken repository via format-patch and friends by treating missing
objects as empty files. Let's prevent that from happening any longer.
Reported-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Signed-off-by: Nicolas Pitre <nico@fluxnic.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'diff.c')
-rw-r--r-- | diff.c | 8 |
1 files changed, 6 insertions, 2 deletions
@@ -2124,10 +2124,14 @@ int diff_populate_filespec(struct diff_filespec *s, int size_only) } else { enum object_type type; - if (size_only) + if (size_only) { type = sha1_object_info(s->sha1, &s->size); - else { + if (type < 0) + die("unable to read %s", sha1_to_hex(s->sha1)); + } else { s->data = read_sha1_file(s->sha1, &type, &s->size); + if (!s->data) + die("unable to read %s", sha1_to_hex(s->sha1)); s->should_free = 1; } } |