diff options
| author | Junio C Hamano <gitster@pobox.com> | 2010-10-26 21:40:54 -0700 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2010-10-26 21:40:54 -0700 | 
| commit | 75b17fee72a0f78e0ad31728771231f8b3ed4d56 (patch) | |
| tree | 190461ec1fedaf1a3c5d5d7fc9201a5a6455a144 /merge-recursive.c | |
| parent | 5a3a484d577d8612f729d64f3a069e63df07ec07 (diff) | |
| parent | 4e5dd044c62f2a82de083e7cd46cad7b0d3465ae (diff) | |
| download | git-75b17fee72a0f78e0ad31728771231f8b3ed4d56.tar.gz | |
Merge branch 'jf/merge-ignore-ws'
* jf/merge-ignore-ws:
  merge-recursive: options to ignore whitespace changes
  merge-recursive --patience
  ll-merge: replace flag argument with options struct
  merge-recursive: expose merge options for builtin merge
Diffstat (limited to 'merge-recursive.c')
| -rw-r--r-- | merge-recursive.c | 52 | 
1 files changed, 41 insertions, 11 deletions
| diff --git a/merge-recursive.c b/merge-recursive.c index c574698819..325a97bf31 100644 --- a/merge-recursive.c +++ b/merge-recursive.c @@ -605,22 +605,26 @@ static int merge_3way(struct merge_options *o,  		      const char *branch2)  {  	mmfile_t orig, src1, src2; +	struct ll_merge_options ll_opts = {0};  	char *base_name, *name1, *name2;  	int merge_status; -	int favor; -	if (o->call_depth) -		favor = 0; -	else { +	ll_opts.renormalize = o->renormalize; +	ll_opts.xdl_opts = o->xdl_opts; + +	if (o->call_depth) { +		ll_opts.virtual_ancestor = 1; +		ll_opts.variant = 0; +	} else {  		switch (o->recursive_variant) {  		case MERGE_RECURSIVE_OURS: -			favor = XDL_MERGE_FAVOR_OURS; +			ll_opts.variant = XDL_MERGE_FAVOR_OURS;  			break;  		case MERGE_RECURSIVE_THEIRS: -			favor = XDL_MERGE_FAVOR_THEIRS; +			ll_opts.variant = XDL_MERGE_FAVOR_THEIRS;  			break;  		default: -			favor = 0; +			ll_opts.variant = 0;  			break;  		}  	} @@ -643,10 +647,7 @@ static int merge_3way(struct merge_options *o,  	read_mmblob(&src2, b->sha1);  	merge_status = ll_merge(result_buf, a->path, &orig, base_name, -				&src1, name1, &src2, name2, -				((o->call_depth ? LL_OPT_VIRTUAL_ANCESTOR : 0) | -				 (o->renormalize ? LL_OPT_RENORMALIZE : 0) | -				 create_ll_flag(favor))); +				&src1, name1, &src2, name2, &ll_opts);  	free(name1);  	free(name2); @@ -1550,3 +1551,32 @@ void init_merge_options(struct merge_options *o)  	memset(&o->current_directory_set, 0, sizeof(struct string_list));  	o->current_directory_set.strdup_strings = 1;  } + +int parse_merge_opt(struct merge_options *o, const char *s) +{ +	if (!s || !*s) +		return -1; +	if (!strcmp(s, "ours")) +		o->recursive_variant = MERGE_RECURSIVE_OURS; +	else if (!strcmp(s, "theirs")) +		o->recursive_variant = MERGE_RECURSIVE_THEIRS; +	else if (!strcmp(s, "subtree")) +		o->subtree_shift = ""; +	else if (!prefixcmp(s, "subtree=")) +		o->subtree_shift = s + strlen("subtree="); +	else if (!strcmp(s, "patience")) +		o->xdl_opts |= XDF_PATIENCE_DIFF; +	else if (!strcmp(s, "ignore-space-change")) +		o->xdl_opts |= XDF_IGNORE_WHITESPACE_CHANGE; +	else if (!strcmp(s, "ignore-all-space")) +		o->xdl_opts |= XDF_IGNORE_WHITESPACE; +	else if (!strcmp(s, "ignore-space-at-eol")) +		o->xdl_opts |= XDF_IGNORE_WHITESPACE_AT_EOL; +	else if (!strcmp(s, "renormalize")) +		o->renormalize = 1; +	else if (!strcmp(s, "no-renormalize")) +		o->renormalize = 0; +	else +		return -1; +	return 0; +} | 
