diff options
author | Nguyễn Thái Ngọc Duy <pclouds@gmail.com> | 2010-12-15 16:02:44 +0100 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2011-02-03 23:08:30 +0100 |
commit | bc96cc87dbb229cbdabfd93391e24ef168713a74 (patch) | |
tree | 9ff90a888efab369476fe4003fe1e36fa0fbd9ba /dir.h | |
parent | tree_entry_interesting(): refactor into separate smaller functions (diff) | |
download | git-bc96cc87dbb229cbdabfd93391e24ef168713a74.tar.xz git-bc96cc87dbb229cbdabfd93391e24ef168713a74.zip |
tree_entry_interesting(): support depth limit
This is needed to replace pathspec_matches() in builtin/grep.c.
max_depth == -1 means infinite depth. Depth limit is only effective
when pathspec.recursive == 1. When pathspec.recursive == 0, the
behavior depends on match functions: non-recursive for
tree_entry_interesting() and recursive for match_pathspec{,_depth}
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 'dir.h')
-rw-r--r-- | dir.h | 1 |
1 files changed, 1 insertions, 0 deletions
@@ -65,6 +65,7 @@ struct dir_struct { #define MATCHED_FNMATCH 2 #define MATCHED_EXACTLY 3 extern int match_pathspec(const char **pathspec, const char *name, int namelen, int prefix, char *seen); +extern int within_depth(const char *name, int namelen, int depth, int max_depth); extern int fill_directory(struct dir_struct *dir, const char **pathspec); extern int read_directory(struct dir_struct *, const char *path, int len, const char **pathspec); |