Skip to content

Commit 490544b

Browse files
Clemens Buchachergitster
authored andcommitted
get_cwd_relative(): do not misinterpret suffix as subdirectory
If the current working directory is the same as the work tree path plus a suffix, e.g. 'work' and 'work-xyz', then the suffix '-xyz' would be interpreted as a subdirectory of 'work'. Signed-off-by: Clemens Buchacher <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent e498257 commit 490544b

File tree

2 files changed

+17
-4
lines changed

2 files changed

+17
-4
lines changed

dir.c

Lines changed: 7 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -958,9 +958,14 @@ char *get_relative_cwd(char *buffer, int size, const char *dir)
958958
}
959959
if (*dir)
960960
return NULL;
961-
if (*cwd == '/')
961+
switch (*cwd) {
962+
case '\0':
963+
return cwd;
964+
case '/':
962965
return cwd + 1;
963-
return cwd;
966+
default:
967+
return NULL;
968+
}
964969
}
965970

966971
int is_inside_dir(const char *dir)

t/t1501-worktree.sh

Lines changed: 10 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -30,6 +30,7 @@ test_rev_parse() {
3030

3131
EMPTY_TREE=$(git write-tree)
3232
mkdir -p work/sub/dir || exit 1
33+
mkdir -p work2 || exit 1
3334
mv .git repo.git || exit 1
3435

3536
say "core.worktree = relative path"
@@ -54,7 +55,9 @@ GIT_DIR=$(pwd)/repo.git
5455
GIT_CONFIG=$GIT_DIR/config
5556
git config core.worktree "$(pwd)/work"
5657
test_rev_parse 'outside' false false false
57-
cd work || exit 1
58+
cd work2
59+
test_rev_parse 'outside2' false false false
60+
cd ../work || exit 1
5861
test_rev_parse 'inside' false false true ''
5962
cd sub/dir || exit 1
6063
test_rev_parse 'subdirectory' false false true sub/dir/
@@ -67,7 +70,9 @@ git config core.worktree non-existent
6770
GIT_WORK_TREE=work
6871
export GIT_WORK_TREE
6972
test_rev_parse 'outside' false false false
70-
cd work || exit 1
73+
cd work2
74+
test_rev_parse 'outside' false false false
75+
cd ../work || exit 1
7176
GIT_WORK_TREE=.
7277
test_rev_parse 'inside' false false true ''
7378
cd sub/dir || exit 1
@@ -76,6 +81,7 @@ test_rev_parse 'subdirectory' false false true sub/dir/
7681
cd ../../.. || exit 1
7782

7883
mv work repo.git/work
84+
mv work2 repo.git/work2
7985

8086
say "GIT_WORK_TREE=absolute path, work tree below git dir"
8187
GIT_DIR=$(pwd)/repo.git
@@ -86,6 +92,8 @@ cd repo.git || exit 1
8692
test_rev_parse 'in repo.git' false true false
8793
cd objects || exit 1
8894
test_rev_parse 'in repo.git/objects' false true false
95+
cd ../work2 || exit 1
96+
test_rev_parse 'in repo.git/work2' false true false
8997
cd ../work || exit 1
9098
test_rev_parse 'in repo.git/work' false true true ''
9199
cd sub/dir || exit 1

0 commit comments

Comments
 (0)