diff options
author | Jeff King <peff@peff.net> | 2012-04-25 14:00:36 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2012-04-30 02:46:32 +0200 |
commit | 4c0a89fcde219df8db8fdb9635ef2ef40d002a6e (patch) | |
tree | bc2f0008d9770ff20e56b0baf3e096cdf2230e01 /config.c | |
parent | Git 1.7.10 (diff) | |
download | git-4c0a89fcde219df8db8fdb9635ef2ef40d002a6e.tar.xz git-4c0a89fcde219df8db8fdb9635ef2ef40d002a6e.zip |
config: expand tildes in include.path variable
You can already use relative paths in include.path, which
means that including "foo" from your global "~/.gitconfig"
will look in your home directory. However, you might want to
do something clever like putting "~/.gitconfig-foo" in a
specific repository's config file.
Signed-off-by: Jeff King <peff@peff.net>
Acked-by: Matthieu Moy <Matthieu.Moy@imag.fr>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'config.c')
-rw-r--r-- | config.c | 6 |
1 files changed, 6 insertions, 0 deletions
@@ -37,6 +37,11 @@ static int handle_path_include(const char *path, struct config_include_data *inc { int ret = 0; struct strbuf buf = STRBUF_INIT; + char *expanded = expand_user_path(path); + + if (!expanded) + return error("Could not expand include path '%s'", path); + path = expanded; /* * Use an absolute path as-is, but interpret relative paths @@ -63,6 +68,7 @@ static int handle_path_include(const char *path, struct config_include_data *inc inc->depth--; } strbuf_release(&buf); + free(expanded); return ret; } |