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

6 lines
28 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>gitremote-helpers  - 帮助程序与远程存储库进行交互</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 remote-&lt;transport&gt; &lt;repository&gt; [&lt;URL&gt;]</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 调用。Git 本身不支持。给定的帮助程序将实现此处记录的功能的子集。当 Git 需要使用远程助手与存储库进行交互时,它会将助手作为独立进程产生,将命令发送给助手的标准输入,并期望助手的标准输出结果。因为远程助手作为独立于 Git 的进程运行,所以不需要重新链接 Git 来添加新的助手,也不需要将助手与 Git 的实现链接起来。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>每个助手必须支持 “capabilities” 命令Git 使用它来确定助手将接受的其他命令。这些其他命令可用于发现和更新远程参考,在对象数据库和远程存储库之间传输对象,并更新本地对象存储。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>Git 自带了远程助手是处理各种传输协议如的“curl”的家庭<code>git-remote-http</code><code>git-remote-https</code><code>git-remote-ftp</code><code>git-remote-ftps</code>。他们实现<code>fetch</code><code>option</code><code>push</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>使用一个或(可选)两个参数调用远程帮助程序。第一个参数和 Git 一样指定一个远程仓库; 它是配置的远程或 URL 的名称。第二个参数指定一个 URL ; 它通常是这种形式<code>&lt;transport&gt;://&lt;address&gt;</code>,但任何字符串都是可能的。该<code>GIT_DIR</code>环境变量是为远程助手设置的,可用于确定在哪里存储其他数据或从哪个目录调用辅助 Git 命令。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>当 Git 遇到一个表单的 URL  <code>&lt;transport&gt;://&lt;address&gt;</code>,其中<code>&lt;transport&gt;</code>是一个它本身无法处理的协议,它会自动调用<code>git remote-&lt;transport&gt;</code>完整的 URL 作为第二个参数。如果直接在命令行中遇到这样的 URL ,那么第一个参数与第二个参数相同,如果在配置的远程中遇到,则第一个参数是该远程的名称。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>该表单的 URL  <code>&lt;transport&gt;::&lt;address&gt;</code>明确指示 Git  <code>git remote-&lt;transport&gt;</code>使用<code>&lt;address&gt;</code>第二个参数。如果在命令行上直接遇到这样的 URL ,那么第一个参数是<code>&lt;address&gt;</code>,如果在配置的远程中遇到,则第一个参数是该远程的名称。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>另外,当配置的远程已经<code>remote.&lt;name&gt;.vcs</code>设置为<code>&lt;transport&gt;</code>GIT 中明确地调用<code>git remote-&lt;transport&gt;</code><code>&lt;name&gt;</code>作为第一个参数。如果设置,第二个参数是<code>remote.&lt;name&gt;.url</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>Git 向标准输入发送远程助手的命令列表,每行一个。第一个命令总是<code>capabilities</code>命令,作为响应,远程助手必须打印它所支持的功能列表(见下文),后面跟着一个空行。对 capabilities 命令的响应决定了 Git 在其余命令流中使用的命令。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>命令流由空行终止。在某些情况下(在相关命令的文档中指出),该空行后面是其他协议中的有效载荷(例如包协议),而在其他情况下则表示输入结束。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>功能</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>预计每个远程助手只支持一部分命令。辅助程序支持的操作在对<code>capabilities</code>命令的响应中声明为 Git (请参见下面的 COMMANDS )。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>在下文中,我们列出了所有已定义的功能,并为每个列出了具有该功能的助手必须提供的命令。</p></div></div><div class="doc-postil"><div class="c-markdown"><h4>推动能力</h4></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">connect</em></p></div></div><div class="doc-postil"><div class="c-markdown"><p>可以尝试使用 git 的本机 packfile 协议连接<code>git receive-pack</code>(推送)<code>git upload-pack</code>等通信。这需要双向全双工连接。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>支持的命令:<code>connect</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">push</em></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>list for-push</code><code>push</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">export</em></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>list for-push</code><code>export</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果给<code>connect</code>打广告Git 将尽可能使用它,如果助手在连接时请求,则会回退到另一个能力(请参阅<code>connect</code> COMMANDS 下的命令)。当选择<code>push</code><code>export</code>Git 喜欢<code>push</code>。其他前端可能有其他一些优先顺序。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">no-private-update</em></p></div></div><div class="doc-postil"><div class="c-markdown"><p>在使用该<code>refspec</code>功能时git 通常会在成功推送时更新私有的参考。当 remote-helper 声明能力时,此更新被禁用<code>no-private-update</code></p></div></div><div class="doc-postil"><div class="c-markdown"><h4>提取能力</h4></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">connect</em></p></div></div><div class="doc-postil"><div class="c-markdown"><p>可以尝试使用 Git 的本机 packfile 协议连接<code>git upload-pack</code>(用于读取)<code>git receive-pack</code>等。这需要双向全双工连接。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>支持的命令:<code>connect</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">fetch</em></p></div></div><div class="doc-postil"><div class="c-markdown"><p>可以发现远程引用并将可从其访问的对象传输到本地对象存储区。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>Supported commands: <code>list</code>, <code>fetch</code>.</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">import</em></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>list</code><code>import</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">check-connectivity</em></p></div></div><div class="doc-postil"><div class="c-markdown"><p>可以保证在请求 clone 时,收到的包是自包含的并且已连接。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果 helper 做广告<code>connect</code>Git 将尽可能使用它,如果助手在连接时请求,则会回退到另一个能力(请参阅<code>connect</code> COMMANDS 下的命令)。当选择<code>fetch</code><code>import</code>Git 喜欢<code>fetch</code>。其他前端可能有其他一些优先顺序。</p></div></div><div class="doc-postil"><div class="c-markdown"><h4>杂项功能</h4></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">option</em></p></div></div><div class="doc-postil"><div class="c-markdown"><p>用于指定像<code>verbosity</code>(写入 stderr 的输出量有多少)和<code>depth</code>(对浅克隆而言需要多少历史记录)等影响其他命令执行的设置。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">refspec</em> &lt;refspec&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>对于实现<code>import</code>或者的远程助手<code>export</code>,这个功能允许 refs 被限制到一个私有名称空间,而不是直接写入 refs / heads 或者 ref / remotes 。建议所有提供此<code>import</code>功能的进口商都使用此功能。这是强制性的<code>export</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>refspec refs/heads/*:refs/svn/origin/branches/*</code>,当它被要求时<code>import refs/heads/topic</code>,它输出的流将更新<code>refs/svn/origin/branches/topic</code>参考。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>此功能可以被多次建议。第一个适用的 refspec 优先。使用此功能宣传的 refspecs 的左侧必须覆盖 list 命令报告的所有参考。如果没有<code>refspec</code>能力被宣传,那就暗示了<code>refspec *:*</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>当为分散版本控制系统编写 remote-helpers 时,建议保留一个本地的版本库副本进行交互,并让私有命名空间参考指向这个本地版本库,而 refs / remotes 命名空间用于跟踪远程存储库。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">bidi-import</em></p></div></div><div class="doc-postil"><div class="c-markdown"><p>这改变了<code>import</code>能力。快速导入命令<code>cat-blob</code><code>ls</code>远程助手可以使用该命令来检索快速导入内存中已存在的斑点和树的信息。这需要一个从快速导入到远程助手的通道。如果除了“导入”之外还公布了它Git 将建立一个从快速导入到远程助手 stdin 的管道。因此Git 和快速导入都连接到远程助手的 stdin 。因为 Git 可以向远程帮助器发送多个命令,所以需要使用<code>bidi-import</code>缓冲区的帮助器<code>import</code>在发送数据到快速导入之前使用缓冲区的所有命令。这是为了防止在助手的 stdin 上混合命令和快速导入响应。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">export-marks</em> &lt;file&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>这会修改该<code>export</code>功能,指示 Git 在完成时将内部标记表转储到 &lt;file&gt; 。有关详细信息,请阅读<code>--export-marks=&lt;file&gt;</code>git-fast-export [1]。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">import-marks</em> &lt;file&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>这会修改该<code>export</code>功能,指示 Git 在处理任何输入之前加载 &lt;file&gt; 中指定的标记。有关详细信息,请阅读<code>--import-marks=&lt;file&gt;</code> git-fast-export [1] 。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">signed-tags</em></p></div></div><div class="doc-postil"><div class="c-markdown"><p>这会修改该<code>export</code>功能,指示 Git 传递<code>--signed-tags=verbatim</code>给 git-fast-export [1] 。在没有这种能力的情况下Git 会使用<code>--signed-tags=warn-strip</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><em style="font-style: italic;">capabilities</em></p></div></div><div class="doc-postil"><div class="c-markdown"><p>列出助手的功能,每行一个,以空行结束。每个功能都可以使用<code>*</code>,这标志着它们对于使用远程帮助程序理解的 Git 版本是强制性的。任何未知的强制性能力都是致命的错误。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>对此命令的支持是强制性的。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">list</em></p></div></div><div class="doc-postil"><div class="c-markdown"><p>以 “&lt;value&gt; &lt;name&gt; &lt;attr&gt; ...” 格式列出每行一个参考。值可以是一个十六进制 sha1 散列,“@ &lt;dest&gt;” 用于 symref或 “?”
以表明助手无法获得参考价值。名称后面有空格分隔的属性列表; 无法识别的属性被忽略。该列表以空行结束。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>有关当前定义的属性的列表,请参阅 REF LIST ATTRIBUTES 。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果助手具有“获取”或“导入”功能,则受支持。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">list for-push</em></p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>list</code>与之类似,只是当且仅当调用者想要生成的引用列表准备推送命令时才使用它。同时支持 push 和 fetch 的助手可以使用它来区分<code>list</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><em style="font-style: italic;">option</em> &lt;name&gt; &lt;value&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>将传输助手选项 &lt;name&gt; 设置为 &lt;value&gt; 。输出包含<code>ok</code>(选项成功设置),<code>unsupported</code>(选项无法识别)和<code>error &lt;msg&gt;</code>(选项 &lt;name&gt; 支持但 &lt;value&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>如果助手具有“选项”功能则支持。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">fetch</em> &lt;sha1&gt; &lt;name&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>获取给定的对象,将必要的对象写入数据库。提取命令以批处理形式发送,每行一个,以空行结束。当同一批次中的所有提取命令都完成时,输出一个空白行。只有在<code>list</code> sha1 的输出中报告的对象可以通过这种方式获取。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>也可以输出一个<code>lock &lt;file&gt;</code>指示 GIT_DIR / objects / pack 下的文件的行,该文件保持一个包,直到 ref 可以被适当地更新。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果<code>check-connectivity</code>请求了选项,<code>connectivity-ok</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><em style="font-style: italic;">push</em> +&lt;src&gt;:&lt;dst&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>将给定的本地 &lt;src&gt; 提交或分支推送到由 &lt;dst&gt; 描述的远程分支。一个或多个<code>push</code>命令的批处理序列以空行结束(如果只有一个引用来推送,则单个<code>push</code>命令后面跟着一个空行)。例如,下面是两批<code>push</code>,第一批要求 remote-helper 将本地 ref推<code>master</code>送到远程 ref <code>master</code>,将本地 ref 推<code>HEAD</code>送到远程<code>branch</code>,第二批要求将 ref 推入<code>foo</code>ref <code>bar</code>(由该请求强制更新<code>+</code></p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">push refs/heads/master:refs/heads/master
push HEAD:refs/heads/branch
\n
push +refs/heads/foo:refs/heads/bar
\n</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>最后一个<code>push</code>命令之后,在批次的终止空白行之前可以输入零个或多个协议选项。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>当推送完成时,输出一个或多个<code>ok &lt;dst&gt;</code><code>error &lt;dst&gt; &lt;why&gt;?</code>线路以指示每个推送参考的成功或失败。状态报告输出以空行结束。如果选项字段包含 LF则可以用 C 风格字符串引用该选项字段。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果助手具有 "push" 功能则支持。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">import</em> &lt;name&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>生成一个快速导入的流,导入指定 ref 的当前值。它还可以根据需要额外导入其他参考以高效地构建历史记录。脚本写入助手特定的私有名称空间。named ref 的值应写入此名称空间中的一个位置,该位置通过将 refspecs 从 “refspec” 功能应用到 ref 的名称而得出。</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>push</code>,一个或多个批处理序列<code>import</code>以空行结束。对于每一批<code>import</code>,远程助手应该产生一个由<code>done</code>命令终止的快速导入流。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>请注意,如果使用了<code>bidi-import</code>功能,则在开始发送数据以进行快速导入之前,必须缓冲完整的批处理序列,以防止在帮助器的 stdin 上混合命令和快速导入响应。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果助手具有 "import" 功能则支持。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">export</em></p></div></div><div class="doc-postil"><div class="c-markdown"><p>指示远程助手任何后续输入都是快速导入流(由生成的<code>git fast-export</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>如果指定了这些<code>export-marks</code><code>import-marks</code>功能,只要它们被传递到<code>git fast-export</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><em style="font-style: italic;">connect</em> &lt;service&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>连接到给定的服务。帮助器的标准输入和标准输出连接到指定服务git 前缀包含在服务名称中,例如,<code>git-upload-pack</code>作为服务提取使用)在远程端。对此命令的有效答复是空行(已建立连接),<code>fallback</code>(不支持智能传输支持,退回到哑传输),并且仅在退出时显示错误消息(无法连接,请勿尝试退回)。在换行终止正(空)响应后,服务输出开始。连接结束后,远程助手退出。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果助手具有 "connect" 功能则支持。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果发生致命错误,程序会将错误消息写入 stderr 并退出。如果孩子关闭连接而未完成当前命令的有效响应,则调用者应该期望已经打印出合适的错误消息。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>可以支持附加的命令,这可以从助手报告的能力中确定。</p></div></div><div class="doc-postil"><div class="c-markdown"><h2>参考列表属性</h2></div></div><div class="doc-postil"><div class="c-markdown"><p><code>list</code>命令产生一个 ref 列表,其中每个 ref 可以后跟一个属性列表。定义了以下参考列表属性。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">unchanged</em></p></div></div><div class="doc-postil"><div class="c-markdown"><p>该引用自上次导入或提取后不变,但助手不一定能确定产生的值。</p></div></div><div class="doc-postil"><div class="c-markdown"><h2>选项</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>如果远程助手有<code>option</code>能力,则定义以下选项并在 Git 中设置(在适当的情况下)。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">option verbosity</em> &lt;n&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>更改助手显示的消息的详细程度。&lt;n&gt; 的值为0意味着进程安静地运行并且助手只产生错误输出。1是默认的详细级别更高的值 &lt;n&gt; 对应于在命令行上传递的 -v 标志的数量。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">option progress</em> {<em style="font-style: italic;">true</em>|<em style="font-style: italic;">false</em>}</p></div></div><div class="doc-postil"><div class="c-markdown"><p>启用(或禁用)传输助手在命令期间显示的进度消息。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">option depth</em> &lt;depth&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>'option deepen-since &lt;timestamp&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>'option deepen-not &lt;ref&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><em style="font-style: italic;">option deepen-relative {'true</em>|<em style="font-style: italic;">false</em>}</p></div></div><div class="doc-postil"><div class="c-markdown"><p>相对于当前的边界,加深了浅仓库的历史。仅在与“选项深度”一起使用时才有效。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">option followtags</em> {<em style="font-style: italic;">true</em>|<em style="font-style: italic;">false</em>}</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>option dry-run</code>{ <code>true</code>| <code>false</code>}:如果为 true ,则假装操作成功完成,但实际上并未更改任何存储库数据。对于大多数帮助者来说,这只适用于<code>push</code>(如果支持的话)。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">option servpath &lt;c-style-quoted-path&gt;</em></p></div></div><div class="doc-postil"><div class="c-markdown"><p>为下一次连接设置服务路径(--upload-pack--receive-pack等。远程帮助程序可能支持此选项但在连接请求发生之前不能依赖此设置。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">option check-connectivity</em> {<em style="font-style: italic;">true</em>|<em style="font-style: italic;">false</em>}</p></div></div><div class="doc-postil"><div class="c-markdown"><p>请求助手检查克隆的连通性。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">option force</em> {<em style="font-style: italic;">true</em>|<em style="font-style: italic;">false</em>}</p></div></div><div class="doc-postil"><div class="c-markdown"><p>请助手执行强制更新。默认为<code>false</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">option cloning</em> {<em style="font-style: italic;">true</em>|<em style="font-style: italic;">false</em>}</p></div></div><div class="doc-postil"><div class="c-markdown"><p>通知助手,这是一个克隆请求(即当前储存库保证为空)。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">option update-shallow</em> {<em style="font-style: italic;">true</em>|<em style="font-style: italic;">false</em>}</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果新引用需要,允许扩展 .git / shallow 。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><em style="font-style: italic;">option pushcert</em> {<em style="font-style: italic;">true</em>|<em style="font-style: italic;">false</em>}</p></div></div><div class="doc-postil"><div class="c-markdown"><p>GPG 标志推动。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>'option push-option &lt;string&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>传输 &lt;string&gt; 作为推送选项。由于推送选项不能包含 LF 或 NUL 字符,因此字符串不会被编码。</p></div></div></div>