Browse Source
If there is a pattern "!foo/bar", this patch makes it not exclude "foo" right away. This gives us a chance to examine "foo" and re-include "foo/bar". Helped-by: brian m. carlson <sandals@crustytoothpaste.net> Helped-by: Micha Wiedenmann <mw-u2@gmx.de> Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>maint
![pclouds@gmail.com](/assets/img/avatar_default.png)
![Junio C Hamano](/assets/img/avatar_default.png)
4 changed files with 276 additions and 10 deletions
@ -0,0 +1,153 @@ |
|||||||
|
#!/bin/sh |
||||||
|
|
||||||
|
test_description='test re-include patterns' |
||||||
|
|
||||||
|
. ./test-lib.sh |
||||||
|
|
||||||
|
test_expect_success 'setup' ' |
||||||
|
mkdir -p fooo foo/bar tmp && |
||||||
|
touch abc foo/def foo/bar/ghi foo/bar/bar |
||||||
|
' |
||||||
|
|
||||||
|
test_expect_success 'no match, do not enter subdir and waste cycles' ' |
||||||
|
cat >.gitignore <<-\EOF && |
||||||
|
/tmp |
||||||
|
/foo |
||||||
|
!fooo/bar/bar |
||||||
|
EOF |
||||||
|
GIT_TRACE_EXCLUDE="$(pwd)/tmp/trace" git ls-files -o --exclude-standard >tmp/actual && |
||||||
|
! grep "enter .foo/.\$" tmp/trace && |
||||||
|
cat >tmp/expected <<-\EOF && |
||||||
|
.gitignore |
||||||
|
abc |
||||||
|
EOF |
||||||
|
test_cmp tmp/expected tmp/actual |
||||||
|
' |
||||||
|
|
||||||
|
test_expect_success 'match, excluded by literal pathname pattern' ' |
||||||
|
cat >.gitignore <<-\EOF && |
||||||
|
/tmp |
||||||
|
/fooo |
||||||
|
/foo |
||||||
|
!foo/bar/bar |
||||||
|
EOF |
||||||
|
cat >fooo/.gitignore <<-\EOF && |
||||||
|
!/* |
||||||
|
EOF git ls-files -o --exclude-standard >tmp/actual && |
||||||
|
cat >tmp/expected <<-\EOF && |
||||||
|
.gitignore |
||||||
|
abc |
||||||
|
foo/bar/bar |
||||||
|
EOF |
||||||
|
test_cmp tmp/expected tmp/actual |
||||||
|
' |
||||||
|
|
||||||
|
test_expect_success 'match, excluded by wildcard pathname pattern' ' |
||||||
|
cat >.gitignore <<-\EOF && |
||||||
|
/tmp |
||||||
|
/fooo |
||||||
|
/fo? |
||||||
|
!foo/bar/bar |
||||||
|
EOF |
||||||
|
git ls-files -o --exclude-standard >tmp/actual && |
||||||
|
cat >tmp/expected <<-\EOF && |
||||||
|
.gitignore |
||||||
|
abc |
||||||
|
foo/bar/bar |
||||||
|
EOF |
||||||
|
test_cmp tmp/expected tmp/actual |
||||||
|
' |
||||||
|
|
||||||
|
test_expect_success 'match, excluded by literal basename pattern' ' |
||||||
|
cat >.gitignore <<-\EOF && |
||||||
|
/tmp |
||||||
|
/fooo |
||||||
|
foo |
||||||
|
!foo/bar/bar |
||||||
|
EOF |
||||||
|
git ls-files -o --exclude-standard >tmp/actual && |
||||||
|
cat >tmp/expected <<-\EOF && |
||||||
|
.gitignore |
||||||
|
abc |
||||||
|
foo/bar/bar |
||||||
|
EOF |
||||||
|
test_cmp tmp/expected tmp/actual |
||||||
|
' |
||||||
|
|
||||||
|
test_expect_success 'match, excluded by wildcard basename pattern' ' |
||||||
|
cat >.gitignore <<-\EOF && |
||||||
|
/tmp |
||||||
|
/fooo |
||||||
|
fo? |
||||||
|
!foo/bar/bar |
||||||
|
EOF |
||||||
|
git ls-files -o --exclude-standard >tmp/actual && |
||||||
|
cat >tmp/expected <<-\EOF && |
||||||
|
.gitignore |
||||||
|
abc |
||||||
|
foo/bar/bar |
||||||
|
EOF |
||||||
|
test_cmp tmp/expected tmp/actual |
||||||
|
' |
||||||
|
|
||||||
|
test_expect_success 'match, excluded by literal mustbedir, basename pattern' ' |
||||||
|
cat >.gitignore <<-\EOF && |
||||||
|
/tmp |
||||||
|
/fooo |
||||||
|
foo/ |
||||||
|
!foo/bar/bar |
||||||
|
EOF |
||||||
|
git ls-files -o --exclude-standard >tmp/actual && |
||||||
|
cat >tmp/expected <<-\EOF && |
||||||
|
.gitignore |
||||||
|
abc |
||||||
|
foo/bar/bar |
||||||
|
EOF |
||||||
|
test_cmp tmp/expected tmp/actual |
||||||
|
' |
||||||
|
|
||||||
|
test_expect_success 'match, excluded by literal mustbedir, pathname pattern' ' |
||||||
|
cat >.gitignore <<-\EOF && |
||||||
|
/tmp |
||||||
|
/fooo |
||||||
|
/foo/ |
||||||
|
!foo/bar/bar |
||||||
|
EOF |
||||||
|
git ls-files -o --exclude-standard >tmp/actual && |
||||||
|
cat >tmp/expected <<-\EOF && |
||||||
|
.gitignore |
||||||
|
abc |
||||||
|
foo/bar/bar |
||||||
|
EOF |
||||||
|
test_cmp tmp/expected tmp/actual |
||||||
|
' |
||||||
|
|
||||||
|
test_expect_success 'prepare for nested negatives' ' |
||||||
|
cat >.git/info/exclude <<-\EOF && |
||||||
|
/.gitignore |
||||||
|
/tmp |
||||||
|
/foo |
||||||
|
/abc |
||||||
|
EOF |
||||||
|
git ls-files -o --exclude-standard >tmp/actual && |
||||||
|
test_must_be_empty tmp/actual && |
||||||
|
mkdir -p 1/2/3/4 && |
||||||
|
touch 1/f 1/2/f 1/2/3/f 1/2/3/4/f |
||||||
|
' |
||||||
|
|
||||||
|
test_expect_success 'match, literal pathname, nested negatives' ' |
||||||
|
cat >.gitignore <<-\EOF && |
||||||
|
/1 |
||||||
|
!1/2 |
||||||
|
1/2/3 |
||||||
|
!1/2/3/4 |
||||||
|
EOF |
||||||
|
git ls-files -o --exclude-standard >tmp/actual && |
||||||
|
cat >tmp/expected <<-\EOF && |
||||||
|
1/2/3/4/f |
||||||
|
1/2/f |
||||||
|
EOF |
||||||
|
test_cmp tmp/expected tmp/actual |
||||||
|
' |
||||||
|
|
||||||
|
test_done |
Loading…
Reference in new issue