Junio C Hamano | 1b0c717 | 2006-03-29 22:55:43 -0800 | [diff] [blame] | 1 | #ifndef TREE_WALK_H |
| 2 | #define TREE_WALK_H |
| 3 | |
Junio C Hamano | 1b0c717 | 2006-03-29 22:55:43 -0800 | [diff] [blame] | 4 | struct name_entry { |
| 5 | const unsigned char *sha1; |
| 6 | const char *path; |
| 7 | unsigned int mode; |
Junio C Hamano | 1b0c717 | 2006-03-29 22:55:43 -0800 | [diff] [blame] | 8 | }; |
| 9 | |
Linus Torvalds | 4651ece | 2007-03-21 10:09:56 -0700 | [diff] [blame] | 10 | struct tree_desc { |
| 11 | const void *buffer; |
| 12 | struct name_entry entry; |
| 13 | unsigned int size; |
| 14 | }; |
| 15 | |
| 16 | static inline const unsigned char *tree_entry_extract(struct tree_desc *desc, const char **pathp, unsigned int *modep) |
| 17 | { |
| 18 | *pathp = desc->entry.path; |
| 19 | *modep = canon_mode(desc->entry.mode); |
| 20 | return desc->entry.sha1; |
| 21 | } |
| 22 | |
Linus Torvalds | 304de2d | 2007-03-17 20:06:24 -0700 | [diff] [blame] | 23 | static inline int tree_entry_len(const char *name, const unsigned char *sha1) |
| 24 | { |
Junio C Hamano | 63daae4 | 2007-06-22 23:19:43 -0700 | [diff] [blame] | 25 | return (const char *)sha1 - name - 1; |
Linus Torvalds | 304de2d | 2007-03-17 20:06:24 -0700 | [diff] [blame] | 26 | } |
| 27 | |
Junio C Hamano | 1b0c717 | 2006-03-29 22:55:43 -0800 | [diff] [blame] | 28 | void update_tree_entry(struct tree_desc *); |
Linus Torvalds | 6fda5e5 | 2007-03-21 10:08:25 -0700 | [diff] [blame] | 29 | void init_tree_desc(struct tree_desc *desc, const void *buf, unsigned long size); |
Junio C Hamano | 1b0c717 | 2006-03-29 22:55:43 -0800 | [diff] [blame] | 30 | |
Linus Torvalds | 4c068a9 | 2006-05-30 09:45:45 -0700 | [diff] [blame] | 31 | /* Helper function that does both of the above and returns true for success */ |
| 32 | int tree_entry(struct tree_desc *, struct name_entry *); |
| 33 | |
Junio C Hamano | 1b0c717 | 2006-03-29 22:55:43 -0800 | [diff] [blame] | 34 | void *fill_tree_descriptor(struct tree_desc *desc, const unsigned char *sha1); |
| 35 | |
Linus Torvalds | 40d934d | 2008-03-05 18:59:29 -0800 | [diff] [blame] | 36 | struct traverse_info; |
Linus Torvalds | 91e4f03 | 2008-03-05 20:06:18 -0800 | [diff] [blame] | 37 | typedef int (*traverse_callback_t)(int n, unsigned long mask, unsigned long dirmask, struct name_entry *entry, struct traverse_info *); |
Linus Torvalds | 5803c6f | 2008-03-05 19:44:06 -0800 | [diff] [blame] | 38 | int traverse_trees(int n, struct tree_desc *t, struct traverse_info *info); |
Junio C Hamano | 1b0c717 | 2006-03-29 22:55:43 -0800 | [diff] [blame] | 39 | |
Linus Torvalds | 40d934d | 2008-03-05 18:59:29 -0800 | [diff] [blame] | 40 | struct traverse_info { |
| 41 | struct traverse_info *prev; |
| 42 | struct name_entry name; |
| 43 | int pathlen; |
| 44 | |
Linus Torvalds | 91e4f03 | 2008-03-05 20:06:18 -0800 | [diff] [blame] | 45 | unsigned long conflicts; |
Linus Torvalds | 40d934d | 2008-03-05 18:59:29 -0800 | [diff] [blame] | 46 | traverse_callback_t fn; |
| 47 | void *data; |
| 48 | }; |
Junio C Hamano | 1b0c717 | 2006-03-29 22:55:43 -0800 | [diff] [blame] | 49 | |
Junio C Hamano | 4dcff63 | 2006-04-19 14:05:47 -0700 | [diff] [blame] | 50 | int get_tree_entry(const unsigned char *, const char *, unsigned char *, unsigned *); |
Linus Torvalds | 40d934d | 2008-03-05 18:59:29 -0800 | [diff] [blame] | 51 | extern char *make_traverse_path(char *path, const struct traverse_info *info, const struct name_entry *n); |
| 52 | extern void setup_traverse_info(struct traverse_info *info, const char *base); |
| 53 | |
| 54 | static inline int traverse_path_len(const struct traverse_info *info, const struct name_entry *n) |
| 55 | { |
| 56 | return info->pathlen + tree_entry_len(n->path, n->sha1); |
| 57 | } |
Junio C Hamano | 4dcff63 | 2006-04-19 14:05:47 -0700 | [diff] [blame] | 58 | |
Junio C Hamano | 1b0c717 | 2006-03-29 22:55:43 -0800 | [diff] [blame] | 59 | #endif |