]> git.ipfire.org Git - thirdparty/git.git/commitdiff
config: normalize the path of the system gitconfig
authorJohannes Schindelin <johannes.schindelin@gmx.de>
Tue, 22 Jun 2021 10:46:48 +0000 (10:46 +0000)
committerJunio C Hamano <gitster@pobox.com>
Tue, 29 Jun 2021 03:11:51 +0000 (20:11 -0700)
Git for Windows is compiled with a runtime prefix, and that runtime
prefix is typically `C:/Program Files/Git/mingw64`. As we want the
system gitconfig to live in the sibling directory `etc`, we define the
relative path as `../etc/gitconfig`.

However, as reported by Philip Oakley, the output of `git config
--show-origin --system -l` looks rather ugly, as it shows the path as
`file:C:/Program Files/Git/mingw64/../etc/gitconfig`, i.e. with the
`mingw64/../` part.

By normalizing the path, we get a prettier path.

Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
config.c

index f9c400ad3062d9953142d6a2f9c4b357962c48c7..3cd10aeb9028405dace7f1c0ca43041e8ab88d64 100644 (file)
--- a/config.c
+++ b/config.c
@@ -1833,9 +1833,10 @@ static int git_config_from_blob_ref(config_fn_t fn,
 char *git_system_config(void)
 {
        char *system_config = xstrdup_or_null(getenv("GIT_CONFIG_SYSTEM"));
-       if (system_config)
-               return system_config;
-       return system_path(ETC_GITCONFIG);
+       if (!system_config)
+               system_config = system_path(ETC_GITCONFIG);
+       normalize_path_copy(system_config, system_config);
+       return system_config;
 }
 
 void git_global_config(char **user_out, char **xdg_out)