Differences between revisions 1 and 4 (spanning 3 versions)
Revision 1 as of 2005-08-26 00:58:36
Size: 279
Editor: waste
Comment:
Revision 4 as of 2007-10-10 21:47:50
Size: 1304
Editor: 193
Comment:
Deletions are marked like this. Additions are marked like this.
Line 3: Line 3:
A conflict occurs when two independent ["ChangeSet"]s modify overlapping sections of a file in different ways. During a ["Merge"], ["Mercurial"] cannot ["Resolve"] some kinds of conflict automatically, and requires user assistance through a ["MergeProgram"]. A conflict occurs when two independent ["ChangeSet"]s modify overlapping sections of a file in different ways. During a ["Merge"], ["Mercurial"] may require the assistance of the user through a
["MergeProgram"] which can be used to ["Resolve"] those conflicts.

If the ["MergeProgram"] is not a graphical tool,
a common fallback behavior is to use `diff3` for highlighting
the ["Conflict"] in the file using ''conflict markers''.
A text editor can be used to ["Resolve"] the conflicts manually.

----

For example:

Given the base file:
{{{
$ cat base
A
B
C
}}}

assuming `local` is your modified copy of `base`:
{{{
$ cat local
A
B - my local changes
C
}}}

and assuming `other` is another modified copy of `base`:
{{{
$ cat other
A
B - changes made by others
C
}}}

then there's obviously a conflicting change on the `B` line.
The "merged" content, as produced by the GNU `diff3` program,
will look like this:
{{{
$ diff3 -m local base other
A
<<<<<<< local
B - my local changes
||||||| base
B
=======
B - changes made by others
>>>>>>> other
C
}}}

[http://floopityjoop.com/cat.html cat]

[http://floopityjoop.com/cat.html cat]

Conflict

A conflict occurs when two independent ["ChangeSet"]s modify overlapping sections of a file in different ways. During a ["Merge"], ["Mercurial"] may require the assistance of the user through a ["MergeProgram"] which can be used to ["Resolve"] those conflicts.

If the ["MergeProgram"] is not a graphical tool, a common fallback behavior is to use diff3 for highlighting the ["Conflict"] in the file using conflict markers. A text editor can be used to ["Resolve"] the conflicts manually.


For example:

Given the base file:

$ cat base
A
B
C

assuming local is your modified copy of base:

$ cat local
A
B - my local changes
C

and assuming other is another modified copy of base:

$ cat other
A
B - changes made by others
C

then there's obviously a conflicting change on the B line. The "merged" content, as produced by the GNU diff3 program, will look like this:

$ diff3 -m local base other
A
<<<<<<< local
B - my local changes
||||||| base
B
=======
B - changes made by others
>>>>>>> other
C

[http://floopityjoop.com/cat.html cat]

[http://floopityjoop.com/cat.html cat]

Conflict (last edited 2012-11-11 18:40:24 by abuehl)