diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2008-03-05 18:59:29 -0800 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2008-03-09 00:43:47 -0800 | 
| commit | 40d934df72eaf244c826d5c26da0896ce7185cb6 (patch) | |
| tree | ee461fff98614c9a4593f16944a2ff0b05d00a78 /tree-walk.h | |
| parent | 0ab9e1e8cdaefdd33bf24bb0be0ec766483f8bbe (diff) | |
| download | git-40d934df72eaf244c826d5c26da0896ce7185cb6.tar.gz | |
Make 'traverse_tree()' use linked structure rather than 'const char *base'
This makes the calling convention a bit less obvious, but a lot more
flexible.  Instead of allocating and extending a new 'base' string, we
just link the top-most name into a linked list of the 'info' structure
when traversing a subdirectory, and we can generate the basename by
following the list.
Perhaps even more importantly, the linked list of info structures also
gives us a place to naturally save off other information than just the
directory name.
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'tree-walk.h')
| -rw-r--r-- | tree-walk.h | 20 | 
1 files changed, 18 insertions, 2 deletions
diff --git a/tree-walk.h b/tree-walk.h index db0fbdc701..7c4ae646be 100644 --- a/tree-walk.h +++ b/tree-walk.h @@ -33,10 +33,26 @@ int tree_entry(struct tree_desc *, struct name_entry *);  void *fill_tree_descriptor(struct tree_desc *desc, const unsigned char *sha1); -typedef void (*traverse_callback_t)(int n, unsigned long mask, struct name_entry *entry, const char *base); +struct traverse_info; +typedef void (*traverse_callback_t)(int n, unsigned long mask, struct name_entry *entry, struct traverse_info *); +void traverse_trees(int n, struct tree_desc *t, struct traverse_info *info); -void traverse_trees(int n, struct tree_desc *t, const char *base, traverse_callback_t callback); +struct traverse_info { +	struct traverse_info *prev; +	struct name_entry name; +	int pathlen; + +	traverse_callback_t fn; +	void *data; +};  int get_tree_entry(const unsigned char *, const char *, unsigned char *, unsigned *); +extern char *make_traverse_path(char *path, const struct traverse_info *info, const struct name_entry *n); +extern void setup_traverse_info(struct traverse_info *info, const char *base); + +static inline int traverse_path_len(const struct traverse_info *info, const struct name_entry *n) +{ +	return info->pathlen + tree_entry_len(n->path, n->sha1); +}  #endif  | 
