uTools-Manuals/docs/git/git merge.html
2019-04-08 23:22:26 +08:00

11 lines
36 KiB
HTML
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<div class="c-markdown doc-markdown"><div class="doc-postil"><div class="c-markdown"><h2>名称</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>git-merge - Join two or more development histories together</p></div></div><div class="doc-postil"><div class="c-markdown"><h2>概要</h2></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">git merge [-n] [--stat] [--no-commit] [--squash] [--[no-]edit]        [-s &lt;strategy&gt;] [-X &lt;strategy-option&gt;] [-S[&lt;keyid&gt;]]        [--[no-]allow-unrelated-histories]        [--[no-]rerere-autoupdate] [-m &lt;msg&gt;] [&lt;commit&gt;…]git merge --abort
git merge --continue</pre></div></div><div class="doc-postil"><div class="c-markdown"><h2>描述</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>将已命名的提交(从历史记录与当前分支分离的时间以来)的更改合并到当前分支中。该命令用于<code>git pull</code>合并另一个存储库中的更改,并可用于手动合并从一个分支到另一个分支的更改。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>假设存在以下历史记录,并且当前分支是“ <code>master</code>”:</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">          A---B---C topic         /
    D---E---F---G master</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>然后“ <code>git merge topic</code>”将重播在<code>topic</code>分支上发生的变化,因为它从<code>master</code>(即<code>E</code>分支到其当前的commit<code>C</code>)之上<code>master</code>,并且将结果记录在新的提交中以及两个父提交的名称和日志消息来自描述更改的用户。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">          A---B---C topic         /         \
    D---E---F---G---H master</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>第二个语法(“ <code>git merge --abort</code>”)只能在合并导致冲突后才能运行。<code>git merge --abort</code>将中止合并过程并尝试重新构建合并前状态。但是,如果在合并开始时发生未提交的更改(尤其是在合并开始后进一步修改这些更改),<code>git merge --abort</code>则在某些情况下将无法重建原始(合并前)更改。因此:</p></div></div><div class="doc-postil"><div class="c-markdown"><p><strong>警告</strong><code>git merge</code>不鼓励使用不平凡的未提交更改:尽管可能,但可能会让您处于难以在冲突情况下退出的状态。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>第四种语法(“ <code>git merge --continue</code>”)只能在合并导致冲突后才能运行。</p></div></div><div class="doc-postil"><div class="c-markdown"><h2>选项</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>--commit   --no-commit</p></div></div><div class="doc-postil"><div class="c-markdown"><p>执行合并并提交结果。这个选项可以用来覆盖--no-commit。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>使用--no-commit执行合并但假装合并失败并且不自动提交以使用户有机会在提交之前检查并进一步调整合并结果。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--edit   -e   --no-edit</p></div></div><div class="doc-postil"><div class="c-markdown"><p>在提交成功的机械合并之前调用编辑器来进一步编辑自动生成的合并消息,以便用户可以解释并验证合并。该<code>--no-edit</code>选项可用于接受自动生成的消息(这通常是不鼓励的)。该<code>--edit</code>(或<code>-e</code>)选项仍然是有用的,如果你给同一个消息草稿<code>-m</code>命令行选项,并希望在编辑器中编辑。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>较旧的脚本可能取决于不允许用户编辑合并日志消息的历史行为。他们将在运行时看到编辑器打开<code>git merge</code>。为了更容易地将这些脚本调整为更新的行为,<code>GIT_MERGE_AUTOEDIT</code>可以将环境变量设置为<code>no</code>它们的开头。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--ff</p></div></div><div class="doc-postil"><div class="c-markdown"><p>当合并解析为快进时,只更新分支指针,而不创建合并提交。这是默认行为。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--no-ff</p></div></div><div class="doc-postil"><div class="c-markdown"><p>即使合并解析为快进,也可以创建合并提交。这是合并注释(可能有符号)标记时的默认行为。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--ff-only</p></div></div><div class="doc-postil"><div class="c-markdown"><p>拒绝合并并以非零状态退出,除非电流<code>HEAD</code>已经是最新的或合并可以解决为快进。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--log=&lt;n&gt;   --no-log</p></div></div><div class="doc-postil"><div class="c-markdown"><p>除了分支名称之外,还可以用来自至多&lt;n&gt;实际提交的单行描述来填充日志消息。另请参阅git-fmt-merge-msg [1]。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>使用--no-log不会列出要合并的实际提交的单行描述。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--stat   -n   --no-stat</p></div></div><div class="doc-postil"><div class="c-markdown"><p>在合并结束时显示diffstat。diffstat也由配置选项merge.stat控制。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>使用-n或--no-stat不会在合并结束时显示diffstat。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--squash   --no-squash</p></div></div><div class="doc-postil"><div class="c-markdown"><p>生成工作树和索引状态,就像发生真正的合并(合并信息除外)一样,但实际上并未进行提交,移动<code>HEAD</code>或记录<code>$GIT_DIR/MERGE_HEAD</code>(以导致下一个<code>git commit</code>命令创建合并提交)。这允许您在当前分支上创建一个单独的提交,其效果与合并另一个分支相同(或者在章鱼的情况下更多)。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>用--no-squash执行合并并提交结果。这个选项可以用来覆盖--squash。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>-s &lt;strategy&gt;   --strategy=&lt;strategy&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>使用给定的合并策略; 可以多次提供,以按照他们应该尝试的顺序指定它们。如果没有<code>-s</code>选项,则使用内置策略列表(否则<code>git merge-recursive</code>合并单个头部时<code>git merge-octopus</code>)。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>-X &lt;option&gt;   --strategy-option=&lt;option&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>将合并策略特定选项传递给合并策略。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--verify-signatures   --no-verify-signatures</p></div></div><div class="doc-postil"><div class="c-markdown"><p>验证被合并的分支的提示提交是否使用有效密钥签名即具有有效uid的密钥在默认信任模型中这意味着签名密钥已由可信密钥签名。如果侧分支的提示提交未使用有效密钥进行签名则会中止合并。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--summary   --no-summary</p></div></div><div class="doc-postil"><div class="c-markdown"><p>同义词--stat和--no-stat; 这些已被弃用,并将在未来被删除。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>-q   --quiet</p></div></div><div class="doc-postil"><div class="c-markdown"><p>安静地操作。意味着 --no-progress</p></div></div><div class="doc-postil"><div class="c-markdown"><p>-v   --verbose</p></div></div><div class="doc-postil"><div class="c-markdown"><p>详细。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--progress   --no-progress</p></div></div><div class="doc-postil"><div class="c-markdown"><p>明确地打开/关闭进度。如果没有指定,如果标准错误连接到终端,则显示进度。请注意,并非所有合并策略都可能支持进度报告。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--allow-unrelated-histories</p></div></div><div class="doc-postil"><div class="c-markdown"><p>默认情况下,<code>git merge</code>命令拒绝合并不共享祖先的历史记录。在合并两个独立开始他们的生活的项目的历史时,可以使用此选项来覆盖此安全性。由于这是非常罕见的情况,因此默认情况下不存在配置变量,因此不会添加该变量。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>-S&lt;keyid&gt;   --gpg-sign=&lt;keyid&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>GPG-sign合并提交。该<code>keyid</code>参数是可选的,并且默认为提交者身份; 如果指定,它必须粘贴到选项没有空格。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>-m &lt;msg&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>设置要用于合并提交的提交消息(以防创建)。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果<code>--log</code>指定,则将合并的提交短记录附加到指定的消息。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>git fmt-merge-msg</code>命令可用于为自动<code>git merge</code>调用提供良好的默认值。自动化消息可以包含分支描述。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--no-rerere-autoupdate</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果可能的话允许rerere机制用自动冲突解决的结果更新索引。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--abort</p></div></div><div class="doc-postil"><div class="c-markdown"><p>中止当前的冲突解决过程,并尝试重新构建预合并状态。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果在合并开始时存在未提交的工作树更改,<code>git merge --abort</code>则在某些情况下无法重建这些更改。因此建议在运行之前始终提交或存储更改<code>git merge</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>git merge --abort</code>相当于<code>git reset --merge</code>何时<code>MERGE_HEAD</code>存在。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--continue</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>git merge</code>由于冲突停止后,您可以通过运行来结束合并<code>git merge --continue</code>(请参阅下面的“如何解决冲突”一节)。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>&lt;commit&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>通常其他分行负责人将合并到我们的分行。指定多个提交将与两个以上的父母创建合并亲切地称为Octopus合并</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果没有从命令行提交提交,则合并当前分支被配置为用作其上游的远程跟踪分支。另见本手册页面的配置部分。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>FETCH_HEAD</code>(并且没有其他提交)被指定时,<code>.git/FETCH_HEAD</code>通过先前调用<code>git fetch</code>合并记录在文件中的分支被合并到当前分支。</p></div></div><div class="doc-postil"><div class="c-markdown"><h2>Pre-merge checks</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>在应用外部变更之前您应该完成自己的工作并在本地承诺因此如果发生冲突它不会被破坏。另见git-stash [1]。<code>git pull</code><code>git merge</code>会停止,而不做任何事情时,本地提交的更改与文件重叠<code>git pull</code>/ <code>git merge</code>可能需要更新。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>为了避免在合并提交中记录不相关的更改,<code>git pull</code>并且<code>git merge</code>如果在索引中相对于<code>HEAD</code>提交注册了任何更改,也会中止。(一个例外是当已更改的索引条目处于已经合并的状态时。)</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果所有已命名的提交都已经是祖先<code>HEAD</code><code>git merge</code>则会提前退出,并显示“已更新”消息。</p></div></div><div class="doc-postil"><div class="c-markdown"><h2>Fast-forward merge</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>通常当前分支头是命名提交的祖先。这是最常见的情况,特别是在从<code>git pull</code>以下情况调用时:您正在跟踪上游存储库,您没有提交本地更改,现在您想更新为更新的上游修订版。在这种情况下,不需要新的提交来存储组合的历史; 相反,<code>HEAD</code>(与索引一起)更新为指向指定的提交,而不创建额外的合并提交。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>该行为可以通过该<code>--no-ff</code>选项进行抑制。</p></div></div><div class="doc-postil"><div class="c-markdown"><h2>真正的合并</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>除了在快进合并中(见上文),要合并的分支必须通过合并提交绑定在一起,合并提交将它们都作为其父项。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>提交一个合并版本来协调所有要合并的分支的更改,并将您的<code>HEAD</code>索引和工作树更新为它。只要不重叠,可以在工作树中进行修改; 更新将保留它们。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果不清楚如何协调更改,则会发生以下情况:</p></div></div><div class="doc-postil"><div class="c-markdown"><ol class="ol-level-0 list-paddingleft-2"><li><p><code>HEAD</code>指针保持不变。</p></li><li><p><code>MERGE_HEAD</code>ref被设置为指向另一个分支头。</p></li><li><p>干净合并的路径在索引文件和工作树中都会更新。</p></li><li><p>对于冲突的路径索引文件最多可以记录三个版本第1阶段存储公共祖先的版本第2阶段的版本<code>HEAD</code>和第3 阶段的版本<code>MERGE_HEAD</code>(可以检查阶段<code>git ls-files -u</code>)。工作树文件包含“合并”程序的结果; 即3路合并结果与熟悉的冲突标记<code>&lt;&lt;&lt;</code> <code>===</code> <code>&gt;&gt;&gt;</code></p></li><li><p>没有其他更改。特别是,在开始合并之前进行的本地修改将保持不变,并且它们的索引条目保持原样,即匹配<code>HEAD</code></p></li></ol></div></div><div class="doc-postil"><div class="c-markdown"><p>如果您尝试导致复杂冲突并想重新开始的合并,则可以使用恢复<code>git merge --abort</code></p></div></div><div class="doc-postil"><div class="c-markdown"><h2>Merging tag</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>合并注释也可能是签名标记时即使可以进行快进合并Git也会始终创建合并提交并且提交消息模板是使用标记消息准备的。另外如果标签已签名则签名检查会作为消息模板中的注释报告。另请参阅git-tag [1]。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>当您只想将导致正好被标记的提交的工作集成时,例如与上游发行版同步时,您可能不想进行不必要的合并提交。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>在这种情况下您可以在喂食之前自己“unwrap”标签<code>git merge</code>,或者<code>--ff-only</code>在您自己没有任何工作时通过。例如</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">git fetch origin
