]> git.ipfire.org Git - thirdparty/git.git/blame - tree-walk.h
Merge branch 'ar/diff'
[thirdparty/git.git] / tree-walk.h
CommitLineData
1b0c7174
JH
1#ifndef TREE_WALK_H
2#define TREE_WALK_H
3
4struct tree_desc {
4c068a98 5 const void *buf;
1b0c7174
JH
6 unsigned long size;
7};
8
9struct name_entry {
10 const unsigned char *sha1;
11 const char *path;
12 unsigned int mode;
13 int pathlen;
14};
15
304de2d2
LT
16static inline int tree_entry_len(const char *name, const unsigned char *sha1)
17{
18 return (char *)sha1 - (char *)name - 1;
19}
20
1b0c7174
JH
21void update_tree_entry(struct tree_desc *);
22const unsigned char *tree_entry_extract(struct tree_desc *, const char **, unsigned int *);
23
4c068a98
LT
24/* Helper function that does both of the above and returns true for success */
25int tree_entry(struct tree_desc *, struct name_entry *);
26
1b0c7174
JH
27void *fill_tree_descriptor(struct tree_desc *desc, const unsigned char *sha1);
28
29typedef void (*traverse_callback_t)(int n, unsigned long mask, struct name_entry *entry, const char *base);
30
31void traverse_trees(int n, struct tree_desc *t, const char *base, traverse_callback_t callback);
32
4dcff634
JH
33int get_tree_entry(const unsigned char *, const char *, unsigned char *, unsigned *);
34
1b0c7174 35#endif