diff options
| -rw-r--r-- | setup.c | 22 | ||||
| -rwxr-xr-x | t/t2104-update-index-gitfile.sh | 2 | 
2 files changed, 20 insertions, 4 deletions
| @@ -252,6 +252,8 @@ static int check_repository_format_gently(int *nongit_ok)  const char *read_gitfile_gently(const char *path)  {  	char *buf; +	char *dir; +	const char *slash;  	struct stat st;  	int fd;  	size_t len; @@ -276,9 +278,23 @@ const char *read_gitfile_gently(const char *path)  	if (len < 9)  		die("No path in gitfile: %s", path);  	buf[len] = '\0'; -	if (!is_git_directory(buf + 8)) -		die("Not a git repository: %s", buf + 8); -	path = make_absolute_path(buf + 8); +	dir = buf + 8; + +	if (!is_absolute_path(dir) && (slash = strrchr(path, '/'))) { +		size_t pathlen = slash+1 - path; +		size_t dirlen = pathlen + len - 8; +		dir = xmalloc(dirlen + 1); +		strncpy(dir, path, pathlen); +		strncpy(dir + pathlen, buf + 8, len - 8); +		dir[dirlen] = '\0'; +		free(buf); +		buf = dir; +	} + +	if (!is_git_directory(dir)) +		die("Not a git repository: %s", dir); +	path = make_absolute_path(dir); +  	free(buf);  	return path;  } diff --git a/t/t2104-update-index-gitfile.sh b/t/t2104-update-index-gitfile.sh index ba719846a6..641607d89a 100755 --- a/t/t2104-update-index-gitfile.sh +++ b/t/t2104-update-index-gitfile.sh @@ -31,7 +31,7 @@ test_expect_success 'submodule with relative .git file' '  	 test_commit first)  ' -test_expect_failure 'add gitlink to relative .git file' ' +test_expect_success 'add gitlink to relative .git file' '  	git update-index --add -- sub2  ' | 
