summaryrefslogtreecommitdiffstats
path: root/rev-tree.c
diff options
context:
space:
mode:
authorPetr Baudis <pasky@ucw.cz>2005-04-12 23:37:42 +0200
committerLinus Torvalds <torvalds@ppc970.osdl.org>2005-04-12 23:37:42 +0200
commit3d8c7a57903f91decd5e6c531974a1af1aaa3c97 (patch)
tree9796e3ff820daee2ce8b2439f237dff900769db5 /rev-tree.c
parentMake "checkout-cache" silently skip up-to-date files. (diff)
downloadgit-3d8c7a57903f91decd5e6c531974a1af1aaa3c97.tar.xz
git-3d8c7a57903f91decd5e6c531974a1af1aaa3c97.zip
[PATCH] Fix a crash when doing rev-tree
In parse_commit(), free(buffer) is fed a bogus pointer. Signed-off-by: Petr Baudis <pasky@ucw.cz> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'rev-tree.c')
-rw-r--r--rev-tree.c12
1 files changed, 6 insertions, 6 deletions
diff --git a/rev-tree.c b/rev-tree.c
index 82bf5aaf9e..f2414b20fe 100644
--- a/rev-tree.c
+++ b/rev-tree.c
@@ -152,22 +152,22 @@ static int parse_commit(unsigned char *sha1)
struct revision *rev = lookup_rev(sha1);
if (!(rev->flags & SEEN)) {
- void *buffer;
+ void *buffer, *bufptr;
unsigned long size;
char type[20];
unsigned char parent[20];
rev->flags |= SEEN;
- buffer = read_sha1_file(sha1, type, &size);
+ buffer = bufptr = read_sha1_file(sha1, type, &size);
if (!buffer || strcmp(type, "commit"))
return -1;
- buffer += 46; /* "tree " + "hex sha1" + "\n" */
- while (!memcmp(buffer, "parent ", 7) && !get_sha1_hex(buffer+7, parent)) {
+ bufptr += 46; /* "tree " + "hex sha1" + "\n" */
+ while (!memcmp(bufptr, "parent ", 7) && !get_sha1_hex(bufptr+7, parent)) {
add_relationship(rev, parent);
parse_commit(parent);
- buffer += 48; /* "parent " + "hex sha1" + "\n" */
+ bufptr += 48; /* "parent " + "hex sha1" + "\n" */
}
- rev->date = parse_commit_date(buffer);
+ rev->date = parse_commit_date(bufptr);
free(buffer);
}
return 0;