diff options
author | Nguyễn Thái Ngọc Duy <pclouds@gmail.com> | 2015-09-21 11:56:15 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2015-09-21 20:06:47 +0200 |
commit | 57534ee77d22e725d971ee89c77dc6aad61c573f (patch) | |
tree | b39f066cd62141319d0d5d5d4279013a70d374da /unpack-trees.h | |
parent | dir.c: make last_exclude_matching_from_list() run til the end (diff) | |
download | git-57534ee77d22e725d971ee89c77dc6aad61c573f.tar.xz git-57534ee77d22e725d971ee89c77dc6aad61c573f.zip |
dir.c: don't exclude whole dir prematurely if neg pattern may match
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".
In order for it to detect that the directory under examination should
not be excluded right away, in other words it is a parent directory of a
negative pattern, the "directory path" of the negative pattern must be
literal. Patterns like "!f?o/bar" can't stop "foo" from being excluded.
Basename matching (i.e. "no slashes in the pattern") or must-be-dir
matching (i.e. "trailing slash in the pattern") does not work well with
this. For example, if we descend in "foo" and are examining "foo/abc",
current code for "foo/" pattern will check if path "foo/abc", not "foo",
is a directory. The same problem with basename matching. These may need
big code reorg to make it work.
Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'unpack-trees.h')
0 files changed, 0 insertions, 0 deletions