setup: split off a function to checks working dir for .git file
The repository discovery procedure looks something like this: while (same filesystem) { check .git in working dir check . chdir(..) } Add a function for the first step to make the actual code look a bit closer to that pseudocode. Signed-off-by: Jonathan Nieder <jrnieder@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
e4e303479b
commit
93a00542ea
20
setup.c
20
setup.c
@ -348,6 +348,18 @@ static const char *setup_explicit_git_dir(const char *gitdirenv,
|
|||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int cwd_contains_git_dir(const char **gitfile_dirp)
|
||||||
|
{
|
||||||
|
const char *gitfile_dir = read_gitfile_gently(DEFAULT_GIT_DIR_ENVIRONMENT);
|
||||||
|
*gitfile_dirp = gitfile_dir;
|
||||||
|
if (gitfile_dir) {
|
||||||
|
if (set_git_dir(gitfile_dir))
|
||||||
|
die("Repository setup failed");
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return is_git_directory(DEFAULT_GIT_DIR_ENVIRONMENT);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* We cannot decide in this function whether we are in the work tree or
|
* We cannot decide in this function whether we are in the work tree or
|
||||||
* not, since the config can only be read _after_ this function was called.
|
* not, since the config can only be read _after_ this function was called.
|
||||||
@ -407,13 +419,7 @@ const char *setup_git_directory_gently(int *nongit_ok)
|
|||||||
current_device = buf.st_dev;
|
current_device = buf.st_dev;
|
||||||
}
|
}
|
||||||
for (;;) {
|
for (;;) {
|
||||||
gitfile_dir = read_gitfile_gently(DEFAULT_GIT_DIR_ENVIRONMENT);
|
if (cwd_contains_git_dir(&gitfile_dir))
|
||||||
if (gitfile_dir) {
|
|
||||||
if (set_git_dir(gitfile_dir))
|
|
||||||
die("Repository setup failed");
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if (is_git_directory(DEFAULT_GIT_DIR_ENVIRONMENT))
|
|
||||||
break;
|
break;
|
||||||
if (is_git_directory(".")) {
|
if (is_git_directory(".")) {
|
||||||
inside_git_dir = 1;
|
inside_git_dir = 1;
|
||||||
|
Loading…
Reference in New Issue
Block a user