From: Nguyễn Thái Ngọc Duy Date: Wed, 18 Apr 2018 14:53:37 +0000 (+0200) Subject: submodule--helper: don't print null in 'submodule status' X-Git-Tag: v2.18.0-rc0~82^2 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=0b5e2ea7cf3;p=thirdparty%2Fgit.git submodule--helper: don't print null in 'submodule status' The function compute_rev_name() can return NULL sometimes (e.g. right after 'submodule init'). The current code makes 'submodule status' print this: 19d97bf5af05312267c2e874ee6bcf584d9e9681 sha1collisiondetection ((null)) This ugly 'null' adds no value to the user using this command. More importantly printf() on some platform can't handle NULL as a string and will crash instead of printing '(null)'. Check for this and skip printing this part (the alternative is printing '(n/a)' or something but I think that is just noise). Signed-off-by: Nguyễn Thái Ngọc Duy Reviewed-by: Stefan Beller Signed-off-by: Junio C Hamano --- diff --git a/builtin/submodule--helper.c b/builtin/submodule--helper.c index a4193c01d9..d85b29b49e 100644 --- a/builtin/submodule--helper.c +++ b/builtin/submodule--helper.c @@ -562,8 +562,12 @@ static void print_status(unsigned int flags, char state, const char *path, printf("%c%s %s", state, oid_to_hex(oid), displaypath); - if (state == ' ' || state == '+') - printf(" (%s)", compute_rev_name(path, oid_to_hex(oid))); + if (state == ' ' || state == '+') { + const char *name = compute_rev_name(path, oid_to_hex(oid)); + + if (name) + printf(" (%s)", name); + } printf("\n"); }