X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;ds=sidebyside;f=tree-walk.h;h=903a7b0f483fec5cbb6c6b372ab49cc28b655e75;hb=4d1012c3709e356107d0fb0e3bf5a39e0d5c209d;hp=149393aaa476985d3607f796366b537b6622d50e;hpb=a8c40471ab0851bf9a58f7dc76f121258e0690e2;p=git.git diff --git a/tree-walk.h b/tree-walk.h index 149393aaa..903a7b0f4 100644 --- a/tree-walk.h +++ b/tree-walk.h @@ -1,24 +1,39 @@ #ifndef TREE_WALK_H #define TREE_WALK_H -struct tree_desc { - const void *buf; - unsigned long size; -}; - struct name_entry { const unsigned char *sha1; const char *path; unsigned int mode; }; +static inline enum object_type object_type(unsigned int mode) +{ + return S_ISDIR(mode) ? OBJ_TREE : + S_ISGITLINK(mode) ? OBJ_COMMIT : + OBJ_BLOB; +} + +struct tree_desc { + const void *buffer; + struct name_entry entry; + unsigned int size; +}; + +static inline const unsigned char *tree_entry_extract(struct tree_desc *desc, const char **pathp, unsigned int *modep) +{ + *pathp = desc->entry.path; + *modep = canon_mode(desc->entry.mode); + return desc->entry.sha1; +} + static inline int tree_entry_len(const char *name, const unsigned char *sha1) { - return (char *)sha1 - (char *)name - 1; + return (const char *)sha1 - name - 1; } void update_tree_entry(struct tree_desc *); -const unsigned char *tree_entry_extract(struct tree_desc *, const char **, unsigned int *); +void init_tree_desc(struct tree_desc *desc, const void *buf, unsigned long size); /* Helper function that does both of the above and returns true for success */ int tree_entry(struct tree_desc *, struct name_entry *);