Browse Source

config: make a copy of $GIT_CONFIG string

cmd_config() points our source filename pointer at the return value of
getenv(), but that value may be invalidated by further calls to
environment functions. Let's copy it to make sure it remains valid.

We don't need to bother freeing it, as it remains part of the
whole-process global state until we exit.

Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Jeff King 6 years ago committed by Junio C Hamano
parent
commit
423ff9bef0
  1. 2
      builtin/config.c

2
builtin/config.c

@ -595,7 +595,7 @@ int cmd_config(int argc, const char **argv, const char *prefix) @@ -595,7 +595,7 @@ int cmd_config(int argc, const char **argv, const char *prefix)
int nongit = !startup_info->have_repository;
char *value;

given_config_source.file = getenv(CONFIG_ENVIRONMENT);
given_config_source.file = xstrdup_or_null(getenv(CONFIG_ENVIRONMENT));

argc = parse_options(argc, argv, prefix, builtin_config_options,
builtin_config_usage,

Loading…
Cancel
Save