git merge v1.2.3^0git merge --ff-only v1.2.3</pre></div></div><div class="doc-postil"><div class="c-markdown"><h2>如何呈现冲突</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>在合并期间更新工作树文件以反映合并结果。在对共同祖先版本进行的更改中不重叠的您更改了文件的某个区域而另一侧完全保留该区域或反之亦然最终结果逐字记录。但是当双方都对同一地区进行更改时Git不能随意选择一边而不是另一边并要求您通过将双方对该区域的干涉解决。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>默认情况下Git使用与RCS套件中的“合并”程序使用的风格相同的风格来呈现这样一个冲突的大块如下所示</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">Here are lines that are either unchanged from the common
ancestor, or cleanly resolved because only one side changed.&lt;&lt;&lt;&lt;&lt;&lt;&lt; yours:sample.txt
Conflict resolution is hard;let's go shopping.=======Git makes conflict resolution easy.&gt;&gt;&gt;&gt;&gt;&gt;&gt; theirs:sample.txt
And here is another line that is cleanly resolved or unmodified.</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>其中一对相互矛盾的变化发生的区域标有标记<code>&lt;&lt;&lt;&lt;&lt;&lt;&lt;</code><code>=======</code><code>&gt;&gt;&gt;&gt;&gt;&gt;&gt;</code>。之前的部分<code>=======</code>通常是你的一面,而之后的部分通常是他们的一面。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>默认格式不显示原始在冲突区域中所说的内容。你不知道有多少行被删除, 取而代之的是芭比的评论在你身边。你唯一能说的是, 你的一方想说这是很难的, 你宁愿去购物, 而另一方想声称这是容易的。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>通过将“merge.conflictStyle”配置变量设置为“diff3”可以使用其他样式。在“diff3”风格中上述冲突可能如下所示</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">Here are lines that are either unchanged from the common
ancestor, or cleanly resolved because only one side changed.&lt;&lt;&lt;&lt;&lt;&lt;&lt; yours:sample.txt
Conflict resolution is hard;let's go shopping.|||||||Conflict resolution is hard.=======Git makes conflict resolution easy.&gt;&gt;&gt;&gt;&gt;&gt;&gt; theirs:sample.txt
And here is another line that is cleanly resolved or unmodified.</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>除了<code>&lt;&lt;&lt;&lt;&lt;&lt;&lt;</code><code>=======</code><code>&gt;&gt;&gt;&gt;&gt;&gt;&gt;</code>标志,它使用另一个<code>|||||||</code>后跟原文标记。你可以说,原文只是陈述了一个事实,你方只是放弃了这个陈述而放弃了,而另一方则试图采取更积极的态度。有时您可以通过查看原件来获得更好的分辨率。</p></div></div><div class="doc-postil"><div class="c-markdown"><h2>如何解决冲突</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>看到冲突后,你可以做两件事:</p></div></div><div class="doc-postil"><div class="c-markdown"><ul class="ul-level-0 list-paddingleft-2" style="margin: 10px 0px 10px 20px;"><li><p>决定不合并。您需要的唯一清理操作是将索引文件重置为<code>HEAD</code>提交以反向2.并清除由2.和3所做的工作树更改。<code>git merge --abort</code>可以用于此。</p></li><li><p>解决冲突。Git将标记工作树中的冲突。将这些文件编辑为形状<code>git add</code>并将其转换为索引。使用<code>git commit</code><code>git merge --continue</code>密封交易。后一个命令在调用之前检查是否存在正在进行的(中断的)合并<code>git commit</code></p></li></ul></div></div><div class="doc-postil"><div class="c-markdown"><p>您可以通过许多工具解决冲突:</p></div></div><div class="doc-postil"><div class="c-markdown"><ul class="ul-level-0 list-paddingleft-2" style="margin: 10px 0px 10px 20px;"><li><p>使用mergetool。<code>git mergetool</code>启动一个图形化的合并工具,这将通过合并工作。</p></li><li><p>看看差异。<code>git diff</code>将显示三方差异,突出显示来自版本<code>HEAD</code><code>MERGE_HEAD</code>版本的更改。</p></li><li><p>看看每个分支的差异。<code>git log --merge -p &lt;path&gt;</code>将首先显示<code>HEAD</code>版本和<code>MERGE_HEAD</code>版本的差异。</p></li><li><p>看看原件。<code>git show :1:filename</code>显示共同的祖先,<code>git show :2:filename</code>显示<code>HEAD</code>版本,并<code>git show :3:filename</code>显示<code>MERGE_HEAD</code>版本。</p></li></ul></div></div><div class="doc-postil"><div class="c-markdown"><h2>例子</h2></div></div><div class="doc-postil"><div class="c-markdown"><ul class="ul-level-0 list-paddingleft-2" style="margin: 10px 0px 10px 20px;"><li><p>合并分支<code>fixes</code><code>enhancements</code>当前分支的顶部,使分支合并:$ git merge fixes enhancements</p></li><li><p><code>obsolete</code>使用<code>ours</code>合并策略将分支合并到当前分支中:$ git merge -s我们的过时的</p></li><li><p>将分支合并<code>maint</code>到当前分支中,但不要自动创建新的提交:$ git merge --no-commit maint</p></li></ul></div></div><div class="doc-postil"><div class="c-markdown"><p>当您想要对合并进行进一步的更改,或者想要编写自己的合并提交消息时,可以使用此选项。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>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.</p></div></div><div class="doc-postil"><div class="c-markdown"><h2>Merge strategies</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>合并机制(<code>git merge</code><code>git pull</code>命令)允许<code>merge strategies</code>使用<code>-s</code>选项选择后端。一些策略也可以采取他们自己的选择,这可以通过给出<code>-X&lt;option&gt;</code>参数<code>git merge</code>和/或通过<code>git pull</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>resolve</p></div></div><div class="doc-postil"><div class="c-markdown"><p>这只能使用3路合并算法解析两个头即当前分支和另一个分支。它试图仔细检测交叉融合歧义并被认为通常是安全和快速的。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>recursive</p></div></div><div class="doc-postil"><div class="c-markdown"><p>这只能使用3路合并算法来解析两个头。当有多个可用于3路合并的共同祖先时它将创建共同祖先的合并树并将其用作3路合并的参考树。据报道这会导致更少的合并冲突而不会因从Linux 2.6内核开发历史记录中进行的实际合并提交所做的测试而导致混淆。此外,这可以检测并处理涉及重命名的合并。这是拉取或合并一个分支时的默认合并策略。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>recursive</code>策略可以采取以下选择:</p></div></div><div class="doc-postil"><div class="c-markdown"><p>ours</p></div></div><div class="doc-postil"><div class="c-markdown"><p>该选项强制冲突的hunk通过支持<code>our</code>版本自动解决。来自另一棵与我们不冲突的树的变化反映到合并结果。对于二进制文件,整个内容都是从我们这边拿来的。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>这不应与<code>ours</code>合并策略混淆,合并策略甚至不会考虑其他树包含的内容。它丢弃了其他树的所有内容,声明<code>our</code>历史包含发生在其中的所有事情。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>theirs</p></div></div><div class="doc-postil"><div class="c-markdown"><p>这是相反的<code>ours</code>; 请注意,与此不同的<code>ours</code>是,没有<code>theirs</code>融合策略来混淆这个合并选项。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>patience</p></div></div><div class="doc-postil"><div class="c-markdown"><p>使用此选项,<code>merge-recursive</code>花费一点额外的时间来避免由于不重要的匹配行例如来自不同功能的括号而导致的混淆。当要合并的分支疯狂地分歧时使用它。另请参阅git-diff [1] <code>--patience</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>diff-algorithm=patience|minimal|histogram|myers</p></div></div><div class="doc-postil"><div class="c-markdown"><p>告诉<code>merge-recursive</code>使用不同的差异算法这可以帮助避免由于不重要的匹配行例如不同功能的花括号而发生误合。另请参阅git-diff [1] <code>--diff-algorithm</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>ignore-space-change   ignore-all-space   ignore-space-at-eol</p></div></div><div class="doc-postil"><div class="c-markdown"><p>为了三路合并的目的将指定类型的空白的行对待不变。空白变化与其他变化混合在一起不会被忽略。另见GIT-DIFF [1] <code>-b</code><code>-w</code><code>--ignore-space-at-eol</code></p></div></div><div class="doc-postil"><div class="c-markdown"><ul class="ul-level-0 list-paddingleft-2" style="margin: 10px 0px 10px 20px;"><li><p>If <code>their</code> version only introduces whitespace changes to a line, <code>our</code> version is used;</p></li><li><p>If <code>our</code> version introduces whitespace changes but <code>their</code> version includes a substantial change, <code>their</code> version is used;</p></li><li><p>Otherwise, the merge proceeds in the usual way.</p></li></ul></div></div><div class="doc-postil"><div class="c-markdown"><p>renormalize</p></div></div><div class="doc-postil"><div class="c-markdown"><p>This runs a virtual check-out and check-in of all three stages of a file when resolving a three-way merge. This option is meant to be used when merging branches with different clean filters or end-of-line normalization rules. See "Merging branches with differing checkin/checkout attributes" in gitattributes[5] for details.</p></div></div><div class="doc-postil"><div class="c-markdown"><p>no-renormalize</p></div></div><div class="doc-postil"><div class="c-markdown"><p>禁用该<code>renormalize</code>选项。这覆盖<code>merge.renormalize</code>配置变量。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>no-renames</p></div></div><div class="doc-postil"><div class="c-markdown"><p>关闭重命名检测。另请参阅git-diff [1] <code>--no-renames</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>find-renames=&lt;n&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>打开重命名检测可选择设置相似性阈值。这是默认设置。另请参阅git-diff [1] <code>--find-renames</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>rename-threshold=&lt;n&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>Deprecated synonym for <code>find-renames=&lt;n&gt;</code>.</p></div></div><div class="doc-postil"><div class="c-markdown"><p>subtree=&lt;path&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>该选项是一种更高级的<code>subtree</code>策略形式,该策略可以猜测两个树在合并时必须如何移动以相互匹配。相反,指定的路径是前缀(或从开始剥离)以使两棵树的形状匹配。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>octopus</p></div></div><div class="doc-postil"><div class="c-markdown"><p>这解决了两个以上负责人的情况,但拒绝执行需要手动解决的复杂合并。它主要用于将主题分支主题捆绑在一起。这是拉取或合并多个分支时的默认合并策略。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>ours</p></div></div><div class="doc-postil"><div class="c-markdown"><p>这可以解析任意数量的头,但合并结果树始终是当前分支头的树,有效地忽略了所有其他分支的所有更改。它是用来取代侧枝的旧发展历史。请注意,这与<code>recursive</code>合并策略的-Xours选项不同。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>subtree</p></div></div><div class="doc-postil"><div class="c-markdown"><p>这是一个修改后的递归策略。合并树A和B时如果B对应于A的子树则首先调整B以匹配A的树结构而不是读取处于同一级别的树。这种调整也对共同的祖先树进行。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>对于使用3路合并包括默认值<code>recursive</code>)的策略,如果在两个分支上进行了更改,但稍后在其中一个分支上进行了恢复,则该更改将出现在合并结果中; 有些人觉得这种行为很混乱。这是因为在执行合并时仅考虑头部和合并基础,而不是个别提交。因此,合并算法将恢复的更改视为完全没有更改,而是替换更改后的版本。</p></div></div><div class="doc-postil"><div class="c-markdown"><h2>配置</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>merge.conflictStyle</p></div></div><div class="doc-postil"><div class="c-markdown"><p>指定在合并时将冲突的区块写入工作树文件的样式。默认值是“合并”,它显示了一个<code>&lt;&lt;&lt;&lt;&lt;&lt;&lt;</code>冲突标记,一侧<code>=======</code>发生的变化,一个标记,另一侧发生的变化,然后是<code>&gt;&gt;&gt;&gt;&gt;&gt;&gt;</code>标记。另一种样式“diff3”在<code>|||||||</code>标记之前添加了一个标记和原始文本<code>=======</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>merge.defaultToUpstream</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果在没有任何提交参数的情况下调用合并,则使用存储在其远程跟踪分支中的上次观察值合并为当前分支配置的上游分支。查询<code>branch.&lt;current branch&gt;.merge</code>名称为远程命名的远程分支的值<code>branch.&lt;current branch&gt;.remote</code>,然后将它们映射<code>remote.&lt;remote&gt;.fetch</code>到其对应的远程跟踪分支,并合并这些跟踪分支的提示。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>merge.ff</p></div></div><div class="doc-postil"><div class="c-markdown"><p>默认情况下Git在合并作为当前提交的后代的提交时不会创建额外的合并提交。相反当前分支的尖端被快速转发。当设置为<code>false</code>这个变量告诉Git在这种情况下创建一个额外的合并提交相当于<code>--no-ff</code>从命令行提供选项)。设置<code>only</code>为时,只允许进行这种快进合并(相当于<code>--ff-only</code>从命令行提供选项)。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>merge.branchdesc</p></div></div><div class="doc-postil"><div class="c-markdown"><p>除了分支名称之外还可以使用与它们关联的分支描述文本填充日志消息。默认为false。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>merge.log</p></div></div><div class="doc-postil"><div class="c-markdown"><p>除了分支名称之外还可以在日志消息中最多填入要合并的实际提交中指定数量的单行描述。默认为falsetrue为20的同义词。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>merge.renameLimit</p></div></div><div class="doc-postil"><div class="c-markdown"><p>在合并期间执行重命名检测时要考虑的文件数量; 如果未指定则默认为diff.renameLimit的值。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>merge.renormalize</p></div></div><div class="doc-postil"><div class="c-markdown"><p>告诉Git存储库中文件的规范表示已经随时间而改变例如较早的提交记录具有CRLF行尾的文本文件但最近使用LF行结尾。在这样的存储库中Git可以在提交之前将提交中记录的数据转换为规范形式然后再执行合并以减少不必要的冲突。有关更多信息请参阅gitattributes [5]中的“合并具有不同签入/签出属性的分支”部分。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>merge.stat</p></div></div><div class="doc-postil"><div class="c-markdown"><p>是否在合并结束时在ORIG_HEAD和合并结果之间打印diffstat。默认情况下为真。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>merge.tool</p></div></div><div class="doc-postil"><div class="c-markdown"><p>控制哪个合并工具由git-mergetool [1]使用。下面的列表显示了有效的内置值。任何其他值都被视为自定义合并工具并要求定义相应的mergetool。&lt;tool&gt; .cmd变量。</p></div></div><div class="doc-postil"><div class="c-markdown"><ul class="ul-level-0 list-paddingleft-2" style="margin: 10px 0px 10px 20px;"><li><p>araxis</p></li><li><p>bc</p></li><li><p>bc3</p></li><li><p>codecompare</p></li><li><p>deltawalker</p></li><li><p>diffmerge</p></li><li><p>diffuse</p></li><li><p>ecmerge</p></li><li><p>emerge</p></li><li><p>examdiff</p></li><li><p>gvimdiff</p></li><li><p>gvimdiff2</p></li><li><p>gvimdiff3</p></li><li><p>kdiff3</p></li><li><p>meld</p></li><li><p>opendiff</p></li><li><p>p4merge</p></li><li><p>tkdiff</p></li><li><p>tortoisemerge</p></li><li><p>vimdiff</p></li><li><p>vimdiff2</p></li><li><p>vimdiff3</p></li><li><p>winmerge</p></li><li><p>xxdiff</p></li></ul></div></div><div class="doc-postil"><div class="c-markdown"><p>merge.verbosity</p></div></div><div class="doc-postil"><div class="c-markdown"><p>控制递归合并策略显示的输出量。如果检测到冲突级别0只输出最终的错误消息。1级只输出冲突2个输出冲突和文件更改。5级及以上输出调试信息。缺省值是2级。可以由<code>GIT_MERGE_VERBOSITY</code>环境变量覆盖。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>merge.&lt;driver&gt;.name</p></div></div><div class="doc-postil"><div class="c-markdown"><p>为自定义低级合并驱动程序定义一个人类可读的名称。有关详细信息请参阅gitattributes [5]。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>merge.&lt;driver&gt;.driver</p></div></div><div class="doc-postil"><div class="c-markdown"><p>定义实现自定义低级别合并驱动程序的命令。有关详细信息请参阅gitattributes [5]。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>merge.&lt;driver&gt;.recursive</p></div></div><div class="doc-postil"><div class="c-markdown"><p>在执行公共祖先之间的内部合并时命名一个低级合并驱动程序。有关详细信息请参阅gitattributes [5]。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>branch.&lt;name&gt;.mergeOptions</p></div></div><div class="doc-postil"><div class="c-markdown"><p>设置合并到分支&lt;name&gt;的默认选项。语法和支持的选项与这些选项相同<code>git merge</code>,但包含空白字符的选项值当前不受支持。</p></div></div></div>