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
 |