From: Junio C Hamano Date: Mon, 3 Oct 2005 00:29:21 +0000 (-0700) Subject: Fix minor DOS in rev-list. X-Git-Tag: v0.99.8a~5 X-Git-Url: https://git.verplant.org/?a=commitdiff_plain;h=c807f771947de65dceb22960d1a093d702f42105;p=git.git Fix minor DOS in rev-list. A carefully crafted pathname can be used to disrupt downstream git-pack-objects that uses 'git-rev-list --objects' output. Prevent this. Signed-off-by: Junio C Hamano --- diff --git a/rev-list.c b/rev-list.c index 523fda07..5ec9ccb6 100644 --- a/rev-list.c +++ b/rev-list.c @@ -194,7 +194,17 @@ static void show_commit_list(struct commit_list *list) die("unknown pending object %s (%s)", sha1_to_hex(obj->sha1), name); } while (objects) { - printf("%s %s\n", sha1_to_hex(objects->item->sha1), objects->name); + /* An object with name "foo\n0000000000000000000000000000000000000000" + * can be used confuse downstream git-pack-objects very badly. + */ + const char *ep = strchr(objects->name, '\n'); + if (ep) { + printf("%s %.*s\n", sha1_to_hex(objects->item->sha1), + (int) (ep - objects->name), + objects->name); + } + else + printf("%s %s\n", sha1_to_hex(objects->item->sha1), objects->name); objects = objects->next; } }