 6a0b0b6de9
			
		
	
	6a0b0b6de9
	
	
	
		
			
			This allows the callback to use 'base' as a temporary buffer to quickly assemble full path "without" extra allocation. The callback has to restore it afterwards of course. Helped-by: Eric Sunshine <sunshine@sunshineco.com> Signed-off-by: Nguyễn Thái Ngọc Duy <pclouds@gmail.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
		
			
				
	
	
		
			36 lines
		
	
	
		
			958 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			958 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef TREE_H
 | |
| #define TREE_H
 | |
| 
 | |
| #include "object.h"
 | |
| 
 | |
| extern const char *tree_type;
 | |
| struct strbuf;
 | |
| 
 | |
| struct tree {
 | |
| 	struct object object;
 | |
| 	void *buffer;
 | |
| 	unsigned long size;
 | |
| };
 | |
| 
 | |
| struct tree *lookup_tree(const unsigned char *sha1);
 | |
| 
 | |
| int parse_tree_buffer(struct tree *item, void *buffer, unsigned long size);
 | |
| 
 | |
| int parse_tree(struct tree *tree);
 | |
| void free_tree_buffer(struct tree *tree);
 | |
| 
 | |
| /* Parses and returns the tree in the given ent, chasing tags and commits. */
 | |
| struct tree *parse_tree_indirect(const unsigned char *sha1);
 | |
| 
 | |
| #define READ_TREE_RECURSIVE 1
 | |
| typedef int (*read_tree_fn_t)(const unsigned char *, struct strbuf *, const char *, unsigned int, int, void *);
 | |
| 
 | |
| extern int read_tree_recursive(struct tree *tree,
 | |
| 			       const char *base, int baselen,
 | |
| 			       int stage, const struct pathspec *pathspec,
 | |
| 			       read_tree_fn_t fn, void *context);
 | |
| 
 | |
| extern int read_tree(struct tree *tree, int stage, struct pathspec *pathspec);
 | |
| 
 | |
| #endif /* TREE_H */
 |