diff options
| author | Junio C Hamano <gitster@pobox.com> | 2009-05-03 15:01:19 -0700 |
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2009-05-03 15:01:19 -0700 |
| commit | 652f0c8f1df362755253fe9c5a975be7e5a5cbdc (patch) | |
| tree | a3b08e754f6128a37ca14741d2269b08489f0613 /tree.c | |
| parent | Merge branch 'maint-1.6.0' into maint-1.6.1 (diff) | |
| parent | match_tree_entry(): a pathspec only matches at directory boundaries (diff) | |
| download | git-652f0c8f1df362755253fe9c5a975be7e5a5cbdc.tar.gz git-652f0c8f1df362755253fe9c5a975be7e5a5cbdc.zip | |
Merge branch 'bs/maint-1.6.0-tree-walk-prefix' into maint-1.6.1
* 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.c')
| -rw-r--r-- | tree.c | 8 |
1 files changed, 6 insertions, 2 deletions
@@ -60,8 +60,12 @@ static int match_tree_entry(const char *base, int baselen, const char *path, uns /* If it doesn't match, move along... */ if (strncmp(base, match, matchlen)) continue; - /* The base is a subdirectory of a path which was specified. */ - return 1; + /* pathspecs match only at the directory boundaries */ + if (!matchlen || + base[matchlen] == '/' || + match[matchlen - 1] == '/') + return 1; + continue; } /* Does the base match? */ |
