diff options
author | Junio C Hamano <gitster@pobox.com> | 2009-04-07 22:33:10 -0700 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2009-04-07 22:33:10 -0700 |
commit | 00f39fc9955c22b6a8a2702b88509647e65291ce (patch) | |
tree | c08fb8ff323f175d25857d3db7925149c62c7684 /tree-diff.c | |
parent | fe42fe4bcaaf262082a982e43bca1d8cac5a706d (diff) | |
parent | 8092bfb6c23776d72ce4b38a3b517c3753c3b9fe (diff) | |
download | git-00f39fc9955c22b6a8a2702b88509647e65291ce.tar.gz git-00f39fc9955c22b6a8a2702b88509647e65291ce.tar.xz |
Merge branch 'bs/maint-1.6.0-tree-walk-prefix'
* bs/maint-1.6.0-tree-walk-prefix:
match_tree_entry(): a pathspec only matches at directory boundaries
tree_entry_interesting: a pathspec only matches at directory boundary
Diffstat (limited to 'tree-diff.c')
-rw-r--r-- | tree-diff.c | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/tree-diff.c b/tree-diff.c index 9f67af6c1..b05d0f435 100644 --- a/tree-diff.c +++ b/tree-diff.c @@ -118,10 +118,16 @@ static int tree_entry_interesting(struct tree_desc *desc, const char *base, int continue; /* - * The base is a subdirectory of a path which - * was specified, so all of them are interesting. + * If the base is a subdirectory of a path which + * was specified, all of them are interesting. */ - return 2; + if (!matchlen || + base[matchlen] == '/' || + match[matchlen - 1] == '/') + return 2; + + /* Just a random prefix match */ + continue; } /* Does the base match? */ |