Skip to content

Commit

Permalink
Make setup_git_env() resolve .git file when $GIT_DIR is not specified
Browse files Browse the repository at this point in the history
This makes reinitializing on a .git file repository work.

This is probably the only case that setup_git_env() (via
set_git_dir()) is called on a .git file. Other cases in
setup_git_dir_gently() and enter_repo() both cover .git file case
explicitly because they need to verify the target repo is valid.

Reported-by: Ximin Luo <infinity0@gmx.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
pclouds authored and gitster committed Sep 3, 2013
1 parent a3bc3d0 commit 487a2b7
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 5 deletions.
9 changes: 4 additions & 5 deletions environment.c
Expand Up @@ -123,14 +123,13 @@ static char *expand_namespace(const char *raw_namespace)

static void setup_git_env(void)
{
const char *gitfile;

git_dir = getenv(GIT_DIR_ENVIRONMENT);
git_dir = git_dir ? xstrdup(git_dir) : NULL;
if (!git_dir) {
git_dir = read_gitfile(DEFAULT_GIT_DIR_ENVIRONMENT);
git_dir = git_dir ? xstrdup(git_dir) : NULL;
}
if (!git_dir)
git_dir = DEFAULT_GIT_DIR_ENVIRONMENT;
gitfile = read_gitfile(git_dir);
git_dir = xstrdup(gitfile ? gitfile : git_dir);
git_object_dir = getenv(DB_ENVIRONMENT);
if (!git_object_dir) {
git_object_dir = xmalloc(strlen(git_dir) + 9);
Expand Down
4 changes: 4 additions & 0 deletions t/t0001-init.sh
Expand Up @@ -379,6 +379,10 @@ test_expect_success 'init with separate gitdir' '
test -d realgitdir/refs
'

test_expect_success 're-init on .git file' '
( cd newdir && git init )
'

test_expect_success 're-init to update git link' '
(
cd newdir &&
Expand Down

0 comments on commit 487a2b7

Please sign in to comment.