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

12 lines
25 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>Name</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>git-commit  - 记录对存储库的更改</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 commit [-a | --interactive | --patch] [-s] [-v] [-u&lt;mode&gt;] [--amend]           [--dry-run] [(-c | -C | --fixup | --squash) &lt;commit&gt;]           [-F &lt;file&gt; | -m &lt;msg&gt;] [--reset-author] [--allow-empty]           [--allow-empty-message] [--no-verify] [-e] [--author=&lt;author&gt;]           [--date=&lt;date&gt;] [--cleanup=&lt;mode&gt;] [--[no-]status]           [-i | -o] [-S[&lt;keyid&gt;]] [--] [&lt;file&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>在新提交中存储索引的当前内容以及来自描述更改的用户的日志消息。</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>git add</code>在使用<code>commit</code>命令之前使用增量“增加”索引更改(注意:即使修改过的文件也必须“添加”);</p></li></ol></div></div><div class="doc-postil"><div class="c-markdown"><p>2. 通过<code>git rm</code>删除从工作树和索引文件,再次使用前<code>commit</code>命令;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>3 . 通过将文件列为参数<code>commit</code>(不带--interactive或--patch开关在这种情况下提交将忽略在索引中执行的更改而是记录列出的文件的当前内容必须已知GIT;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>4 . 通过使用带<code>commit</code>命令的-a开关自动从所有已知文件即索引中已列出的所有文件中“添加”更改并自动从索引中删除工作树中的“rm”文件然后执行实际提交;</p></div></div><div class="doc-postil"><div class="c-markdown"><p>5. 通过使用--interactive或--patch开关和<code>commit</code>命令在完成操作之前除索引中的内容之外逐个决定哪些文件或块应该是提交的一部分。请参阅git-add [1]的“交互模式”部分了解如何操作这些模式。该<code>--dry-run</code>选项可用于通过给出相同的一组参数(选项和路径)。如果你提交了一个提交,然后在那之后立即发现一个错误,你可以用它来恢复<code>git reset</code>.Options -a --all告诉命令自动对已被修改和删除的文件进行分段但没有告知Git的新文件不受影响。-p --patch使用交互式补丁选择界面来选择要提交的更改。有关详细信息请参阅git-add [1]。-C &lt;commit&gt; --reuse-message = &lt;commit&gt;取一个现有的提交对象,并在创建提交时重用日志消息和作者信息(包括时间戳)。-c &lt;commit&gt; --reedit-message = &lt;commit&gt;好像<code>-C</code>,但是<code>-c</code>调用了编辑器,以便用户可以进一步编辑提交消息。--fixup = &lt;commit&gt;构造一个提交消息以供使用<code>rebase --autosquash</code>。提交消息将成为指定提交的主题行其前缀为“fixup”。有关详细信息请参阅git-rebase [1]。--squash = &lt;commit&gt;构造一个提交消息以供使用<code>rebase --autosquash</code>。提交消息主题行取自指定的提交前缀为“squash”。可以与其他提交消息选项<code>-m</code>/ <code>-c</code>/ <code>-C</code>/ <code>-F</code>一起使用。有关详细信息请参阅git-rebase [1]。--reset-author当与-C / -c /  - 修改选项一起使用时,或者在冲突樱桃挑选后提交时,声明结果提交的作者现在属于提交者。这也会更新作者的时间戳。 -  short当进行干运行时以短格式输出输出。有关详细信息请参阅git-status [1]。暗示<code>--dry-run</code>。--branch甚至以短格式显示分支和跟踪信息。 - 陶瓷当进行干式运行时请以陶瓷准备好的格式输出。有关详细信息请参阅git-status [1]。意味着<code>--dry-run</code>。 - 长时间运行时,以长格式输出。意味着<code>--dry-run</code>。-z --null当显示<code>short</code><code>porcelain</code>状态输出时逐字打印文件名并用NUL而不是LF结束输入。如果没有给出格式则表示<code>--porcelain</code>输出格式。如果没有这个<code>-z</code>选项,带有“不寻常”字符的文件名将按照配置变量的说明引用<code>core.quotePath</code>请参阅git-config [1])。-F &lt;file&gt; --file = &lt;file&gt;从给定文件中获取提交消息。使用<code>-</code>从标准输入读取消息。--author = &lt;author&gt;覆盖提交作者。使用标准<code>A U Thor &lt;author@example.com&gt;</code>格式指定明确的作者。否则&lt;author&gt;被认为是一个模式用于搜索该作者现有的提交即rev-list --all -i --author = &lt;author&gt;; 然后从第一个找到的提交中复制提交作者。--date = &lt;date&gt;覆盖提交中使用的作者日期。-m &lt;msg&gt; --message = &lt;msg&gt;使用给定的&lt;msg&gt;作为提交消息。如果<code>-m</code>给出了多个选项,则它们的值被连接为单独的段落。-t &lt;file&gt; --template = &lt;file&gt;编辑提交信息时,用给定文件中的内容启动编辑器。该<code>commit.template</code>配置变量通常用于隐式地将该选项赋予命令。这种机制可以被那些想要引导参与者提供什么信息以什么顺序写在消息中的暗示的项目使用。如果用户退出编辑器而不编辑消息,则提交将中止。当通过其他方式给出消息时,例如使用<code>-m</code><code>-F</code>选项,这不起作用。-s --signoff在提交日志消息结尾添加Sign-off-by行。签名的含义取决于项目但它通常证明提交者有权根据相同的许可证提交此项工作并同意开发者原始证书参见http://developercertificate.org/)。了解更多信息)。-n --no-verify这个选项绕过预先提交和提交msg钩子。另见githooks [5]。--allow-empty通常记录与其唯一父提交完全相同的提交是一个错误并且该命令阻止您进行此类提交。此选项绕过安全性主要供外国SCM接口脚本使用。--allow-empty-message与--allow-empty一样此命令主要供外部SCM接口脚本使用。它允许你使用空的提交消息创建一个提交而不使用像git-commit-tree [1]这样的管道命令。--cleanup = &lt;mode&gt;该选项确定在提交之前应如何清理提供的提交消息。该<code>&lt;mode&gt;</code><code>strip</code><code>whitespace</code><code>verbatim</code><code>scissors</code>或者<code>default</code>。带剥离前导和尾随空行,尾随空白,评论和折叠连续的空行。空格与#<code>strip</code>注释相同,不会被删除。逐字不要改变信息。剪刀<code>whitespace</code>除了从下面找到的行(包括下面的行)中的所有内容被截断之后,如果要编辑的消息都一样。“ <code>#</code>”可以用core.commentChar自定义。------------------------&gt; 8 ------------- ----------- default与<code>strip</code>消息编辑相同。否则<code>whitespace</code>。默认值可以通过<code>commit.cleanup</code>配置变量进行更改请参阅git-config [1])。-e --edit从文件中提取的消息<code>-F</code>,命令行<code>-m</code>和从提交对象中提取的消息<code>-C</code>通常用作未修改的提交日志消息。该选项可让您进一步编辑从这些源获取的消息。--no-edit在不启动编辑器的情况下使用选定的提交消息。例如<code>git commit --amend --no-edit</code>修改提交而不更改其提交消息。--amend通过创建一个新的提交来替换当前分支的提示。记录的树像往常一样准备包括<code>-i</code><code>-o</code>选项和显式pathspec的效果并且当从命令行中未指定其他消息时将使用原始提交的消息作为起点而不是空消息通过选项<code>-m</code><code>-F</code><code>-c</code>,等新犯有相同的父母和作者作为当前一个(在<code>--reset-author</code>选项可以反制这个)。它是一个粗略的等价物:$ git reset --soft HEAD ^ $ ...做一些其他的事情来得到正确的树... $ git commit -c ORIG_HEADbut可以用来修改一个合并提交。如果您修改已发布的提交您应该了解重写历史记录的含义。请参阅git-rebase [1]中的“从上行链路重新启动”部分)。--no-post-rewrite绕过重写后挂钩。-i --include在到目前为止的阶段性内容提交之前还要在命令行上给出路径的内容。这通常不是你想要的除非你正在完成一个冲突的合并。-o  - 仅通过获取命令行中指定路径的更新工作树内容来进行提交,无视任何已经为其他路径上演的内容。这是默认的操作模式<code>git commit</code>如果在命令行上给出了任何路径,在这种情况下,该选项可以省略。如果此选项与“一起指定” <code>--amend</code>,则不需要指定任何路径,可以使用这些路径修改上次提交而不提交已经执行的更改。如果与<code>--allow-empty</code>路径一起使用也不是必需的,并且将创建一个空的提交。-u &lt;mode&gt; --untracked-files = &lt;mode&gt;显示未跟踪的文件。模式参数是可选的(默认为<code>all</code>),用于指定处理未跟踪的文件; 当-u未使用时默认值是<code>normal</code>,即显示未跟踪的文件和目录。可能的选项是:</p></div></div><div class="doc-postil"><div class="c-markdown"><ol class="ol-level-0 list-paddingleft-2"><li><p><code>no</code>  - 不显示未跟踪的文件</p></li></ol></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>normal</code>  - 显示未跟踪的文件和目录</p></li></ul></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>all</code>  - 还显示未跟踪目录中的单个文件。</p></li></ul></div></div><div class="doc-postil"><div class="c-markdown"><p>可以使用git-config [1]中记录的status.showUntrackedFiles配置变量来更改默认值。</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>显示HEAD提交与提交消息模板底部提交的内容之间的统一差异以帮助用户通过提醒提交具有哪些更改来描述提交。请注意此差异输出的前面没有前缀<code>#</code>。这个差异不会是提交消息的一部分。请参阅<code>commit.verbose</code>git-config [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>-q   --quiet</p></div></div><div class="doc-postil"><div class="c-markdown"><p>Suppress commit summary message.</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--dry-run</p></div></div><div class="doc-postil"><div class="c-markdown"><p>不要创建提交,而是显示要提交的路径列表,包含未提交的本地更改的路径以及未跟踪的路径。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--status</p></div></div><div class="doc-postil"><div class="c-markdown"><p>使用编辑器准备提交消息时在提交消息模板中包含git-status [1]的输出。默认为打开但可用于覆盖配置变量commit.status。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--no-status</p></div></div><div class="doc-postil"><div class="c-markdown"><p>使用编辑器准备默认提交消息时不要在提交消息模板中包含git-status [1]的输出。</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标志提交<code>keyid</code>参数是可选的,并且默认为提交者身份; 如果指定,它必须粘贴到选项没有空格。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>--no-gpg-sign</p></div></div><div class="doc-postil"><div class="c-markdown"><p><code>commit.gpgSign</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"><p>&lt;file&gt;</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>GIT_AUTHOR_DATE</code><code>GIT_COMMITTER_DATE</code>环境变量和<code>--date</code>选项支持以下日期格式:</p></div></div><div class="doc-postil"><div class="c-markdown"><p>Git内部格式</p></div></div><div class="doc-postil"><div class="c-markdown"><p>这是<code>&lt;unix timestamp&gt; &lt;time zone offset&gt;</code>,在这里<code>&lt;unix timestamp&gt;</code>是从unix新纪元的秒数。<code>&lt;time zone offset&gt;</code>是UTC的正数或负数偏移量。例如CET比UTC早1小时<code>+0100</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>例如RFC 2822所描述的标准电子邮件格式<code>Thu, 07 Apr 2005 22:13:13 +0200</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>ISO 8601</p></div></div><div class="doc-postil"><div class="c-markdown"><p>例如ISO 8601标准规定的时间和日期<code>2005-04-07T22:13:13</code>。解析器也接受一个空格而不是<code>T</code>字符。</p></div></div><div class="doc-postil"><div class="c-markdown"><div class="table-wrapper"><table><thead><tr class="firstRow"><th style="text-align: left;"><div class="table-header"><p>Note</p></div></th><th style="text-align: left;"><div class="table-header"><p>In addition, the date part is accepted in the following formats: YYYY.MM.DD, MM/DD/YYYY and DD.MM.YYYY.</p></div></th></tr></thead><tbody></tbody></table></div></div></div><div class="doc-postil"><div class="c-markdown"><h2>例子</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>在录制自己的作品时工作树中修改文件的内容将临时存储到一个名为“index”的临时区域中<code>git add</code>。一个文件只能在索引中恢复,但不能在工作树中<code>git reset HEAD -- &lt;file&gt;</code>恢复为最后一次提交的文件,这会有效地恢复<code>git add</code>并阻止对该文件的更改参与下一次提交。在使用这些命令构建要逐步提交的状态之后,<code>git commit</code>(不带任何路径名参数)用于记录迄今为止已执行的操作。这是命令的最基本形式。一个例子:</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">$ edit hello.c
$ git rm goodbye.c
$ git add hello.c
$ git commit</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>不要在每个单独更改之后登台文件,而是<code>git commit</code>要注意对在工作树中跟踪内容的文件进行更改,<code>git add</code><code>git rm</code>为您做相应的工作。也就是说,如果工作树中没有其他更改,则此示例与前面的示例执行的操作相同:</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">$ edit hello.c
$ rm goodbye.c
$ git commit -a</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>命令<code>git commit -a</code>首先查看您的工作树注意到您修改了hello.c并删除了goodbye.c并执行了必要的操作<code>git add</code><code>git rm</code>为您执行。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>在更改许多文件之后,您可以通过提供路径名来更改记录更改的顺序<code>git commit</code>。当给出路径名时,命令进行提交,只记录对指定路径所做的更改:</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">$ edit hello.c hello.h
$ git add hello.c hello.h
$ edit Makefile
$ git commit Makefile</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>这使得提交记录修改<code>Makefile</code>。所做的更改已进行<code>hello.c</code>并且<code>hello.h</code>未包含在结果提交中。然而,他们的变化并没有失去 - 他们仍然上演,只是被阻止。在上述顺序之后,如果你这样做:</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">$ git commit</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>第二次提交会记录更改<code>hello.c</code>并按<code>hello.h</code>预期进行。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>合并后(由<code>git merge</code>or 发起<code>git pull</code>)由于冲突而停止,干净合并的路径已经分阶段为您提交,并且发生冲突的路径处于未合并状态。您必须首先检查哪些路径与<code>git status</code>您的工作树中的手动修复冲突,然后像往常一样分阶段执行结果<code>git add</code></p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">$ git status | grep unmerged
unmerged: hello.c
$ edit hello.c
$ git add hello.c</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>解决冲突并分级后,<code>git ls-files -u</code>会停止提及冲突的路径。完成后,运行<code>git commit</code>以最终记录合并:</p></div></div><div class="doc-postil"><div class="c-markdown"><pre class="prism-token token language-javascript">$ git commit</pre></div></div><div class="doc-postil"><div class="c-markdown"><p>与记录您自己的更改的情况一样,您可以使用<code>-a</code>选项来保存输入。一个区别是,在合并解析期间,不能使用<code>git commit</code>路径名来更改提交更改的顺序,因为合并应该记录为单个提交。事实上,命令在给定路径名时拒绝运行(但请参阅<code>-i</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>虽然不是必需的但最好先用一个简短的少于50个字符行来概述变化然后再用空行和更彻底的描述来开始提交消息。直到提交消息中的第一个空行的文本被视为提交标题并且该标题在整个Git中使用。例如git-format-patch [1]将提交转换为电子邮件,并使用主题行上的标题和正文中的其余提交。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>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>blob对象的内容是未解释的字节序列。在核心层面没有编码翻译。</p></li></ul></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>路径名以UTF-8标准化形式C编码。这适用于树对象索引文件ref名称以及命令行参数环境变量和配置文件中的路径名<code>.git/config</code>请参阅git-config [1] gitignore [5]gitattributes [5]和gitmodules [5])。</p></li></ul></div></div><div class="doc-postil"><div class="c-markdown"><p>请注意核心级Git将路径名视为非NUL字节序列不存在路径名编码转换Mac和Windows除外。因此即使在使用传统扩展ASCII编码的平台和文件系统上使用非ASCII路径名也可以工作。但是在这些系统上创建的存储库在基于UTF-8的系统例如LinuxMacWindows上无法正常工作反之亦然。此外许多基于Git的工具只是假设路径名称为UTF-8并且无法正确显示其他编码。</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>提交日志消息通常以UTF-8编码但也支持其他扩展ASCII编码。这包括ISO-8859-xCP125x等等但是<code>not</code>UTF-16/32EBCDIC和CJK多字节编码GBKShift-JISBig5EUC-xCP9xx等等虽然我们鼓励提交日志消息以UTF-8编码核心和Git瓷器都不会强制项目上使用UTF-8。如果特定项目的所有参与者发现使用遗留编码更方便Git不会禁止它。但是有几件事要牢记。</p></li></ul></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>git commit</code>并且<code>git commit-tree</code>如果提交给它的提交日志消息看起来不像一个有效的UTF-8字符串则会发出警告除非您明确声明您的项目使用了旧版编码。说这个的方法是在<code>.git/config</code>文件中使用i18n.commitencoding ,如下所示:</p></li></ul></div></div><div class="doc-postil"><div class="c-markdown"><p>i18n         commitEncoding = ISO-8859-1</p></div></div><div class="doc-postil"><div class="c-markdown"><p>使用上述设置创建的提交对象记录<code>i18n.commitEncoding</code><code>encoding</code>标题中的值。这是为了帮助稍后看到他们的其他人。缺少这个头部意味着提交日志消息以UTF-8编码。</p></div></div><div class="doc-postil"><div class="c-markdown"><ol class="ol-level-0 list-paddingleft-2"><li><p><code>git log</code><code>git show</code><code>git blame</code><code>encoding</code>一个提交对象的报头并且尝试除非另有规定重新代码日志消息转换成UTF-8。您可以<code>i18n.logOutputEncoding</code><code>.git/config</code>文件中指定所需的输出编码,如下所示:</p></li></ol></div></div><div class="doc-postil"><div class="c-markdown"><p>i18n         logOutputEncoding = ISO-8859-1</p></div></div><div class="doc-postil"><div class="c-markdown"><p>如果您没有此配置变量,<code>i18n.commitEncoding</code>则会使用该值。</p></div></div><div class="doc-postil"><div class="c-markdown"><p>请注意在提交对象级别强制使用UTF-8时我们故意选择不重新编写提交日志消息因为重新编码为UTF-8不一定是可逆操作。</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_EDITOR</code>环境变量core.editor配置变量<code>VISUAL</code>环境变量或<code>EDITOR</code>环境变量按此顺序中进行选择。有关详细信息请参阅git-var [1]。</p></div></div><div class="doc-postil"><div class="c-markdown"><h2>Hooks</h2></div></div><div class="doc-postil"><div class="c-markdown"><p>这个命令可以运行<code>commit-msg</code><code>prepare-commit-msg</code><code>pre-commit</code><code>post-commit</code><code>post-rewrite</code>hooks。有关更多信息请参阅githooks [5]。</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_DIR/COMMIT_EDITMSG</code></p></div></div><div class="doc-postil"><div class="c-markdown"><p>文件包含正在进行的提交的提交消息。如果<code>git commit</code>在创建提交之前由于错误而退出,则用户提供的任何提交消息(例如,在编辑器会话中)将在此文件中可用,但将在下一次调用时被覆盖<code>git commit</code></p></div></div></div>