 f8a9d42872
			
		
	
	f8a9d42872
	
	
	
		
			
			This follows up commit ed93b449 where we removed overcautious
"working file will be lost" check.
A new option "--exclude-per-directory=.gitignore" can be used to
tell the "git-read-tree" command that the user does not mind
losing contents in untracked files in the working tree, if they
need to be overwritten by a merge (either a two-way "switch
branches" merge, or a three-way merge).
Signed-off-by: Junio C Hamano <junkio@cox.net>
		
	
		
			
				
	
	
		
			37 lines
		
	
	
		
			890 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			890 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef UNPACK_TREES_H
 | |
| #define UNPACK_TREES_H
 | |
| 
 | |
| struct unpack_trees_options;
 | |
| 
 | |
| typedef int (*merge_fn_t)(struct cache_entry **src,
 | |
| 		struct unpack_trees_options *options);
 | |
| 
 | |
| struct unpack_trees_options {
 | |
| 	int reset;
 | |
| 	int merge;
 | |
| 	int update;
 | |
| 	int index_only;
 | |
| 	int nontrivial_merge;
 | |
| 	int trivial_merges_only;
 | |
| 	int verbose_update;
 | |
| 	int aggressive;
 | |
| 	const char *prefix;
 | |
| 	struct dir_struct *dir;
 | |
| 	merge_fn_t fn;
 | |
| 
 | |
| 	int head_idx;
 | |
| 	int merge_size;
 | |
| 
 | |
| 	struct cache_entry *df_conflict_entry;
 | |
| };
 | |
| 
 | |
| extern int unpack_trees(struct object_list *trees,
 | |
| 		struct unpack_trees_options *options);
 | |
| 
 | |
| int threeway_merge(struct cache_entry **stages, struct unpack_trees_options *o);
 | |
| int twoway_merge(struct cache_entry **src, struct unpack_trees_options *o);
 | |
| int bind_merge(struct cache_entry **src, struct unpack_trees_options *o);
 | |
| int oneway_merge(struct cache_entry **src, struct unpack_trees_options *o);
 | |
| 
 | |
| #endif
 |