pathspec: only match across submodule boundaries when requested
commiteef3df5a93784e4d709907ce03006374ffc3ea26
authorBrandon Williams <bmwill@google.com>
Tue, 5 Dec 2017 00:07:34 +0000 (4 16:07 -0800)
committerJunio C Hamano <gitster@pobox.com>
Tue, 5 Dec 2017 17:23:15 +0000 (5 09:23 -0800)
tree2548858fe0419a17385547bcdfc5ea453e2e732c
parent9560e6245a1a0b7483a57d7018e5b7a852fdba62
pathspec: only match across submodule boundaries when requested

Commit 74ed43711fd (grep: enable recurse-submodules to work on <tree>
objects, 2016-12-16) taught 'tree_entry_interesting()' to be able to
match across submodule boundaries in the presence of wildcards.  This is
done by performing literal matching up to the first wildcard and then
punting to the submodule itself to perform more accurate pattern
matching.  Instead of introducing a new flag to request this behavior,
commit 74ed43711fd overloaded the already existing 'recursive' flag in
'struct pathspec' to request this behavior.

This leads to a bug where whenever any other caller has the 'recursive'
flag set as well as a pathspec with wildcards that all submodules will
be indicated as matches.  One simple example of this is:

git init repo
cd repo

git init submodule
git -C submodule commit -m initial --allow-empty

touch "[bracket]"
git add "[bracket]"
git commit -m bracket
git add submodule
git commit -m submodule

git rev-list HEAD -- "[bracket]"

Fix this by introducing the new flag 'recurse_submodules' in 'struct
pathspec' and using this flag to determine if matches should be allowed
to cross submodule boundaries.

This fixes https://github.com/git-for-windows/git/issues/1371.

Signed-off-by: Brandon Williams <bmwill@google.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
builtin/grep.c
pathspec.h
t/t4208-log-magic-pathspec.sh
tree-walk.c