summaryrefslogtreecommitdiffstats
path: root/setup.c
diff options
context:
space:
mode:
authorSZEDER Gábor <szeder@ira.uka.de>2009-01-16 16:37:33 +0100
committerJunio C Hamano <gitster@pobox.com>2009-01-18 06:46:50 +0100
commit72183cb297f614dc2df1c0ed08afac1be27ec35a (patch)
tree2c27182ec9b1be03b7b786cf92456b8436f7edfc /setup.c
parentDocumentation: let asciidoc align related options (diff)
downloadgit-72183cb297f614dc2df1c0ed08afac1be27ec35a.tar.xz
git-72183cb297f614dc2df1c0ed08afac1be27ec35a.zip
Fix gitdir detection when in subdir of gitdir
If the current working directory is a subdirectory of the gitdir (e.g. <repo>/.git/refs/), then setup_git_directory_gently() will climb its parent directories until it finds itself in a gitdir. However, no matter how many parent directories it climbs, it sets 'GIT_DIR_ENVIRONMENT' to ".", which is obviously wrong. This behaviour affected at least 'git rev-parse --git-dir' and hence caused some errors in bash completion (e.g. customized command prompt when on a detached head and completion of refs). To fix this, we set the absolute path of the found gitdir instead. Signed-off-by: SZEDER Gábor <szeder@ira.uka.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'setup.c')
-rw-r--r--setup.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/setup.c b/setup.c
index 78a8041ff0..dd7c039f0d 100644
--- a/setup.c
+++ b/setup.c
@@ -456,7 +456,11 @@ const char *setup_git_directory_gently(int *nongit_ok)
inside_git_dir = 1;
if (!work_tree_env)
inside_work_tree = 0;
- setenv(GIT_DIR_ENVIRONMENT, ".", 1);
+ if (offset != len) {
+ cwd[offset] = '\0';
+ setenv(GIT_DIR_ENVIRONMENT, cwd, 1);
+ } else
+ setenv(GIT_DIR_ENVIRONMENT, ".", 1);
check_repository_format_gently(nongit_ok);
return NULL;
}