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 @@
@@ -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