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

49 lines
78 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-fast-import  - 用于快速Git数据导入器的后端</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">frontend | git fast-import [options]</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 fast-import</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>快速导入从标准输入读取混合命令/数据流并将一个或多个包文件直接写入当前存储库。当在标准输入接收到EOF时快速导入会写出更新的分支和标记参考并使用新导入的数据完全更新当前存储库。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>快速导入后端本身可以导入到一个空的存储库(已经初始化<code>git init</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>--force</p></div></div><div class="doc-postil"><div class="c-markdown"><p>强制更新已修改的现有分支,即使这样做会导致提交丢失(因为新提交不包含旧提交)。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--quiet</p></div></div><div class="doc-postil"><div class="c-markdown"><p>禁用所有非致命输出,在成功时快速导入无声。该选项禁用--stats显示的输出。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--stats</p></div></div><div class="doc-postil"><div class="c-markdown"><p>显示有关fast-import创建的对象的基本统计信息它们存储到的包文件以及在此运行期间通过快速导入使用的内存。显示此输出目前是默认值但可以使用--quiet禁用。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>前端选项</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>--cat-blob-fd=&lt;fd&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>写响应<code>get-mark</code><code>cat-blob</code>以及<code>ls</code>查询到文件描述符&lt;FD&gt;代替<code>stdout</code>。允许<code>progress</code>将最终用户的输出与其他输出分离。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--date-format=&lt;fmt&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>指定日期的前端将供应给中快速导入的类型<code>author</code><code>committer</code><code>tagger</code>命令。有关支持哪些格式及其语法的详细信息,请参阅下面的“日期格式”。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--done</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果<code>done</code>流尾没有命令,则会终止并报错。此选项对于检测导致前端在开始写入流之前终止的错误可能很有用。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>标记文件的位置</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>--export-marks=&lt;file&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>完成后将内部标记表转储到&lt;file&gt;。标记每行写成一个<code>:markid SHA-1</code>。前端可以使用此文件在导入完成后验证导入,或跨增量运行保存标记表。由于&lt;file&gt;仅在检查点(或完成)时打开并截断,因此同样的路径也可以安全地分配给--import-marks。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--import-marks=&lt;file&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>在处理任何输入之前,请加载&lt;文件&gt;中指定的标记。输入文件必须存在,必须可读,并且必须使用与--export-marks相同的格式。可以提供多个选项来导入一组以上的标记。如果标记被定义为不同的值则最后一个文件将获胜。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--import-marks-if-exists=&lt;file&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>就像--import-marks一样但不是错误的如果文件不存在静静地跳过文件。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--no-relative-marks</p></div></div><div class="doc-postil"><div class="c-markdown"><p>指定--relative-marks之后使用--import-marks =和--export-marks =指定的路径与当前存储库中的内部目录相关。在git-fast-import中这意味着路径相对于.git / info / fast-import目录。但是其他进口商可能会使用不同的地点。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>相对标记和非相关标记可以通过交织 - (无 - - 相对标记与 - import | export-marks =选项进行组合。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>性能和压缩调优</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>--active-branches=&lt;n&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>一次保持活动的最大分支数量。有关详细信息,请参阅下面的“内存使用率” 缺省值是5。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--big-file-threshold=&lt;n&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>快速导入将尝试创建增量的最大大小以字节表示。默认值为512m512 MiB。一些进口商可能希望在内存受限的系统上降低这一点。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--depth=&lt;n&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>最大增量深度用于blob和树的分离。默认值是50。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--export-pack-edges=&lt;file&gt;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>创建一个 packfile 后,将一行数据打印到&lt;file&gt;列出 packfile 的文件名以及每个分支写入 packfile 的最后一次提交。导入其总对象集超过 4 GiB packfile 限制的项目后,此信息可能会有用,因为这些提交可用作呼叫期间的边缘点<code>git pack-objects</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>--max-pack-size=&lt;n&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>fastimport.unpackLimit</p></div></div><div class="doc-postil"><div class="c-markdown"><p>见git-config [1]</p></div></div><div class="doc-postil"><div class="c-markdown"><h2>性能</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>快速导入的设计允许它以最少的内存使用量和处理时间导入大型项目。假设前端能够跟上快速导入并为其提供持续不断的数据流对于持续10年以上历史并且包含100,000个以上单独提交的项目导入时间通常仅需1-2小时即可完成相当适中 〜$ 2,000美元硬件。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>大多数瓶颈似乎在外部源数据访问源代码无法足够快地提取修订版本或磁盘IO快速导入写入与磁盘接收数据一样快。如果源数据存储在与目标Git存储库不同的驱动器上由于较少的IO争用导入将运行得更快。</p></div></div><div class="doc-postil"><div class="c-markdown"><h2>开发成本</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>一个典型的快速导入前端往往会用大约200行的Perl / Python / Ruby代码进行权衡。大多数开发者在几个小时内就能创建工作导入者尽管这是他们第一次接触快速导入有时甚至是Git。这是一个理想的情况因为大多数转换工具都是丢弃使用一次永远不会回头</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>git push</code>或者<code>git fetch</code>,通过快速导入处理的导入可以安全地与并行<code>git repack -a -d</code><code>git gc</code>调用或任何其他Git操作包括<code>git prune</code>快速导入从不使用的松散对象)一起运行。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>快速导入不锁定它正在主动导入的分支或标签。导入之后在其ref引用更新阶段快速导入测试每个现有的分支引用以验证更新是否为快速更新存储在ref中的提交包含在要写入的提交的新历史记录中。如果更新不是快进更新则快速导入将跳过更新该参考文件而是输出警告消息。快速导入将始终尝试更新所有分支引用并且不会在第一次失败时停止。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>可以使用--force强制更新分支但建议仅在安静的存储库上使用分支更新。初始导入到一个空的存储库时使用--force不是必需的。</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>commit</code>在输入流上发送命令,可以在导入过程中的任何时刻创建或修改任何分支。这种设计允许前端程序同时处理无限数量的分支,按照源数据可用的顺序生成提交。它也大大简化了前端程序。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>快速导入不会使用或更改当前的工作目录或其中的任何文件。但它会更新当前的Git存储库如引用的那样<code>GIT_DIR</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没有解释之外快速导入输入格式是基于文本ASCII的格式。这种基于文本的格式简化了前端程序的开发和调试特别是在使用诸如PerlPython或Ruby的高级语言时。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>快速进口对其投入非常严格。当我们说下面SP意味着我们<strong>正好</strong>有一个空格。同样LF表示一个且只有一个换行符和HT一个并且只有一个水平制表符。提供额外的空白字符会导致意想不到的结果例如分支名称或文件名称中包含前导或尾随空格或者在遇到意外输入时提前终止快速导入。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>Stream Comments</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>为了帮助快速调试前端import-ignore会忽略以<code>#</code>ASCII pound / hash开头并包含行结尾的行<code>LF</code>。注释行可能包含任何不包含LF的字节序列因此可用于包含任何可能特定于前端的详细调试信息并且在检查快速导入数据流时很有用。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>日期格式</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>支持以下日期格式。前端应通过将格式名称传递给--date-format = &lt;fmt&gt;命令行选项来选择将用于此导入的格式。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>raw</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>这是Git本地格式并且是<code>&lt;time&gt; SP &lt;offutc&gt;</code>。如果未指定--date-format它也是快速导入的默认格式。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>事件的时间由<code>&lt;time&gt;</code>自UNIX纪元1970年1月1日午夜UTC以来的秒数指定并写为ASCII十进制整数。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>本地偏移<code>&lt;offutc&gt;</code>量由UTC 指定为正值或负值。例如ESTUTC时间后5小时将以<code>&lt;tz&gt;</code>“-0500” 表示而UTC为“+0000”。本地抵消不影响<code>&lt;time&gt;</code>; 它仅用作帮助格式化例程显示时间戳的建议。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果源材料中的本地偏移量不可用,请使用“+0000”或最常用的本地偏移量。例如很多组织都有一个CVS存储库它只能被位于相同位置和时区的用户访问。在这种情况下可以假定与UTC的合理偏移。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>rfc2822</code>格式不同,这种格式非常严格。格式的任何变化都会导致快速导入拒绝该值。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>rfc2822</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>这是RFC 2822所描述的标准电子邮件格式。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>示例值为“2月6日11:22:18 2007年-0500”。Git解析器是准确的但在宽松的一面。这是<code>git am</code>应用从电子邮件收到的补丁时使用的解析器。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>一些格式错误的字符串可能被接受为有效日期。在某些情况下Git仍然可以从格式不正确的字符串中获取正确的日期。也有一些类型的错误的字符串Git会解析错误但仍然认为是有效的。严重格式错误的字符串将被拒绝。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>与上述<code>raw</code>格式不同包含在RFC 2822日期字符串中的时区/ UTC偏移量信息用于在存储之前将日期值调整为UTC。因此重要的是这些信息尽可能准确。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果源材料使用RFC 2822风格的日期则前端应该让快速导入处理分析和转换而不是尝试自行完成因为Git分析器已经得到了广泛的测试。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>raw</code>如果源代码材料已经使用UNIX-epoch格式可以通过指定格式给出日期或者可以很容易地将格式转换为格式前端应该更喜欢这种格式因为在解析时没有歧义。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>now</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>始终使用当前时间和时区。文字<code>now</code>必须始终提供<code>&lt;when&gt;</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>git update-index</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果单独的<code>author</code><code>committer</code>命令以使用<code>commit</code>时间戳可能不匹配,因为系统时钟将被轮询两次(一次对每个命令)。确保作者和提交者身份信息具有相同时间戳的唯一方法是省略<code>author</code>(从而复制<code>committer</code>)或使用除<code>now</code>。以外的日期格式。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>命令</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>fast-import接受几个命令来更新当前的存储库并控制当前的导入过程。稍后会对每条命令进行更详细的讨论附带示例</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>commit</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>tag</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>reset</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>blob</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>将原始文件数据转换为blob以供将来在<code>commit</code>命令中使用。该命令是可选的,不需要执行导入。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>checkpoint</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>强制快速导入以关闭当前的包文件生成其独特的SHA-1校验和和索引并启动新的包文件。该命令是可选的不需要执行导入。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>progress</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>done</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>标记流的结束。除非<code>done</code>使用<code>--done</code>命令行选项或<code>feature done</code>命令请求功能,否则此命令是可选的。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>get-mark</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>导致fast-import将标记对应的SHA-1打印到设置的文件描述符中<code>--cat-blob-fd</code>,或者<code>stdout</code>未指定。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>cat-blob</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>导致fast-import将<code>cat-file --batch</code>格式打印到使用<code>--cat-blob-fd</code>或未指定的文件描述符<code>stdout</code>中。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>ls</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>导致 fast-import 将描述目录条目的行以<code>ls-tree</code>格式打印到使用<code>--cat-blob-fd</code>或未指定的文件描述符<code>stdout</code>中。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>feature</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>option</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>指定OPTIONS下列出的任何不改变流语义以满足前端需求的选项。该命令是可选的不需要执行导入。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3><code>commit</code></h3></div></div><div class="doc-postil"><div class="c-markdown"><p>用新提交创建或更新分支,记录项目的逻辑更改。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'commit' SP &lt;ref&gt; LF
        mark?        ('author' (SP &lt;name&gt;)? SP LT &lt;email&gt; GT SP &lt;when&gt; LF)?        'committer' (SP &lt;name&gt;)? SP LT &lt;email&gt; GT SP &lt;when&gt; LF        data        ('from' SP &lt;commit-ish&gt; LF)?        ('merge' SP &lt;commit-ish&gt; LF)?        (filemodify | filedelete | filecopy | filerename | filedeleteall | notemodify)*
        LF?</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>其中<code>&lt;ref&gt;</code>是进行提交的分支的名称。通常分支名称以<code>refs/heads/</code>Git 作为前缀因此导入CVS分支符号<code>RELENG-1_0</code>将用作<code>refs/heads/RELENG-1_0</code><code>&lt;ref&gt;</code><code>&lt;ref&gt;</code>在Git中的值必须是有效的refname。由于<code>LF</code>在Git refname中无效因此此处不支持引用或转义语法。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>mark</code>可以选择出现一个命令,请求快速导入以保存对新创建的提交的引用,以供将来前端使用(请参阅下面的格式)。前端非常常见的是标记他们创建的每个提交,从而允许从任何导入的提交创建未来的分支。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>以下<code>data</code>命令<code>committer</code>必须提供提交消息(请参阅下面的<code>data</code>命令语法。要导入一个空的提交消息请使用长度为0的数据。提交消息是自由格式的不被 Git 解释。目前它们必须以 UTF-8 编码,因为快速导入不允许指定其他编码。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>零个或多个<code>filemodify</code><code>filedelete</code><code>filecopy</code><code>filerename</code><code>filedeleteall</code><code>notemodify</code>命令可以被包括到分支的内容创建的提交之前更新。这些命令可以以任何顺序提供。然而,建议一个<code>filedeleteall</code>命令优先于所有<code>filemodify</code><code>filecopy</code><code>filerename</code><code>notemodify</code>在相同的命令提交,作为<code>filedeleteall</code>擦拭干净分支(见下文)。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>LF</code>命令之后是可选的(它曾经是必需的)。</p></div></div><div class="doc-postil"><div class="c-markdown"><h4><code>author</code></h4></div></div><div class="doc-postil"><div class="c-markdown"><p>如果作者信息可能与提交者信息不同,则可以选择出现一条<code>author</code>命令。如果<code>author</code>省略,那么快速导入将自动使用提交者的信息作为提交的作者部分。请参阅下文中的字段说明<code>author</code>,因为它们与之相同<code>committer</code></p></div></div><div class="doc-postil"><div class="c-markdown"><h4><code>committer</code></h4></div></div><div class="doc-postil"><div class="c-markdown"><p><code>committer</code>命令表明是谁做出这个提交,以及何时提交。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>&lt;name&gt;</code>是人的显示名称(例如“ Com M itter ”),并且<code>&lt;email&gt;</code>是人的电子邮件地址“cm@example.com”<code>LT</code>并且<code>GT</code>是文字小于(\ x3c和大于\ x3e的符号。这些都需要从行中的其他字段分隔电子邮件地址。注意<code>&lt;name&gt;</code><code>&lt;email&gt;</code>是自由形式,并且可以包含任何字节序列,不同之处<code>LT</code><code>GT</code><code>LF</code><code>&lt;name&gt;</code>通常是 UTF-8 编码。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>更改时间通过<code>&lt;when&gt;</code>使用由--date-format = &lt;fmt&gt; 命令行选项选择的日期格式指定。有关支持的一组格式及其语法,请参阅上面的“日期格式”。</p></div></div><div class="doc-postil"><div class="c-markdown"><h4><code>from</code></h4></div></div><div class="doc-postil"><div class="c-markdown"><p><code>from</code>命令用于指定从该初始化分支的提交。这次修订将是新提交的第一个父类。在此提交中构建的树的状态将以<code>from</code>提交时的状态开始,并由此提交中的内容修改进行更改。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>from</code>在新分支的第一次提交中省略命令将导致快速导入来创建没有父类的提交。这往往只适用于项目的初始提交。如果前端在创建新分支时从头开始创建所有文件,<code>merge</code>则可以使用命令而不<code>from</code>是以空树开始提交。<code>from</code>通常需要省略现有分支上的命令,因为分支上的当前提交被自动假定为新提交的第一个父类。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>由于<code>LF</code>在 Git refname 或 SHA-1 表达式中无效,因此在内部不支持引用或转义语法<code>&lt;commit-ish&gt;</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>&lt;commit-ish&gt;</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>已经在快速导入的内部分支表中的现有分支的名称。如果快速导入不知道名称,则将其视为 SHA-1 表达式。</p></li><li><p>标记参考,标记号<code>:&lt;idnum&gt;</code>在哪里<code>&lt;idnum&gt;</code>。快速导入<code>:</code>用来表示标记引用的原因是该字符在Git分支名称中不合法。领先的<code>:</code>使得它很容易区分标志42<code>:42</code>和分支42<code>42</code><code>refs/heads/42</code>),或者是一个简单的 SHA-1它恰好只包含了基数为10的数字。标记必须先声明通过<code>mark</code>)才可以使用。</p></li><li><p>完整的40字节或缩写的提交 SHA-1十六进制</p></li><li><p>任何有效的解析为提交的 Git SHA-1 表达式。有关详细信息,请参阅 gitrevisions [7] 中的“指定修订”。</p></li><li><p>特殊的空 SHA-140个零指定分支要被移除。</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"><pre class="prism-token token language-javascript">        from refs/heads/branch^0</pre></div></div><div class="doc-postil"><div class="c-markdown"><p><code>^0</code>后缀是必需的,因为快速导入不允许一个分支,从自身做起,并在内存中创建<code>from</code>分支之前,即使从输入读取命令。添加<code>^0</code>将强制快速导入通过 Git 的修订解析库而不是其内部分支表来解析提交,从而加载分支的现有值。</p></div></div><div class="doc-postil"><div class="c-markdown"><h4><code>merge</code></h4></div></div><div class="doc-postil"><div class="c-markdown"><p>包含一个额外的父类提交。额外的父类链接不会改变在此提交时树状态的构建方式。如果<code>from</code>在创建新分支时省略该命令,则第一次<code>merge</code>提交将是当前提交的第一个祖先,并且分支将从没有文件开始。<code>merge</code>快速导入允许每次提交的命令数量不受限制,从而建立 n 路合并。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>这里<code>&lt;commit-ish&gt;</code>是任何承诺规范表达式也被<code>from</code>接受(见上文)。</p></div></div><div class="doc-postil"><div class="c-markdown"><h4><code>filemodify</code></h4></div></div><div class="doc-postil"><div class="c-markdown"><p>包含在<code>commit</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>blob</code>命令提供。前端只需要连接它。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'M' SP &lt;mode&gt; SP &lt;dataref&gt; SP &lt;path&gt; LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>这里通常<code>&lt;dataref&gt;</code>必须是<code>:&lt;idnum&gt;</code>由先前<code>blob</code>命令设置的标记引用()或现有 Git Blob 对象的完整40字节 SHA-1 。如果<code>&lt;mode&gt;</code>是,<code>040000`</code><code>&lt;dataref&gt;</code>必须是现有 Git 树对象的全部40字节 SHA-1 或使用其设置的标记引用<code>--import-marks</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>文件的数据内容尚未提供。前端想要提供它作为这个修改命令的一部分。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'M' SP &lt;mode&gt; SP 'inline' SP &lt;path&gt; LF
        data</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>请参阅下面的<code>data</code>命令的详细说明。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>这两种格式<code>&lt;mode&gt;</code>都是八进制文件输入的类型。Git 仅支持以下模式:</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>100644</code>或者<code>644</code>:正常(不可执行)文件。大多数项目中的大多数文件都使用此模式。如果有疑问,这是你想要的。</p></li><li><p><code>100755</code>或者<code>755</code>:正常但可执行的文件。</p></li><li><p><code>120000</code>:一个符号链接,文件的内容将成为链接目标。</p></li><li><p><code>160000</code>:对象的 gitlinkSHA-1 引用另一个存储库中的提交。Git 链接只能由 SHA 或通过提交标记指定。它们用于实现子模块。</p></li><li><p><code>040000</code>:一个子目录。子目录只能通过 SHA 或通过设置树标记来指定<code>--import-marks</code></p></li></ul></div></div><div class="doc-postil"><div class="c-markdown"><p>两种格式<code>&lt;path&gt;</code>都是要添加的文件的完整路径(如果尚不存在)或修改(如果已经存在)。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>&lt;path&gt;</code>字符串必须使用 UNIX 风格的目录分隔符(正斜杠<code>/</code>),可能包含除了以外的任何字节<code>LF</code>,并且不得以双引号(<code>"</code>)开头。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>一个路径可以使用 C 风格的字符串引用; 这在所有情况下都被接受,并且如果文件名以双引号或包含开头则是强制性的<code>LF</code>。在 C 风格的引用中,完整名称应该用双引号括起来,并且任何<code>LF</code>反斜杠或双引号字符都必须用反斜杠(例如,<code>"path/with\n, \\ and \" in it"</code>)在前面进行转义。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>价值<code>&lt;path&gt;</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>包含一个空目录组件(例如<code>foo//bar</code>无效),</p></li><li><p>以目录分隔符结束(例如<code>foo/</code>无效),</p></li><li><p>以目录分隔符开始(例如<code>/foo</code>无效),</p></li><li><p>包含特殊组件<code>.</code><code>..</code>(例如<code>foo/./bar</code><code>foo/../bar</code>无效)。</p></li></ul></div></div><div class="doc-postil"><div class="c-markdown"><p>树的根可以用空字符串表示<code>&lt;path&gt;</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>建议<code>&lt;path&gt;</code>始终使用 UTF-8 编码。</p></div></div><div class="doc-postil"><div class="c-markdown"><h4><code>filedelete</code></h4></div></div><div class="doc-postil"><div class="c-markdown"><p>包含在<code>commit</code>删除文件的命令中或递归地从分支中删除整个目录。如果文件或目录删除使其父目录为空,则父目录也会自动删除。这会级联树直到达到第一个非空目录或根目录。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'D' SP &lt;path&gt; LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>这里<code>&lt;path&gt;</code>是从分支中删除的文件或子目录的完整路径。请参阅<code>filemodify</code>上面的详细说明<code>&lt;path&gt;</code></p></div></div><div class="doc-postil"><div class="c-markdown"><h4><code>filecopy</code></h4></div></div><div class="doc-postil"><div class="c-markdown"><p>递归地将现有文件或子目录复制到分支内的其他位置。现有的文件或目录必须存在。如果目标存在,它将被从源复制的内容完全替换。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'C' SP &lt;path&gt; SP &lt;path&gt; LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>这里第一个<code>&lt;path&gt;</code>是源位置,第二个<code>&lt;path&gt;</code>是目的地。有关可能的外观<code>filemodify</code>的详细说明,请参阅上文<code>&lt;path&gt;</code>。要使用包含 SP 的源路径,必须引用该路径。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>一条<code>filecopy</code>命令立即生效。一旦将源位置复制到目标位置,将来应用于源位置的任何命令都不会影响副本的目标位置。</p></div></div><div class="doc-postil"><div class="c-markdown"><h4><code>filerename</code></h4></div></div><div class="doc-postil"><div class="c-markdown"><p>将现有文件或子目录重命名为分支中的其他位置。现有的文件或目录必须存在。如果目标存在,它将被源目录取代。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'R' SP &lt;path&gt; SP &lt;path&gt; LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>这里第一个<code>&lt;path&gt;</code>是源位置,第二个<code>&lt;path&gt;</code>是目的地。有关可能的外观<code>filemodify</code>的详细说明,请参阅上文<code>&lt;path&gt;</code>。要使用包含 SP 的源路径,必须引用该路径。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>filerename</code>命令立即生效。一旦源位置已被重命名为目标,任何应用于源位置的命令都将在那里创建新文件,而不会影响重命名的目标。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>请注意,<code>filerename</code>与源位置<code>filecopy</code>后跟的<code>filedelete</code>是一样的。使用<code>filerename</code>时有一个轻微的性能优势,但优点非常小,因此永远不值得尝试将源资料中的删除/添加对转换为重命名以快速导入。提供<code>filerename</code>命令只是为了简化已经具有重命名信息的前端,并且不希望将<code>filecopy</code>分解为后面的<code>filedelete</code></p></div></div><div class="doc-postil"><div class="c-markdown"><h4><code>filedeleteall</code></h4></div></div><div class="doc-postil"><div class="c-markdown"><p>包含在<code>commit</code>从分支中删除所有文件(以及所有目录)的命令中。该命令重置内部分支结构以使其中没有文件,从而允许前端从头开始添加所有有趣的文件。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'deleteall' LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>如果前端不知道(或不在乎知道)分支上当前有哪些文件,则该命令非常有用,因此无法生成<code>filedelete</code>更新内容的正确命令。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>发出一个<code>filedeleteall</code>后面紧跟着所需的<code>filemodify</code>命令来设置正确的内容将产生与只发送所需命令<code>filemodify</code><code>filedelete</code>命令相同的结果。<code>filedeleteall</code>但是这种方法可能需要快速导入以便在每个活动分支中使用更多的内存即使是大多数大型项目也少于1 MiB; 因此鼓励那些只能轻松获得提交的受影响路径的前端这样做。</p></div></div><div class="doc-postil"><div class="c-markdown"><h4><code>notemodify</code></h4></div></div><div class="doc-postil"><div class="c-markdown"><p>包含在<code>commit</code> <code>&lt;notes_ref&gt;</code>添加注释a <code>&lt;commit-ish&gt;</code>或更改此注释内容的新注释的命令中。它在内部与<code>&lt;commit-ish&gt;</code>路径上的 filemodify 100644 类似(可能拆分成子目录)。建议不要使用任何其他命令来写入<code>&lt;notes_ref&gt;</code>树,除非<code>filedeleteall</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>blob</code>命令提供。前端只需要将其连接到将被注释的提交。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'N' SP &lt;dataref&gt; SP &lt;commit-ish&gt; LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p><code>&lt;dataref&gt;</code>可以是<code>:&lt;idnum&gt;</code>由先前<code>blob</code>命令设置的标记引用(),也可以是现有 Git Blob 对象的完整40字节 SHA-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>笔记的数据内容尚未提供。前端想要提供它作为这个修改命令的一部分。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'N' SP 'inline' SP &lt;commit-ish&gt; LF
        data</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>请参阅下面的<code>data</code>命令的详细说明。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>在这两种格式<code>&lt;commit-ish&gt;</code>中,任何提交规范表达式也被接受<code>from</code>(参见上文)。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3><code>mark</code></h3></div></div><div class="doc-postil"><div class="c-markdown"><p>安排快速导入以保存对当前对象的引用,允许前端在未来的时间点调用此对象,而无需知道其 SHA-1 。这里的当前对象是<code>mark</code>命令出现的对象创建命令。这可能是<code>commit</code><code>tag</code><code>blob</code>,但是<code>commit</code>是最常见的用法。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'mark' SP ':' &lt;idnum&gt; LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p><code>&lt;idnum&gt;</code>前端分配给此标记的号码在哪里。该值<code>&lt;idnum&gt;</code>
ASCII 十进制整数表示。值 0 保留,不能用作标记。只有大于或等于 1 的值才可以用作标记。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>新标记会自动创建。只需<code>&lt;idnum&gt;</code>在另一个<code>mark</code>命令中重复使用相同的标记,就可以将现有的标记移动到另一个对象。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3><code>tag</code></h3></div></div><div class="doc-postil"><div class="c-markdown"><p>创建一个引用特定提交的注释标签。要创建轻量级(未注释)标签,请参阅<code>reset</code>下面的命令。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'tag' SP &lt;name&gt; LF        'from' SP &lt;commit-ish&gt; LF        'tagger' (SP &lt;name&gt;)? SP LT &lt;email&gt; GT SP &lt;when&gt; LF
        data</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>其中<code>&lt;name&gt;</code>是要创建的标记的名称。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>标记名称会自动用前缀<code>refs/tags/</code>时,存储在 Git 的,所以在导入 CVS 分支符号<code>RELENG-1_0-FINAL</code>将只使用<code>RELENG-1_0-FINAL</code><code>&lt;name&gt;</code>,并快速导入会写相应的裁判作为<code>refs/tags/RELENG-1_0-FINAL</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>&lt;name&gt;</code>必须是 Git 中的有效 refname因此可能包含正斜杠。由于<code>LF</code>在 Git refname 中无效,因此此处不支持引用或转义语法。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>from</code>命令与<code>commit</code>命令中的命令相同; 详情见上文。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>tagger</code>命令使用与之<code>committer</code>内相同的格式<code>commit</code>; 再次参见上面的细节。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>以下<code>data</code>命令<code>tagger</code>必须提供带注释的标记消息(请参阅下面的<code>data</code>命令语法。要导入空标签消息请使用长度为0的数据。标记消息是自由格式的不被 Git 解释。目前它们必须以
UTF-8 编码,因为快速导入不允许指定其他编码。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>不支持在快速导入过程中从导入过程中签署带注释的标签。不建议尝试包含您自己的 PGP / GPG 签名,因为前端不能轻松访问通常进入此签名的完整字节集。如果需要签名,请使用快速导入功能创建轻量级标记<code>reset</code>,然后使用标准<code>git tag</code>过程在离线情况下创建这些标记的注释版本。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3><code>reset</code></h3></div></div><div class="doc-postil"><div class="c-markdown"><p>创建或重新创建指定的分支可以从特定修订开始。reset 命令允许前端<code>from</code>为现有分支发出新命令,或者从现有提交创建新分支而不创建新提交。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'reset' SP &lt;ref&gt; LF        ('from' SP &lt;commit-ish&gt; LF)?
        LF?</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>为的详细说明<code>&lt;ref&gt;</code><code>&lt;commit-ish&gt;</code>参见上述下<code>commit</code><code>from</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>LF</code>命令之后是可选的(它曾经是必需的)。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>reset</code>命令也可用于创建轻量级(未注释)标签。例如:</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">reset refs/tags/938from :938</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>将创建<code>refs/tags/938</code>引用任何提交标记<code>:938</code>引用的轻量级标记。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3><code>blob</code></h3></div></div><div class="doc-postil"><div class="c-markdown"><p>请求将一个文件修订版写入 packfile 。该修订与任何提交都没有关联; 这个连接必须在随后的<code>commit</code>命令中通过指定的标记引用
blob 来形成。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'blob' LF
        mark?
        data</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>标记命令在这里是可选的,因为一些前端已经选择为 blob 自己生成 Git SHA-1 ,并直接提供给它<code>commit</code>。然而,这通常比它的价值更大,因为商标价格低廉,易于使用。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3><code>data</code></h3></div></div><div class="doc-postil"><div class="c-markdown"><p>提供原始数据(用作 blob /文件内容,提交消息或注释标记消息)以快速导入。可以使用确切的字节数提供数据,也可以使用终止线来分隔数据。用于生产质量转换的真正前端应始终使用确切的字节计数格式,因为它更健壮,性能更好。分隔格式主要用于测试快速导入。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>&lt;raw&gt;</code>部分<code>data</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>前端必须指定数据的字节数。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'data' SP &lt;count&gt; LF        &lt;raw&gt; LF?</pre></div></div><div class="doc-postil"><div class="c-markdown"><p><code>&lt;count&gt;</code>确切的字节数出现在哪里<code>&lt;raw&gt;</code>。值<code>&lt;count&gt;</code>用 ASCII 十进制整数表示。所述<code>LF</code>的任一侧<code>&lt;raw&gt;</code>不包含在<code>&lt;count&gt;</code>,并且将不被包括在导入的数据。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>LF</code>之后<code>&lt;raw&gt;</code>是可选的它使用的需要但建议。总是包含它使得调试快速导入流变得更容易因为下一个命令总是从下一行的第0列开始即使<code>&lt;raw&gt;</code>没有结束<code>LF</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>Delimited format</p></div></div><div class="doc-postil"><div class="c-markdown"><p>分隔符字符串用于标记数据的结尾。快速导入将通过搜索分隔符来计算长度。这种格式主要用于测试,不建议用于真实数据。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'data' SP '&lt;&lt;' &lt;delim&gt; LF        &lt;raw&gt; LF        &lt;delim&gt; LF
        LF?</pre></div></div><div class="doc-postil"><div class="c-markdown"><p><code>&lt;delim&gt;</code>选择的分隔符字符串在哪里。字符串<code>&lt;delim&gt;</code>不能出现在一行内<code>&lt;raw&gt;</code>,否则快速导入会认为数据比实际更早结束。<code>LF</code>立即尾随<code>&lt;raw&gt;</code>的一部分<code>&lt;raw&gt;</code>。这是分隔格式的限制之一不可能提供没有LF作为其最后一个字节的数据块。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>LF</code><code>&lt;delim&gt; LF</code>是可选的(它用于需要)。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3><code>checkpoint</code></h3></div></div><div class="doc-postil"><div class="c-markdown"><p>强制快速导入以关闭当前 packfile启动一个新文件并保存所有当前分支引用标记和标记。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'checkpoint' LF
        LF?</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>请注意,当前包文件达到--max-pack-size 或4 GiB 时,快速导入会自动切换包文件,无论哪个限制较小。在自动打包文件切换期间,快速导入不会更新分支引用,标记或标记。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>由于<code>checkpoint</code>需要大量的CPU时间和磁盘 IO为了计算总体包 SHA-1 校验和,生成相应的索引文件并更新参考文件),单个<code>checkpoint</code>命令可以轻松完成几分钟。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>前端可能会选择在非常大且长时间运行的导入期间发出检查点,或者当他们需要允许其他 Git 进程访问分支时。但是考虑到一个30 GiB Subversion 版本库可以在大约3小时内通过快速导入加载到Git中显式检查点可能不是必需的。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>LF</code>命令之后是可选的(它曾经是必需的)。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3><code>progress</code></h3></div></div><div class="doc-postil"><div class="c-markdown"><p>当从输入流处理命令<code>progress</code>时,导致 fast-import 将未修改的整行打印到其标准输出通道文件描述符1。命令对当前导入或任何快速导入的内部状态都没有影响。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'progress' SP &lt;any&gt; LF
        LF?</pre></div></div><div class="doc-postil"><div class="c-markdown"><p><code>&lt;any&gt;</code>命令的一部分可能包含任何不包含的字节序列<code>LF</code>。该<code>LF</code>命令后是可选的。呼叫者可能希望通过 sed 等工具处理输出,以删除线路的前端部分,例如:</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">frontend | git fast-import | sed 's/^progress //'</pre></div></div><div class="doc-postil"><div class="c-markdown"><p><code>checkpoint</code>之后立即发出命令<code>progress</code>通知阅将读器何时完成<code>checkpoint</code>,并且它可以安全地访问快速更新的参考文献。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3><code>get-mark</code></h3></div></div><div class="doc-postil"><div class="c-markdown"><p>导致 fast-import 将与标记对应的 SHA-1 打印到标准输出或先前以<code>--cat-blob-fd</code>参数排列的文件描述符。该命令对当前的导入没有影响; 其目的是检索稍后提交的 SHA-1 可能希望在其提交消息中引用的 SHA-1 。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'get-mark' SP ':' &lt;idnum&gt; LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>命令可以在接受评论的流中的任何地方使用。特别是,<code>get-mark</code>命令可以在提交过程中使用,但不能在<code>data</code>命令中使用。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>有关如何安全读取此输出的详细信息,请参阅下面的“对命令的响应”。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3><code>cat-blob</code></h3></div></div><div class="doc-postil"><div class="c-markdown"><p>导致 fast-import 将一个 blob 打印到先前按照<code>--cat-blob-fd</code>参数排列的文件描述符中。该命令对当前的导入没有影响; 其主要目的是检索可能位于快速导入内存中但不能从目标存储库访问的 Blob 。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'cat-blob' SP &lt;dataref&gt; LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p><code>&lt;dataref&gt;</code>可以是<code>:&lt;idnum&gt;</code>之前设置的标记引用(),也可以是已存在或可以写入的 Git blob 的完整40字节 SHA-1。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>输出使用与以下相同的格式<code>git cat-file --batch</code></p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">&lt;sha1&gt; SP 'blob' SP &lt;size&gt; LF&lt;contents&gt; LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>命令可以在接受评论的流中的任何地方使用。特别是,<code>cat-blob</code>命令可以在提交过程中使用,但不能在<code>data</code>命令中使用。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>有关如何安全读取此输出的详细信息,请参阅下面的“对命令的响应”。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3><code>ls</code></h3></div></div><div class="doc-postil"><div class="c-markdown"><p>在先前按<code>--cat-blob-fd</code>参数排列的文件描述符的路径上打印关于对象的信息。这允许从活动提交with <code>cat-blob</code>)中打印
