2006-07-30 12:25:18 -06:00
|
|
|
#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;
|
2006-12-04 17:00:46 -07:00
|
|
|
struct dir_struct *dir;
|
2006-07-30 12:25:18 -06:00
|
|
|
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);
|
|
|
|
|
2006-07-30 12:26:15 -06:00
|
|
|
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);
|
|
|
|
|
2006-07-30 12:25:18 -06:00
|
|
|
#endif
|