Code

git-merge-file --ours, --theirs
authorJunio C Hamano <gitster@pobox.com>
Fri, 20 Jun 2008 07:17:27 +0000 (00:17 -0700)
committerJunio C Hamano <gitster@pobox.com>
Mon, 30 Nov 2009 07:11:46 +0000 (23:11 -0800)
commit73eb40eeaaebc5ebae283c06286b96b4aea00143
tree79b7e3d0bcc3c57e8dcec293fb95286cd4342189
parent44148f2daf6e1ac3fe087dd07da2930411b3bcf2
git-merge-file --ours, --theirs

Sometimes people want their conflicting merges autoresolved by
favouring upstream changes.  The standard answer they are given is
to run "git diff --name-only | xargs git checkout MERGE_HEAD --" in
such a case.  This is to accept automerge results for the paths that
are fully resolved automatically, while taking their version of the
file in full for paths that have conflicts.

This is problematic on two counts.

One is that this is not exactly what these people want.  It discards
all changes they did on their branch for any paths that conflicted.
They usually want to salvage as much automerge result as possible in
a conflicted file, and want to take the upstream change only in the
conflicted part.

This patch teaches two new modes of operation to the lowest-lever
merge machinery, xdl_merge().  Instead of leaving the conflicted
lines from both sides enclosed in <<<, ===, and >>> markers, the
conflicts are resolved favouring our side or their side of changes.

A larger problem is that this tends to encourage a bad workflow by
allowing people to record such a mixed up half-merged result as a
full commit without auditing.  This commit does not tackle this
issue at all.  In git, we usually give long enough rope to users
with strange wishes as long as the risky features are not enabled by
default, and this is such a risky feature.

Signed-off-by: Avery Pennarun <apenwarr@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
Documentation/git-merge-file.txt
builtin-merge-file.c
xdiff/xdiff.h
xdiff/xmerge.c