Discard "deleted" cache entries after using them to update the working tree
[git/dscho.git] / unpack-trees.h
blob83d12295325ba234458d140c5cc718ce5176ede9
1 #ifndef UNPACK_TREES_H
2 #define UNPACK_TREES_H
4 struct unpack_trees_options;
6 typedef int (*merge_fn_t)(struct cache_entry **src,
7 struct unpack_trees_options *options,
8 int remove);
10 struct unpack_trees_options {
11 int reset;
12 int merge;
13 int update;
14 int index_only;
15 int nontrivial_merge;
16 int trivial_merges_only;
17 int verbose_update;
18 int aggressive;
19 int gently;
20 const char *prefix;
21 int pos;
22 struct dir_struct *dir;
23 merge_fn_t fn;
25 int head_idx;
26 int merge_size;
28 struct cache_entry *df_conflict_entry;
29 void *unpack_data;
32 extern int unpack_trees(unsigned n, struct tree_desc *t,
33 struct unpack_trees_options *options);
35 int threeway_merge(struct cache_entry **stages, struct unpack_trees_options *o, int);
36 int twoway_merge(struct cache_entry **src, struct unpack_trees_options *o, int);
37 int bind_merge(struct cache_entry **src, struct unpack_trees_options *o, int);
38 int oneway_merge(struct cache_entry **src, struct unpack_trees_options *o, int);
40 #endif