X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=tree.h;h=6a875464b051e043f49cd938fabfada1cfdbd507;hb=f75e53edb38c97c8b21b69d4fc00d5419199ae4b;hp=330ab64bbd40bd9202a7474cbda0818b98640cde;hpb=a549e11cc2fee10ddf66dd98ea79f7c624eee34e;p=git.git diff --git a/tree.h b/tree.h index 330ab64b..6a875464 100644 --- a/tree.h +++ b/tree.h @@ -10,21 +10,20 @@ struct tree_entry_list { unsigned directory : 1; unsigned executable : 1; unsigned symlink : 1; - unsigned zeropad : 1; unsigned int mode; - char *name; - union { - struct object *any; - struct tree *tree; - struct blob *blob; - } item; + const char *name; + const unsigned char *sha1; }; struct tree { struct object object; - struct tree_entry_list *entries; + void *buffer; + unsigned long size; }; +struct tree_entry_list *create_tree_entry_list(struct tree *); +void free_tree_entry_list(struct tree_entry_list *); + struct tree *lookup_tree(const unsigned char *sha1); int parse_tree_buffer(struct tree *item, void *buffer, unsigned long size); @@ -35,7 +34,7 @@ int parse_tree(struct tree *tree); struct tree *parse_tree_indirect(const unsigned char *sha1); #define READ_TREE_RECURSIVE 1 -typedef int (*read_tree_fn_t)(unsigned char *, const char *, int, const char *, unsigned int, int); +typedef int (*read_tree_fn_t)(const unsigned char *, const char *, int, const char *, unsigned int, int); extern int read_tree_recursive(struct tree *tree, const char *base, int baselen,