235 lines
		
	
	
		
			8.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
			
		
		
	
	
			235 lines
		
	
	
		
			8.1 KiB
		
	
	
	
		
			Plaintext
		
	
	
| git-merge(1)
 | |
| ============
 | |
| 
 | |
| NAME
 | |
| ----
 | |
| git-merge - Join two or more development histories together
 | |
| 
 | |
| 
 | |
| SYNOPSIS
 | |
| --------
 | |
| [verse]
 | |
| 'git merge' [-n] [--stat] [--no-commit] [--squash] [-s <strategy>]...
 | |
| 	[-m <msg>] <remote> <remote>...
 | |
| 'git merge' <msg> HEAD <remote>...
 | |
| 
 | |
| DESCRIPTION
 | |
| -----------
 | |
| This is the top-level interface to the merge machinery
 | |
| which drives multiple merge strategy scripts.
 | |
| 
 | |
| The second syntax (<msg> `HEAD` <remote>) is supported for
 | |
| historical reasons.  Do not use it from the command line or in
 | |
| new scripts.  It is the same as `git merge -m <msg> <remote>`.
 | |
| 
 | |
| 
 | |
| OPTIONS
 | |
| -------
 | |
| include::merge-options.txt[]
 | |
| 
 | |
| -m <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.
 | |
| 
 | |
| <remote>...::
 | |
| 	Other branch heads to merge 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[]
 | |
| 
 | |
| 
 | |
| If you tried a merge which resulted in complex conflicts and
 | |
| want to start over, you can recover with 'git-reset'.
 | |
| 
 | |
| CONFIGURATION
 | |
| -------------
 | |
| include::merge-config.txt[]
 | |
| 
 | |
| branch.<name>.mergeoptions::
 | |
| 	Sets default options for merging into branch <name>. The syntax and
 | |
| 	supported options are equal to that of 'git-merge', but option values
 | |
| 	containing whitespace characters are currently not supported.
 | |
| 
 | |
| HOW MERGE WORKS
 | |
| ---------------
 | |
| 
 | |
| A merge is always between the current `HEAD` and one or more
 | |
| commits (usually, branch head or tag), and the index file must
 | |
| match the tree of `HEAD` commit (i.e. the contents of the last commit)
 | |
| when it starts out.  In other words, `git diff --cached HEAD` must
 | |
| report no changes.  (One exception is when the changed index
 | |
| entries are already in the same state that would result from
 | |
| the merge anyway.)
 | |
| 
 | |
| Three kinds of merge can happen:
 | |
| 
 | |
| * The merged commit is already contained in `HEAD`. This is the
 | |
|   simplest case, called "Already up-to-date."
 | |
| 
 | |
| * `HEAD` is already contained in the merged commit. This is the
 | |
|   most common case especially when invoked from 'git pull':
 | |
|   you are tracking an upstream repository, have committed no local
 | |
|   changes and now you want to update to a newer upstream revision.
 | |
|   Your `HEAD` (and the index) is updated to point at the merged
 | |
|   commit, without creating an extra merge commit.  This is
 | |
|   called "Fast-forward".
 | |
| 
 | |
| * Both the merged commit and `HEAD` are independent and 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.
 | |
| 
 | |
| The chosen merge strategy merges the two commits into a single
 | |
| new source tree.
 | |
| When things merge cleanly, this is what happens:
 | |
| 
 | |
| 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 matches 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 those paths differing 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, the following happens:
 | |
| 
 | |
| 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 contain the result of the "merge" program; i.e. 3-way
 | |
|    merge results 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`.
 | |
| 
 | |
| 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.
 | |
| ------------
 | |
| 
 | |
| The area where a pair of conflicting changes happened is marked with markers
 | |
| `<<<<<<<`, `=======`, and `>>>>>>>`.  The part before the `=======`
 | |
| is typically your side, and the part afterwards is typically their side.
 | |
| 
 | |
| 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
 | |
| 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.
 | |
| ------------
 | |
| 
 | |
| In addition to the `<<<<<<<`, `=======`, and `>>>>>>>` markers, it uses
 | |
| another `|||||||` marker that is followed by the original text.  You can
 | |
| 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
 | |
| ------------------------
 | |
| 
 | |
| After seeing a conflict, you can do two things:
 | |
| 
 | |
|  * Decide not to merge.  The only clean-ups 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 --hard' can
 | |
|    be used for this.
 | |
| 
 | |
|  * Resolve the conflicts.  Git will mark the conflicts in
 | |
|    the working tree.  Edit the files into shape and
 | |
|    'git-add' them to the index.  Use 'git-commit' to seal the deal.
 | |
| 
 | |
| You can work through the conflict with a number of tools:
 | |
| 
 | |
|  * Use a mergetool.  'git mergetool' to launch a graphical
 | |
|    mergetool which will work you through the merge.
 | |
| 
 | |
|  * Look at the diffs.  'git diff' will show a three-way diff,
 | |
|    highlighting changes from both the HEAD and remote versions.
 | |
| 
 | |
|  * Look at the diffs on their own. 'git log --merge -p <path>'
 | |
|    will show diffs first for the HEAD version and then the
 | |
|    remote version.
 | |
| 
 | |
|  * 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 the remote version.
 | |
| 
 | |
| SEE ALSO
 | |
| --------
 | |
| linkgit:git-fmt-merge-msg[1], linkgit:git-pull[1],
 | |
| 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]
 | |
| 
 | |
| Author
 | |
| ------
 | |
| Written by Junio C Hamano <gitster@pobox.com>
 | |
| 
 | |
| 
 | |
| Documentation
 | |
| --------------
 | |
| Documentation by Junio C Hamano and the git-list <git@vger.kernel.org>.
 | |
| 
 | |
| GIT
 | |
| ---
 | |
| Part of the linkgit:git[1] suite
 |