blob或者复制之前提交中的blob或树以用于当前提交with <code>filemodify</code>)。</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>ls</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>commit</code>。该路径在快速导入的活动提交中命名目录条目。在这种情况下必须引用路径。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'ls' SP &lt;path&gt; LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>从命名树中读取</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>&lt;dataref&gt;</code>可以是标记引用(<code>:&lt;idnum&gt;</code>),也可以是预先存在或等待写入的 Git 标记提交或树对象的完整40字节 SHA-1。该路径相对于名为的树的顶层<code>&lt;dataref&gt;</code></p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'ls' SP &lt;dataref&gt; SP &lt;path&gt; LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>请参阅<code>filemodify</code>上面的详细说明<code>&lt;path&gt;</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>输出使用与以下相同的格式<code>git ls-tree &lt;tree&gt; -- &lt;path&gt;</code></p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">&lt;mode&gt; SP ('blob' | 'tree' | 'commit') SP &lt;dataref&gt; HT &lt;path&gt; LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>&lt;dataref&gt;代表斑点、树,或在&lt;路径&gt; commit 对象,并且可以在稍后被用于<code>get-mark</code><code>cat-blob</code><code>filemodify</code>,或<code>ls</code>命令。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果在路径上没有文件或子树,<code>git fast-import</code>则会报告</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">missing SP &lt;path&gt; LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>有关如何安全读取此输出的详细信息,请参阅下面的“对命令的响应”。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3><code>feature</code></h3></div></div><div class="doc-postil"><div class="c-markdown"><p>要求快速导入支持指定的功能,或者如果不支持则中止。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">        'feature' SP &lt;feature&gt; ('=' &lt;argument&gt;)? LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>命令的&lt;feature&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>--</code>传递带有前导的相应命令行选项一样(请参阅上面的 OPTIONS</p></div></div><div class="doc-postil"><div class="c-markdown"><p>import-marks   import-marks-if-exists</p></div></div><div class="doc-postil"><div class="c-markdown"><p>与--import-marks一样除了两个方面首先每个流只能使用一个“功能 import-marks” 或“ feature import-marks-if-exists ”命令; 第二,--import-marks =或--import-marks-if-exists 命令行选项将覆盖流中的任何“特征”命令; 第三,“功能 import-marks-if-exists” 就像一个相应的命令行选项,悄无声息地跳过一个不存在的文件。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>get-mark   cat-blob   ls</p></div></div><div class="doc-postil"><div class="c-markdown"><p>要求后端支撑<code>get-mark</code><code>cat-blob</code>或者<code>ls</code>分别命令。不支持指定命令的快速导入版本将退出并显示一条消息。这样可以提前清除导入错误并显示明确的消息,而不会在检测到不支持的命令之前浪费导入的早期时间。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>notes</p></div></div><div class="doc-postil"><div class="c-markdown"><p>要求后端支持<code>notemodify</code>命令的N<code>commit</code>命令。快速导入不支持笔记的版本将退出,并显示一条消息。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>done</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果流没有<code>done</code>命令而结束,则返回错误。如果没有此功能,导致前端在流中便利点突然结束的错误可能无法检测到。例如,如果导入前端在中间操作中死掉,而在其下级 git 快速导入实例中未发出 SIGTERM 或 SIGKILL则可能发生这种情况。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3><code>option</code></h3></div></div><div class="doc-postil"><div class="c-markdown"><p>处理指定的选项,以便 git fast-import 以符合前端需求的方式运行。请注意,前端指定的选项将被用户可能指定的用于快速导入自身的任何选项覆盖。</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">    'option' SP &lt;option&gt; LF</pre></div></div><div class="doc-postil"><div class="c-markdown"><p><code>&lt;option&gt;</code>命令的一部分可能包含 OPTIONS 部分中列出的任何不改变导入语义的选项,没有前导<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>以下命令行选项更改导入语义,因此可能不会作为选项传递:</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>date-format</p></li><li><p>import-marks</p></li><li><p>export-marks</p></li><li><p>cat-blob-fd</p></li><li><p>force</p></li></ul></div></div><div class="doc-postil"><div class="c-markdown"><h3><code>done</code></h3></div></div><div class="doc-postil"><div class="c-markdown"><p>如果<code>done</code>功能未被使用,则视为已读取 EOF 。这可以用来告诉快速导入提前完成。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果<code>--done</code>命令行选项或<code>feature done</code>命令正在使用,则该<code>done</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>然而,对于某些前端,能够从当前存储库更新数据时(例如,当源材料按照要应用于先前导入的对象的修补程序描述对象时)读取数据很有用。这可以通过连接前端和通过双向管道快速导入来完成:</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">mkfifo fast-import-output
frontend &lt;fast-import-output |git fast-import &gt;fast-import-output</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>一个前端设置了这种方式可以使用<code>progress</code><code>get-mark</code><code>ls</code>,和<code>cat-blob</code>命令来读取从正在进行的进口信息。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>为了避免死锁,例如前端必须完全消耗任何未决的输出<code>progress</code><code>ls</code><code>get-mark</code>,和<code>cat-blob</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 存储库顶层创建崩溃报告。崩溃报告包含内部快速导入状态的快照以及导致崩溃的最新命令。</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>一个崩溃示例:</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">$ cat &gt;in &lt;&lt;END_OF_INPUT
# my very first test commit
commit refs/heads/master
committer Shawn O. Pearce &lt;spearce&gt; 19283 -0400# who is that guy anyway?data &lt;&lt;EOFthis is my commit
EOF
M 644 inline .gitignore
data &lt;&lt;EOF.gitignore
EOF
M 777 inline bob
END_OF_INPUT</pre></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">$ git fast-import &lt;infatal: Corrupt mode: M 777 inline bob
fast-import: dumping crash report to .git/fast_import_crash_8434</pre></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">$ cat .git/fast_import_crash_8434
fast-import crash report:
    fast-import process: 8434
    parent process     : 1391
    at Sat Sep 1 00:58:12 2007</pre></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">fatal: Corrupt mode: M 777 inline bob</pre></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">Most Recent Commands Before Crash---------------------------------
  # my very first test commit
  commit refs/heads/master
  committer Shawn O. Pearce &lt;spearce&gt; 19283 -0400
  # who is that guy anyway?
  data &lt;&lt;EOF
  M 644 inline .gitignore
  data &lt;&lt;EOF* M 777 inline bob</pre></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">Active Branch LRU-----------------
    active_branches = 1 cur, 5 max</pre></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">pos  clock name~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 1)      0 refs/heads/master</pre></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">Inactive Branches-----------------refs/heads/master:
  status      : active loaded dirty
  tip commit  : 0000000000000000000000000000000000000000
  old tree    : 0000000000000000000000000000000000000000
  cur tree    : 0000000000000000000000000000000000000000
  commit clock: 0
  last pack   :</pre></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">-------------------END OF CRASH REPORT</pre></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"><h3>每个提交使用一个标记</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>在执行存储库转换时,请为每个提交(<code>mark :&lt;n&gt;</code>)使用一个唯一标记,并在命令行上提供--export-marks 选项。快速导入会转储一个文件,其中列出了每个标记以及与其对应的 Git 对象
