Git fork
at reftables-rust 412 lines 15 kB view raw
1git-merge(1) 2============ 3 4NAME 5---- 6git-merge - Join two or more development histories together 7 8 9SYNOPSIS 10-------- 11[synopsis] 12git merge [-n] [--stat] [--compact-summary] [--no-commit] [--squash] [--[no-]edit] 13 [--no-verify] [-s <strategy>] [-X <strategy-option>] [-S[<keyid>]] 14 [--[no-]allow-unrelated-histories] 15 [--[no-]rerere-autoupdate] [-m <msg>] [-F <file>] 16 [--into-name <branch>] [<commit>...] 17git merge (--continue | --abort | --quit) 18 19DESCRIPTION 20----------- 21Incorporates changes from the named commits (since the time their 22histories diverged from the current branch) into the current 23branch. This command is used by `git pull` to incorporate changes 24from another repository and can be used by hand to merge changes 25from one branch into another. 26 27Assume the following history exists and the current branch is 28`master`: 29 30------------ 31 A---B---C topic 32 / 33 D---E---F---G master 34------------ 35 36Then `git merge topic` will replay the changes made on the 37`topic` branch since it diverged from `master` (i.e., `E`) until 38its current commit (`C`) on top of `master`, and record the result 39in a new commit along with the names of the two parent commits and 40a log message from the user describing the changes. Before the operation, 41`ORIG_HEAD` is set to the tip of the current branch (`G`). 42 43------------ 44 A---B---C topic 45 / \ 46 D---E---F---G---H master 47------------ 48 49A merge stops if there's a conflict that cannot be resolved 50automatically or if `--no-commit` was provided when initiating the 51merge. At that point you can run `git merge --abort` or `git merge 52--continue`. 53 54`git merge --abort` will abort the merge process and try to reconstruct 55the pre-merge state. However, if there were uncommitted changes when the 56merge started (and especially if those changes were further modified 57after the merge was started), `git merge --abort` will in some cases be 58unable to reconstruct the original (pre-merge) changes. Therefore: 59 60WARNING: Running `git merge` with non-trivial uncommitted changes is 61discouraged: while possible, it may leave you in a state that is hard to 62back out of in the case of a conflict. 63 64OPTIONS 65------- 66:git-merge: 1 67 68include::merge-options.adoc[] 69 70`-m <msg>`:: 71 Set the commit message to be used for the merge commit (in 72 case one is created). 73+ 74If `--log` is specified, a shortlog of the commits being merged 75will be appended to the specified message. 76+ 77The `git fmt-merge-msg` command can be 78used to give a good default for automated `git merge` 79invocations. The automated message can include the branch description. 80 81`--into-name <branch>`:: 82 Prepare the default merge message as if merging to the branch 83 _<branch>_, instead of the name of the real branch to which 84 the merge is made. 85 86`-F <file>`:: 87`--file=<file>`:: 88 Read the commit message to be used for the merge commit (in 89 case one is created). 90+ 91If `--log` is specified, a shortlog of the commits being merged 92will be appended to the specified message. 93 94include::rerere-options.adoc[] 95 96`--overwrite-ignore`:: 97`--no-overwrite-ignore`:: 98 Silently overwrite ignored files from the merge result. This 99 is the default behavior. Use `--no-overwrite-ignore` to abort. 100 101`--abort`:: 102 Abort the current conflict resolution process, and 103 try to reconstruct the pre-merge state. If an autostash entry is 104 present, apply it to the worktree. 105+ 106If there were uncommitted worktree changes present when the merge 107started, `git merge --abort` will in some cases be unable to 108reconstruct these changes. It is therefore recommended to always 109commit or stash your changes before running `git merge`. 110+ 111`git merge --abort` is equivalent to `git reset --merge` when 112`MERGE_HEAD` is present unless `MERGE_AUTOSTASH` is also present in 113which case `git merge --abort` applies the stash entry to the worktree 114whereas `git reset --merge` will save the stashed changes in the stash 115list. 116 117`--quit`:: 118 Forget about the current merge in progress. Leave the index 119 and the working tree as-is. If `MERGE_AUTOSTASH` is present, the 120 stash entry will be saved to the stash list. 121 122`--continue`:: 123 After a `git merge` stops due to conflicts you can conclude the 124 merge by running `git merge --continue` (see "HOW TO RESOLVE 125 CONFLICTS" section below). 126 127`<commit>...`:: 128 Commits, usually other branch heads, to merge into our branch. 129 Specifying more than one commit will create a merge with 130 more than two parents (affectionately called an Octopus merge). 131+ 132If no commit is given from the command line, merge the remote-tracking 133branches that the current branch is configured to use as its upstream. 134See also the configuration section of this manual page. 135+ 136When `FETCH_HEAD` (and no other commit) is specified, the branches 137recorded in the `.git/FETCH_HEAD` file by the previous invocation 138of `git fetch` for merging are merged to the current branch. 139 140 141PRE-MERGE CHECKS 142---------------- 143 144Before applying outside changes, you should get your own work in 145good shape and committed locally, so it will not be clobbered if 146there are conflicts. See also linkgit:git-stash[1]. 147`git pull` and `git merge` will stop without doing anything when 148local uncommitted changes overlap with files that `git pull`/`git 149merge` may need to update. 150 151To avoid recording unrelated changes in the merge commit, 152`git pull` and `git merge` will also abort if there are any changes 153registered in the index relative to the `HEAD` commit. (Special 154narrow exceptions to this rule may exist depending on which merge 155strategy is in use, but generally, the index must match `HEAD`.) 156 157If all named commits are already ancestors of `HEAD`, `git merge` 158will exit early with the message "Already up to date." 159 160FAST-FORWARD MERGE 161------------------ 162 163Often the current branch head is an ancestor of the named commit. 164This is the most common case especially when invoked from `git 165pull`: you are tracking an upstream repository, you have committed 166no local changes, and now you want to update to a newer upstream 167revision. In this case, a new commit is not needed to store the 168combined history; instead, the `HEAD` (along with the index) is 169updated to point at the named commit, without creating an extra 170merge commit. 171 172This behavior can be suppressed with the `--no-ff` option. 173 174TRUE MERGE 175---------- 176 177Except in a fast-forward merge (see above), the branches to be 178merged must be tied together by a merge commit that has both of them 179as its parents. 180 181A merged version reconciling the changes from all branches to be 182merged is committed, and your `HEAD`, index, and working tree are 183updated to it. It is possible to have modifications in the working 184tree as long as they do not overlap; the update will preserve them. 185 186When it is not obvious how to reconcile the changes, the following 187happens: 188 1891. The `HEAD` pointer stays the same. 1902. The `MERGE_HEAD` ref is set to point to the other branch head. 1913. Paths that merged cleanly are updated both in the index file and 192 in your working tree. 1934. For conflicting paths, the index file records up to three 194 versions: stage 1 stores the version from the common ancestor, 195 stage 2 from `HEAD`, and stage 3 from `MERGE_HEAD` (you 196 can inspect the stages with `git ls-files -u`). The working 197 tree files contain the result of the merge operation; i.e. 3-way 198 merge results with familiar conflict markers +<<<+ `===` +>>>+. 1995. A ref named `AUTO_MERGE` is written, pointing to a tree 200 corresponding to the current content of the working tree (including 201 conflict markers for textual conflicts). Note that this ref is only 202 written when the `ort` merge strategy is used (the default). 2036. No other changes are made. In particular, the local 204 modifications you had before you started merge will stay the 205 same and the index entries for them stay as they were, 206 i.e. matching `HEAD`. 207 208If you tried a merge which resulted in complex conflicts and 209want to start over, you can recover with `git merge --abort`. 210 211MERGING TAG 212----------- 213 214When merging an annotated (and possibly signed) tag, Git always 215creates a merge commit even if a fast-forward merge is possible, and 216the commit message template is prepared with the tag message. 217Additionally, if the tag is signed, the signature check is reported 218as a comment in the message template. See also linkgit:git-tag[1]. 219 220When you want to just integrate with the work leading to the commit 221that happens to be tagged, e.g. synchronizing with an upstream 222release point, you may not want to make an unnecessary merge commit. 223 224In such a case, you can "unwrap" the tag yourself before feeding it 225to `git merge`, or pass `--ff-only` when you do not have any work on 226your own. e.g. 227 228---- 229git fetch origin 230git merge v1.2.3^0 231git merge --ff-only v1.2.3 232---- 233 234HOW CONFLICTS ARE PRESENTED 235--------------------------- 236 237During a merge, the working tree files are updated to reflect the result 238of the merge. Among the changes made to the common ancestor's version, 239non-overlapping ones (that is, you changed an area of the file while the 240other side left that area intact, or vice versa) are incorporated in the 241final result verbatim. When both sides made changes to the same area, 242however, Git cannot randomly pick one side over the other, and asks you to 243resolve it by leaving what both sides did to that area. 244 245By default, Git uses the same style as the one used by the "merge" program 246from the RCS suite to present such a conflicted hunk, like this: 247 248------------ 249Here are lines that are either unchanged from the common 250ancestor, or cleanly resolved because only one side changed, 251or cleanly resolved because both sides changed the same way. 252<<<<<<< yours:sample.txt 253Conflict resolution is hard; 254let's go shopping. 255======= 256Git makes conflict resolution easy. 257>>>>>>> theirs:sample.txt 258And here is another line that is cleanly resolved or unmodified. 259------------ 260 261The area where a pair of conflicting changes happened is marked with markers 262+<<<<<<<+, `=======`, and +>>>>>>>+. The part before the `=======` 263is typically your side, and the part afterwards is typically their side. 264 265The default format does not show what the original said in the conflicting 266area. You cannot tell how many lines are deleted and replaced with 267Barbie's remark on your side. The only thing you can tell is that your 268side wants to say it is hard and you'd prefer to go shopping, while the 269other side wants to claim it is easy. 270 271An alternative style can be used by setting the `merge.conflictStyle` 272configuration variable to either `diff3` or `zdiff3`. In `diff3` 273style, the above conflict may look like this: 274 275------------ 276Here are lines that are either unchanged from the common 277ancestor, or cleanly resolved because only one side changed, 278<<<<<<< yours:sample.txt 279or cleanly resolved because both sides changed the same way. 280Conflict resolution is hard; 281let's go shopping. 282||||||| base:sample.txt 283or cleanly resolved because both sides changed identically. 284Conflict resolution is hard. 285======= 286or cleanly resolved because both sides changed the same way. 287Git makes conflict resolution easy. 288>>>>>>> theirs:sample.txt 289And here is another line that is cleanly resolved or unmodified. 290------------ 291 292while in `zdiff3` style, it may look like this: 293 294------------ 295Here are lines that are either unchanged from the common 296ancestor, or cleanly resolved because only one side changed, 297or cleanly resolved because both sides changed the same way. 298<<<<<<< yours:sample.txt 299Conflict resolution is hard; 300let's go shopping. 301||||||| base:sample.txt 302or cleanly resolved because both sides changed identically. 303Conflict resolution is hard. 304======= 305Git makes conflict resolution easy. 306>>>>>>> theirs:sample.txt 307And here is another line that is cleanly resolved or unmodified. 308------------ 309 310In addition to the +<<<<<<<+, `=======`, and +>>>>>>>+ markers, it uses 311another +|||||||+ marker that is followed by the original text. You can 312tell that the original just stated a fact, and your side simply gave in to 313that statement and gave up, while the other side tried to have a more 314positive attitude. You can sometimes come up with a better resolution by 315viewing the original. 316 317 318HOW TO RESOLVE CONFLICTS 319------------------------ 320 321After seeing a conflict, you can do two things: 322 323 * Decide not to merge. The only clean-ups you need are to reset 324 the index file to the `HEAD` commit to reverse 2. and to clean 325 up working tree changes made by 2. and 3.; `git merge --abort` 326 can be used for this. 327 328 * Resolve the conflicts. Git will mark the conflicts in 329 the working tree. Edit the files into shape and 330 `git add` them to the index. Use `git commit` or 331 `git merge --continue` to seal the deal. The latter command 332 checks whether there is a (interrupted) merge in progress 333 before calling `git commit`. 334 335You can work through the conflict with a number of tools: 336 337 * Use a mergetool. `git mergetool` to launch a graphical 338 mergetool which will work through the merge with you. 339 340 * Look at the diffs. `git diff` will show a three-way diff, 341 highlighting changes from both the `HEAD` and `MERGE_HEAD` 342 versions. `git diff AUTO_MERGE` will show what changes you've 343 made so far to resolve textual conflicts. 344 345 * Look at the diffs from each branch. `git log --merge -p <path>` 346 will show diffs first for the `HEAD` version and then the 347 `MERGE_HEAD` version. 348 349 * Look at the originals. `git show :1:filename` shows the 350 common ancestor, `git show :2:filename` shows the `HEAD` 351 version, and `git show :3:filename` shows the `MERGE_HEAD` 352 version. 353 354 355EXAMPLES 356-------- 357 358* Merge branches `fixes` and `enhancements` on top of 359 the current branch, making an octopus merge: 360+ 361------------------------------------------------ 362$ git merge fixes enhancements 363------------------------------------------------ 364 365* Merge branch `obsolete` into the current branch, using `ours` 366 merge strategy: 367+ 368------------------------------------------------ 369$ git merge -s ours obsolete 370------------------------------------------------ 371 372* Merge branch `maint` into the current branch, but do not make 373 a new commit automatically: 374+ 375------------------------------------------------ 376$ git merge --no-commit maint 377------------------------------------------------ 378+ 379This can be used when you want to include further changes to the 380merge, or want to write your own merge commit message. 381+ 382You should refrain from abusing this option to sneak substantial 383changes into a merge commit. Small fixups like bumping 384release/version name would be acceptable. 385 386 387include::merge-strategies.adoc[] 388 389CONFIGURATION 390------------- 391 392`branch.<name>.mergeOptions`:: 393 Sets default options for merging into branch _<name>_. The syntax and 394 supported options are the same as those of `git merge`, but option 395 values containing whitespace characters are currently not supported. 396 397include::includes/cmd-config-section-rest.adoc[] 398 399include::config/merge.adoc[] 400 401SEE ALSO 402-------- 403linkgit:git-fmt-merge-msg[1], linkgit:git-pull[1], 404linkgit:gitattributes[5], 405linkgit:git-reset[1], 406linkgit:git-diff[1], linkgit:git-ls-files[1], 407linkgit:git-add[1], linkgit:git-rm[1], 408linkgit:git-mergetool[1] 409 410GIT 411--- 412Part of the linkgit:git[1] suite