Skip to content

Commit bb52863

Browse files
pcloudsgitster
authored andcommitted
setup_git_directory(): fix move to worktree toplevel directory
When setup_git_directory() returns successfully, it is supposed to move current working directory to worktree toplevel directory. However, the code recomputing prefix inside setup_git_directory() has to move cwd back to original working directory, in order to get new prefix. After that, it should move cwd back to worktree toplevel directory as expected. Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
1 parent f83eafd commit bb52863

File tree

1 file changed

+2
-0
lines changed

1 file changed

+2
-0
lines changed

setup.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -581,6 +581,8 @@ const char *setup_git_directory(void)
581581
if (retval && chdir(retval))
582582
die ("Could not jump back into original cwd");
583583
rel = get_relative_cwd(buffer, PATH_MAX, get_git_work_tree());
584+
if (rel && *rel && chdir(get_git_work_tree()))
585+
die ("Could not jump to working directory");
584586
return rel && *rel ? strcat(rel, "/") : NULL;
585587
}
586588

0 commit comments

Comments
 (0)