diff options
author | Shawn O. Pearce <spearce@spearce.org> | 2007-01-31 02:24:44 -0500 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2007-01-31 13:09:58 -0800 |
commit | 76f8a302c73d7fe26b2034ab4d1dde64de39c8df (patch) | |
tree | b114257e7a90a53649d4c5a3a9df06987e1f17dd | |
parent | d117452a801af081ebaf2c516e2d715eacf37601 (diff) | |
download | git-76f8a302c73d7fe26b2034ab4d1dde64de39c8df.tar.gz git-76f8a302c73d7fe26b2034ab4d1dde64de39c8df.tar.xz |
Don't coredump on bad refs in update-server-info.
Apparently if we are unable to parse an object update-server-info
coredumps, as it doesn't bother to check the return value of its
call to parse_object.
Instead of coredumping, skip the ref.
Signed-off-by: Shawn O. Pearce <spearce@spearce.org>
Signed-off-by: Junio C Hamano <junkio@cox.net>
-rw-r--r-- | server-info.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/server-info.c b/server-info.c index 6cd38be32..f9be5a7f6 100644 --- a/server-info.c +++ b/server-info.c @@ -10,6 +10,8 @@ static FILE *info_ref_fp; static int add_info_ref(const char *path, const unsigned char *sha1, int flag, void *cb_data) { struct object *o = parse_object(sha1); + if (!o) + return -1; fprintf(info_ref_fp, "%s %s\n", sha1_to_hex(sha1), path); if (o->type == OBJ_TAG) { |