SHA-1。如果前端可以将标记绑定回源存储库那么通过将每个
Git 提交与相应的源修订版进行比较,可以很容易地验证导入的准确性和完整性。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>来自诸如 Perforce 或 Subversion 之类的系统应该非常简单,因为快速导入标记也可以是 Perforce 变更集编号或 Subversion 修订版编号。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>Freely Skip Around Branches</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>在进口期间,不要试图优化前端来一次坚持一个分支。虽然这样做对于快速导入可能会稍微快一些,但这往往会显着增加前端代码的复杂性。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>内部快速导入的分支 LRU 往往表现得非常好,激活非活动分支的成本非常低,以至于在分支间跳动几乎不会影响导入性能。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>Handling Renames</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>在导入重命名文件或目录时只需删除旧名称并在相应的提交期间修改新名称即可。Git 会在事后执行重命名检测,而不是在提交期间显式检测。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>使用标签修复分支</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>一些其他 SCM 系统允许用户从不同于提交/变更集的多个文件创建标签。或者创建标签,这些标签是存储库中可用文件的子集。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果不进行至少一次“修复”文件以匹配标签内容的提交,那么将这些标签原样导入 Git 是不可能的。使用 fast-import <code>reset</code>命令将正常分支空间外的虚拟分支重置为标记的基本提交,然后提交一个或多个文件修复提交,最后标记虚拟分支。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>例如,因为所有正常的分支都<code>refs/heads/</code>以标签修正分支的名字存储<code>TAG_FIXUP</code>。这样,导入器使用的 fixup 分支不可能与从源导入的实际分支产生命名空间冲突(该名称<code>TAG_FIXUP</code>不是<code>refs/heads/TAG_FIXUP</code>)。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>在提交 fixup 时,考虑使用<code>merge</code>将提供文件修订的提交连接到
fixup 分支。这样做可以让工具<code>git blame</code>跟踪真实的提交历史记录并正确注释源文件。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>在快速导入终止后,前端将需要<code>rm .git/TAG_FIXUP</code>去除虚拟分支。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>立即导入,稍后重新打包</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>只要快速导入完成Git 存储库就完全有效并可以使用。通常这只需要很短的时间即使是相当大的项目100,000+次提交)。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>但是重新包装存储库对于提高数据本地化和访问性能是必需的。它也可能需要数小时才能完成大型项目(特别是如果使用-f和大型窗口参数。由于重新包装可以安全地与读者和作者一起运行因此在后台运行重新包装并在完成时让它完成。没有理由等待探索你的新 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>如果您要重新包装非常旧的导入数据(例如比去年早),请考虑花费一些额外的 CPU 时间并在运行时提供--window = 50或更高<code>git repack</code>。这将花费更长时间,但也会产生一个较小的 packfile。您只需花费一次工作量而使用您项目的每个人都将受益于较小的存储库。</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>progress</code>消息来快速导入。这些消息的内容完全是自由格式,因此每次当前提交日期进入下个月时,一个建议就是输出当前的月份和年份。知道有多少数据流已被处理,您的用户会感觉更好。</p></div></div><div class="doc-postil"><div class="c-markdown"><h2>Packfile优化</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>当快速打包 blob 时import 总是试图对最后一个 blob 进行分层。除非前端特别安排,否则这可能不会是同一文件的先前版本,因此生成的增量不会尽可能小。生成的 packfile 将被压缩,但不会是最佳的。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>有效访问单个文件的所有修订(例如读取 RCS / CVSv 文件)的前端可以选择将该文件的所有修订作为一系列连续<code>blob</code>命令提供。这允许快速导入将不同的文件修订彼此分开,从而节省最终包文件中的空间。标记可用于稍后在一系列<code>commit</code>命令中识别单个文件修订版。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>通过快速导入创建的包文件不会鼓励良好的磁盘访问模式。这是由于快速导入将数据按标准输入接收的顺序写入数据,而 Git 通常会在数据包文件中组织数据以使最新当前提示数据出现在历史数据之前。Git 还将提交进行集群,通过更好的缓存局部性加快修订遍历。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>出于这个原因,强烈建议用户在快速导入完成后使用<code>git repack -a -d</code>重新打包存储库,以便 Git 能够重新组织文件包以加快数据访问速度。如果 blob deltas 不理想(参见上文),那么添加<code>-f</code>选项以强制所有delta的重新计算可以显着减少最终的 packfil e 大小小30-50可能非常典型</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 的关键部分一样,快速导入使用自己的内存分配器来分摊与 malloc 相关的任何开销。在实践中,由于使用大块分配,快速导入倾向于将任何 malloc 开销分摊到0。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>每个对象</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>快速导入为在此执行中写入的每个对象维护一个内存中结构。在32位系统上结构为32字节在64位系统上结构为40字节由于指针大小较大。除非快速导入终止否则表中的对象不会解除分配。在32位系统上导入200万个对象需要大约64 MiB 的内存。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>对象表实际上是一个在对象名称(唯一的 SHA-1上键入的散列表。此存储配置允许快速导入重用现有或已写入的对象并避免将重复项写入输出包文件。重复的斑点在导入中非常常见通常是由于源中的分支合并。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>每个标记</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>标记存储在稀疏数组中每个标记使用1个指针4个字节或8个字节取决于指针大小。虽然数组很稀疏但前端仍强烈建议使用1到 n 之间的标记,其中 n 是此导入所需的标记总数。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>每个分支</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>分支被分类为活动和非活动。这两个类的内存使用情况明显不同。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>非活动分支存储在使用96或120个字节分别为32位或64位系统的结构中以及每个分支的分支名称长度通常小于200字节。快速导入可轻松处理 2M 以下内存中多达10,000个不活动的分支。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>活动分支与非活动分支具有相同的开销,但也包含该分支上最近修改的每个树的副本。如果子树<code>include</code>自分支变为活动状态以来未被修改,则其内容不会被加载到内存中,但如果子树<code>src</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>基于简单的最近最少使用的算法快速导入会自动将活动分支移至非活动状态。LRU链在每个<code>commit</code>命令上更新。使用 --active-branches = 可以在命令行上增加或减少活动分支的最大数量。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>每个活动树</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>又名目录在其条目所需内存的顶部只使用12个字节的内存请参阅下面的“每个活动文件”。一棵树的成本几乎为零因为它的开销分摊在单个文件条目上。</p></div></div><div class="doc-postil"><div class="c-markdown"><h3>每个活动文件条目</h3></div></div><div class="doc-postil"><div class="c-markdown"><p>Files (and pointers to subtrees) within active trees require 52 or 64 bytes (32/64 bit platforms) per entry. To conserve space, file and tree names are pooled in a common string table, allowing the filename “Makefile” to use just 16 bytes (after including the string header overhead) no matter how many times it occurs within the project.</p></div></div><div class="doc-postil"><div class="c-markdown"><p>活动分支 LRU 与文件名字符串池和子树的延迟加载结合使用可以在非常有限的内存占用每个活动分支小于2.7 MiB的情况下快速导入以有效导入2,000+个分支和45,114+个文件的项目。</p></div></div><div class="doc-postil"><div class="c-markdown"><h2>信号</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>向进程发送 <strong>SIGUSR1 </strong>可以<code>git fast-import</code>提前结束当前的
packfile模拟一条<code>checkpoint</code>命令。不耐烦的操作员可以使用此工具来查看正在进行的导入中的对象和引用,但需要花费一些额外的运行时间和更差的压缩。</p></div></div></div>