You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
153 lines
5.2 KiB
153 lines
5.2 KiB
git-merge(1) |
|
============ |
|
|
|
NAME |
|
---- |
|
git-merge - Grand Unified Merge Driver |
|
|
|
|
|
SYNOPSIS |
|
-------- |
|
'git-merge' [-n] [--no-commit] [-s <strategy>]... <msg> <head> <remote> <remote>... |
|
|
|
|
|
DESCRIPTION |
|
----------- |
|
This is the top-level user interface to the merge machinery |
|
which drives multiple merge strategy scripts. |
|
|
|
|
|
OPTIONS |
|
------- |
|
include::merge-options.txt[] |
|
|
|
<msg>:: |
|
The commit message to be used for the merge commit (in case |
|
it is created). The `git-fmt-merge-msg` script can be used |
|
to give a good default for automated `git-merge` invocations. |
|
|
|
<head>:: |
|
our branch head commit. |
|
|
|
<remote>:: |
|
other branch head merged into our branch. You need at |
|
least one <remote>. Specifying more than one <remote> |
|
obviously means you are trying an Octopus. |
|
|
|
include::merge-strategies.txt[] |
|
|
|
|
|
HOW MERGE WORKS |
|
--------------- |
|
|
|
A merge is always between the current `HEAD` and one or more |
|
remote branch heads, and the index file must exactly match the |
|
tree of `HEAD` commit (i.e. the contents of the last commit) when |
|
it happens. In other words, `git-diff --cached HEAD` must |
|
report no changes. |
|
|
|
[NOTE] |
|
This is a bit of lie. In certain special cases, your index are |
|
allowed to be different from the tree of `HEAD` commit. The most |
|
notable case is when your `HEAD` commit is already ahead of what |
|
is being merged, in which case your index can have arbitrary |
|
difference from your `HEAD` commit. Otherwise, your index entries |
|
are allowed have differences from your `HEAD` commit that match |
|
the result of trivial merge (e.g. you received the same patch |
|
from external source to produce the same result as what you are |
|
merging). For example, if a path did not exist in the common |
|
ancestor and your head commit but exists in the tree you are |
|
merging into your repository, and if you already happen to have |
|
that path exactly in your index, the merge does not have to |
|
fail. |
|
|
|
Otherwise, merge will refuse to do any harm to your repository |
|
(that is, it may fetch the objects from remote, and it may even |
|
update the local branch used to keep track of the remote branch |
|
with `git pull remote rbranch:lbranch`, but your working tree, |
|
`.git/HEAD` pointer and index file are left intact). |
|
|
|
You may have local modifications in the working tree files. In |
|
other words, `git-diff` is allowed to report changes. |
|
However, the merge uses your working tree as the working area, |
|
and in order to prevent the merge operation from losing such |
|
changes, it makes sure that they do not interfere with the |
|
merge. Those complex tables in read-tree documentation define |
|
what it means for a path to "interfere with the merge". And if |
|
your local modifications interfere with the merge, again, it |
|
stops before touching anything. |
|
|
|
So in the above two "failed merge" case, you do not have to |
|
worry about lossage of data --- you simply were not ready to do |
|
a merge, so no merge happened at all. You may want to finish |
|
whatever you were in the middle of doing, and retry the same |
|
pull after you are done and ready. |
|
|
|
When things cleanly merge, these things happen: |
|
|
|
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. |
|
|
|
Because of 2., we require that the original state of the index |
|
file to match exactly the current `HEAD` commit; otherwise we |
|
will write out your local changes already registered in your |
|
index file along with the merge result, which is not good. |
|
Because 1. involves only the paths different between your |
|
branch and the remote branch you are pulling from during the |
|
merge (which is typically a fraction of the whole tree), you can |
|
have local modifications in your working tree as long as they do |
|
not overlap with what the merge updates. |
|
|
|
When there are conflicts, these things happen: |
|
|
|
1. `HEAD` stays the same. |
|
|
|
2. Cleanly merged paths are updated both in the index file and |
|
in your working tree. |
|
|
|
3. For conflicting paths, the index file records up to three |
|
versions; stage1 stores the version from the common ancestor, |
|
stage2 from `HEAD`, and stage3 from the remote branch (you |
|
can inspect the stages with `git-ls-files -u`). The working |
|
tree files have the result of "merge" program; i.e. 3-way |
|
merge result with familiar conflict markers `<<< === >>>`. |
|
|
|
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`. |
|
|
|
After seeing a conflict, you can do two things: |
|
|
|
* Decide not to merge. The only clean-up you need are to reset |
|
the index file to the `HEAD` commit to reverse 2. and to clean |
|
up working tree changes made by 2. and 3.; `git-reset` can |
|
be used for this. |
|
|
|
* Resolve the conflicts. `git-diff` would report only the |
|
conflicting paths because of the above 2. and 3.. Edit the |
|
working tree files into a desirable shape, `git-update-index` |
|
them, to make the index file contain what the merge result |
|
should be, and run `git-commit` to commit the result. |
|
|
|
|
|
SEE ALSO |
|
-------- |
|
gitlink:git-fmt-merge-msg[1], gitlink:git-pull[1] |
|
|
|
|
|
Author |
|
------ |
|
Written by Junio C Hamano <junkio@cox.net> |
|
|
|
|
|
Documentation |
|
-------------- |
|
Documentation by Junio C Hamano and the git-list <git@vger.kernel.org>. |
|
|
|
GIT |
|
--- |
|
Part of the gitlink:git[7] suite
|
|
|