2005-09-09 12:15:47 +04:00
|
|
|
git-merge(1)
|
|
|
|
============
|
|
|
|
|
|
|
|
NAME
|
|
|
|
----
|
2007-01-19 02:53:37 +03:00
|
|
|
git-merge - Join two or more development histories together
|
2005-09-09 12:15:47 +04:00
|
|
|
|
|
|
|
|
|
|
|
SYNOPSIS
|
|
|
|
--------
|
2006-11-20 12:06:09 +03:00
|
|
|
[verse]
|
2008-06-30 10:09:04 +04:00
|
|
|
'git merge' [-n] [--stat] [--no-commit] [--squash] [-s <strategy>]...
|
2010-01-07 19:32:19 +03:00
|
|
|
[-m <msg>] <commit>...
|
|
|
|
'git merge' <msg> HEAD <commit>...
|
2005-09-09 12:15:47 +04:00
|
|
|
|
|
|
|
DESCRIPTION
|
|
|
|
-----------
|
2010-01-23 12:42:46 +03:00
|
|
|
Incorporates changes from the named commits (since the time their
|
|
|
|
histories diverged from the current branch) into the current
|
|
|
|
branch. This command is used by 'git pull' to incorporate changes
|
|
|
|
from another repository and can be used by hand to merge changes
|
|
|
|
from one branch into another.
|
|
|
|
|
|
|
|
Assume the following history exists and the current branch is
|
|
|
|
"`master`":
|
|
|
|
|
|
|
|
------------
|
|
|
|
A---B---C topic
|
|
|
|
/
|
|
|
|
D---E---F---G master
|
|
|
|
------------
|
|
|
|
|
|
|
|
Then "`git merge topic`" will replay the changes made on the
|
|
|
|
`topic` branch since it diverged from `master` (i.e., `E`) until
|
|
|
|
its current commit (`C`) on top of `master`, and record the result
|
|
|
|
in a new commit along with the names of the two parent commits and
|
|
|
|
a log message from the user describing the changes.
|
|
|
|
|
|
|
|
------------
|
|
|
|
A---B---C topic
|
|
|
|
/ \
|
|
|
|
D---E---F---G---H master
|
|
|
|
------------
|
2005-09-09 12:15:47 +04:00
|
|
|
|
2010-01-07 19:32:19 +03:00
|
|
|
The second syntax (<msg> `HEAD` <commit>...) is supported for
|
2007-10-30 21:54:11 +03:00
|
|
|
historical reasons. Do not use it from the command line or in
|
2010-01-07 19:32:19 +03:00
|
|
|
new scripts. It is the same as `git merge -m <msg> <commit>...`.
|
2007-10-30 21:54:11 +03:00
|
|
|
|
2010-01-10 02:33:00 +03:00
|
|
|
*Warning*: Running 'git merge' with uncommitted changes is
|
2010-01-07 19:42:27 +03:00
|
|
|
discouraged: while possible, it leaves you in a state that is hard to
|
|
|
|
back out of in the case of a conflict.
|
|
|
|
|
2005-09-09 12:15:47 +04:00
|
|
|
|
|
|
|
OPTIONS
|
|
|
|
-------
|
2005-11-07 08:30:56 +03:00
|
|
|
include::merge-options.txt[]
|
2005-09-09 12:15:47 +04:00
|
|
|
|
2007-10-30 21:54:11 +03:00
|
|
|
-m <msg>::
|
2009-10-09 14:16:15 +04:00
|
|
|
Set the commit message to be used for the merge commit (in
|
|
|
|
case one is created). The 'git fmt-merge-msg' command can be
|
|
|
|
used to give a good default for automated 'git merge'
|
|
|
|
invocations.
|
2005-11-01 23:45:55 +03:00
|
|
|
|
2010-01-07 19:32:19 +03:00
|
|
|
<commit>...::
|
|
|
|
Commits, usually other branch heads, to merge into our branch.
|
|
|
|
You need at least one <commit>. Specifying more than one
|
|
|
|
<commit> obviously means you are trying an Octopus.
|
2005-09-09 12:15:47 +04:00
|
|
|
|
|
|
|
|
2010-01-23 12:44:17 +03:00
|
|
|
PRE-MERGE CHECKS
|
|
|
|
----------------
|
|
|
|
|
|
|
|
Before applying outside changes, you should get your own work in
|
|
|
|
good shape and committed locally, so it will not be clobbered if
|
|
|
|
there are conflicts. See also linkgit:git-stash[1].
|
|
|
|
'git pull' and 'git merge' will stop without doing anything when
|
|
|
|
local uncommitted changes overlap with files that 'git pull'/'git
|
|
|
|
merge' may need to update.
|
|
|
|
|
|
|
|
To avoid recording unrelated changes in the merge commit,
|
|
|
|
'git pull' and 'git merge' will also abort if there are any changes
|
|
|
|
registered in the index relative to the `HEAD` commit. (One
|
|
|
|
exception is when the changed index entries are in the state that
|
|
|
|
would result from the merge already.)
|
|
|
|
|
|
|
|
If all named commits are already ancestors of `HEAD`, 'git merge'
|
|
|
|
will exit early with the message "Already up-to-date."
|
|
|
|
|
2010-01-23 12:45:33 +03:00
|
|
|
FAST-FORWARD MERGE
|
|
|
|
------------------
|
|
|
|
|
|
|
|
Often the current branch head is an ancestor of the named commit.
|
|
|
|
This is the most common case especially when invoked from 'git
|
|
|
|
pull': you are tracking an upstream repository, you have committed
|
|
|
|
no local changes, and now you want to update to a newer upstream
|
|
|
|
revision. In this case, a new commit is not needed to store the
|
|
|
|
combined history; instead, the `HEAD` (along with the index) is
|
|
|
|
updated to point at the named commit, without creating an extra
|
|
|
|
merge commit.
|
|
|
|
|
|
|
|
This behavior can be suppressed with the `--no-ff` option.
|
|
|
|
|
2005-11-29 09:54:30 +03:00
|
|
|
HOW MERGE WORKS
|
|
|
|
---------------
|
|
|
|
|
|
|
|
A merge is always between the current `HEAD` and one or more
|
2010-01-23 12:44:17 +03:00
|
|
|
commits (usually a branch head or tag).
|
2008-07-19 22:17:22 +04:00
|
|
|
|
2010-01-23 12:45:33 +03:00
|
|
|
Except in a fast-forward merge (see above), the branches to be
|
|
|
|
merged must be tied together by a merge commit that has both of them
|
|
|
|
as its parents.
|
|
|
|
The rest of this section describes this "True merge" case.
|
2008-07-19 22:17:22 +04:00
|
|
|
|
|
|
|
The chosen merge strategy merges the two commits into a single
|
|
|
|
new source tree.
|
2008-12-09 09:23:51 +03:00
|
|
|
When things merge cleanly, this is what happens:
|
2005-11-29 09:54:30 +03:00
|
|
|
|
2007-08-01 19:43:06 +04:00
|
|
|
1. The results are updated both in the index file and in your
|
|
|
|
working tree;
|
|
|
|
2. Index file is written out as a tree;
|
|
|
|
3. The tree gets committed; and
|
|
|
|
4. The `HEAD` pointer gets advanced.
|
2005-11-29 09:54:30 +03:00
|
|
|
|
|
|
|
Because of 2., we require that the original state of the index
|
2008-12-09 09:23:51 +03:00
|
|
|
file matches exactly the current `HEAD` commit; otherwise we
|
2005-11-29 09:54:30 +03:00
|
|
|
will write out your local changes already registered in your
|
|
|
|
index file along with the merge result, which is not good.
|
2008-12-09 09:23:51 +03:00
|
|
|
Because 1. involves only those paths differing between your
|
2010-01-07 19:32:19 +03:00
|
|
|
branch and the branch you are merging
|
|
|
|
(which is typically a fraction of the whole tree), you can
|
2005-11-29 09:54:30 +03:00
|
|
|
have local modifications in your working tree as long as they do
|
|
|
|
not overlap with what the merge updates.
|
|
|
|
|
2008-12-09 09:23:51 +03:00
|
|
|
When there are conflicts, the following happens:
|
2005-11-29 09:54:30 +03:00
|
|
|
|
|
|
|
1. `HEAD` stays the same.
|
|
|
|
|
|
|
|
2. Cleanly merged paths are updated both in the index file and
|
|
|
|
in your working tree.
|
|
|
|
|
2005-12-02 12:05:35 +03:00
|
|
|
3. For conflicting paths, the index file records up to three
|
|
|
|
versions; stage1 stores the version from the common ancestor,
|
2010-01-07 19:32:19 +03:00
|
|
|
stage2 from `HEAD`, and stage3 from the other branch (you
|
2008-06-30 10:09:04 +04:00
|
|
|
can inspect the stages with `git ls-files -u`). The working
|
2008-12-09 09:23:51 +03:00
|
|
|
tree files contain the result of the "merge" program; i.e. 3-way
|
|
|
|
merge results with familiar conflict markers `<<< === >>>`.
|
2005-11-29 09:54:30 +03:00
|
|
|
|
|
|
|
4. No other changes are done. In particular, the local
|
|
|
|
modifications you had before you started merge will stay the
|
|
|
|
same and the index entries for them stay as they were,
|
|
|
|
i.e. matching `HEAD`.
|
|
|
|
|
2010-01-23 12:31:19 +03:00
|
|
|
If you tried a merge which resulted in complex conflicts and
|
|
|
|
want to start over, you can recover with `git reset --merge`.
|
|
|
|
|
2008-09-01 07:36:32 +04:00
|
|
|
HOW CONFLICTS ARE PRESENTED
|
|
|
|
---------------------------
|
|
|
|
|
|
|
|
During a merge, the working tree files are updated to reflect the result
|
|
|
|
of the merge. Among the changes made to the common ancestor's version,
|
|
|
|
non-overlapping ones (that is, you changed an area of the file while the
|
|
|
|
other side left that area intact, or vice versa) are incorporated in the
|
|
|
|
final result verbatim. When both sides made changes to the same area,
|
|
|
|
however, git cannot randomly pick one side over the other, and asks you to
|
|
|
|
resolve it by leaving what both sides did to that area.
|
|
|
|
|
|
|
|
By default, git uses the same style as that is used by "merge" program
|
|
|
|
from the RCS suite to present such a conflicted hunk, like this:
|
|
|
|
|
|
|
|
------------
|
|
|
|
Here are lines that are either unchanged from the common
|
|
|
|
ancestor, or cleanly resolved because only one side changed.
|
|
|
|
<<<<<<< yours:sample.txt
|
|
|
|
Conflict resolution is hard;
|
|
|
|
let's go shopping.
|
|
|
|
=======
|
|
|
|
Git makes conflict resolution easy.
|
|
|
|
>>>>>>> theirs:sample.txt
|
|
|
|
And here is another line that is cleanly resolved or unmodified.
|
|
|
|
------------
|
|
|
|
|
2008-12-09 09:23:51 +03:00
|
|
|
The area where a pair of conflicting changes happened is marked with markers
|
2009-03-15 14:30:52 +03:00
|
|
|
`<<<<<<<`, `=======`, and `>>>>>>>`. The part before the `=======`
|
2008-12-09 09:23:51 +03:00
|
|
|
is typically your side, and the part afterwards is typically their side.
|
2008-09-01 07:36:32 +04:00
|
|
|
|
2008-12-09 09:23:51 +03:00
|
|
|
The default format does not show what the original said in the conflicting
|
|
|
|
area. You cannot tell how many lines are deleted and replaced with
|
|
|
|
Barbie's remark on your side. The only thing you can tell is that your
|
2008-09-01 07:36:32 +04:00
|
|
|
side wants to say it is hard and you'd prefer to go shopping, while the
|
|
|
|
other side wants to claim it is easy.
|
|
|
|
|
|
|
|
An alternative style can be used by setting the "merge.conflictstyle"
|
|
|
|
configuration variable to "diff3". In "diff3" style, the above conflict
|
|
|
|
may look like this:
|
|
|
|
|
|
|
|
------------
|
|
|
|
Here are lines that are either unchanged from the common
|
|
|
|
ancestor, or cleanly resolved because only one side changed.
|
|
|
|
<<<<<<< yours:sample.txt
|
|
|
|
Conflict resolution is hard;
|
|
|
|
let's go shopping.
|
|
|
|
|||||||
|
|
|
|
Conflict resolution is hard.
|
|
|
|
=======
|
|
|
|
Git makes conflict resolution easy.
|
|
|
|
>>>>>>> theirs:sample.txt
|
|
|
|
And here is another line that is cleanly resolved or unmodified.
|
|
|
|
------------
|
|
|
|
|
2009-03-15 14:30:52 +03:00
|
|
|
In addition to the `<<<<<<<`, `=======`, and `>>>>>>>` markers, it uses
|
|
|
|
another `|||||||` marker that is followed by the original text. You can
|
2008-09-01 07:36:32 +04:00
|
|
|
tell that the original just stated a fact, and your side simply gave in to
|
|
|
|
that statement and gave up, while the other side tried to have a more
|
|
|
|
positive attitude. You can sometimes come up with a better resolution by
|
|
|
|
viewing the original.
|
|
|
|
|
|
|
|
|
|
|
|
HOW TO RESOLVE CONFLICTS
|
|
|
|
------------------------
|
|
|
|
|
2005-11-29 09:54:30 +03:00
|
|
|
After seeing a conflict, you can do two things:
|
|
|
|
|
2008-12-09 09:23:51 +03:00
|
|
|
* Decide not to merge. The only clean-ups you need are to reset
|
2005-11-29 09:54:30 +03:00
|
|
|
the index file to the `HEAD` commit to reverse 2. and to clean
|
2010-01-07 19:49:12 +03:00
|
|
|
up working tree changes made by 2. and 3.; `git-reset --hard` can
|
2005-11-29 09:54:30 +03:00
|
|
|
be used for this.
|
|
|
|
|
2008-08-22 07:32:00 +04:00
|
|
|
* Resolve the conflicts. Git will mark the conflicts in
|
|
|
|
the working tree. Edit the files into shape and
|
2010-01-10 02:33:00 +03:00
|
|
|
'git add' them to the index. Use 'git commit' to seal the deal.
|
2005-11-29 09:54:30 +03:00
|
|
|
|
2008-08-22 07:32:00 +04:00
|
|
|
You can work through the conflict with a number of tools:
|
|
|
|
|
2010-01-07 19:49:12 +03:00
|
|
|
* Use a mergetool. `git mergetool` to launch a graphical
|
2008-08-22 07:32:00 +04:00
|
|
|
mergetool which will work you through the merge.
|
|
|
|
|
2010-01-07 19:49:12 +03:00
|
|
|
* Look at the diffs. `git diff` will show a three-way diff,
|
2010-01-07 19:32:19 +03:00
|
|
|
highlighting changes from both the HEAD and their versions.
|
2008-08-22 07:32:00 +04:00
|
|
|
|
2010-01-07 19:49:12 +03:00
|
|
|
* Look at the diffs on their own. `git log --merge -p <path>`
|
2010-01-07 19:32:19 +03:00
|
|
|
will show diffs first for the HEAD version and then
|
|
|
|
their version.
|
2008-08-22 07:32:00 +04:00
|
|
|
|
2010-01-07 19:49:12 +03:00
|
|
|
* Look at the originals. `git show :1:filename` shows the
|
|
|
|
common ancestor, `git show :2:filename` shows the HEAD
|
|
|
|
version and `git show :3:filename` shows their version.
|
2005-11-29 09:54:30 +03:00
|
|
|
|
2009-10-21 21:21:23 +04:00
|
|
|
|
|
|
|
EXAMPLES
|
|
|
|
--------
|
|
|
|
|
|
|
|
* Merge branches `fixes` and `enhancements` on top of
|
|
|
|
the current branch, making an octopus merge:
|
|
|
|
+
|
|
|
|
------------------------------------------------
|
|
|
|
$ git merge fixes enhancements
|
|
|
|
------------------------------------------------
|
|
|
|
|
|
|
|
* Merge branch `obsolete` into the current branch, using `ours`
|
|
|
|
merge strategy:
|
|
|
|
+
|
|
|
|
------------------------------------------------
|
|
|
|
$ git merge -s ours obsolete
|
|
|
|
------------------------------------------------
|
|
|
|
|
|
|
|
* Merge branch `maint` into the current branch, but do not make
|
|
|
|
a new commit automatically:
|
|
|
|
+
|
|
|
|
------------------------------------------------
|
|
|
|
$ git merge --no-commit maint
|
|
|
|
------------------------------------------------
|
|
|
|
+
|
|
|
|
This can be used when you want to include further changes to the
|
|
|
|
merge, or want to write your own merge commit message.
|
|
|
|
+
|
|
|
|
You should refrain from abusing this option to sneak substantial
|
|
|
|
changes into a merge commit. Small fixups like bumping
|
|
|
|
release/version name would be acceptable.
|
|
|
|
|
|
|
|
|
2010-01-23 12:33:37 +03:00
|
|
|
include::merge-strategies.txt[]
|
|
|
|
|
2010-01-23 12:26:57 +03:00
|
|
|
CONFIGURATION
|
|
|
|
-------------
|
|
|
|
include::merge-config.txt[]
|
|
|
|
|
|
|
|
branch.<name>.mergeoptions::
|
|
|
|
Sets default options for merging into branch <name>. The syntax and
|
|
|
|
supported options are the same as those of 'git merge', but option
|
|
|
|
values containing whitespace characters are currently not supported.
|
|
|
|
|
2005-11-01 23:45:55 +03:00
|
|
|
SEE ALSO
|
|
|
|
--------
|
2007-12-29 09:20:38 +03:00
|
|
|
linkgit:git-fmt-merge-msg[1], linkgit:git-pull[1],
|
2008-06-30 22:56:34 +04:00
|
|
|
linkgit:gitattributes[5],
|
|
|
|
linkgit:git-reset[1],
|
|
|
|
linkgit:git-diff[1], linkgit:git-ls-files[1],
|
|
|
|
linkgit:git-add[1], linkgit:git-rm[1],
|
|
|
|
linkgit:git-mergetool[1]
|
2005-11-01 23:45:55 +03:00
|
|
|
|
2005-09-09 12:15:47 +04:00
|
|
|
Author
|
|
|
|
------
|
2008-07-21 23:14:42 +04:00
|
|
|
Written by Junio C Hamano <gitster@pobox.com>
|
2005-09-09 12:15:47 +04:00
|
|
|
|
|
|
|
|
|
|
|
Documentation
|
|
|
|
--------------
|
|
|
|
Documentation by Junio C Hamano and the git-list <git@vger.kernel.org>.
|
|
|
|
|
|
|
|
GIT
|
|
|
|
---
|
2008-06-06 11:07:32 +04:00
|
|
|
Part of the linkgit:git[1] suite
|