我进行了一些更改以提交。如何查看为下一次提交准备的所有文件的差异?有一个方便的内衬吗?

gitstatus只显示暂存文件的名称,但我想查看实际的差异。

gitdiff(1)手册页显示:

git diff[--选项][--][…]此表单用于查看相对于索引所做的更改(下一次提交的暂存区域)。换句话说,这些差异是您可以告诉git进一步添加到索引中的,但您仍然没有。您可以使用gitadd(1)暂存这些更改。


当前回答

如果您的意图是将目标推送到远程回购分支,并且提交更改日志的第一次传递不完整,则可以在这样推送之前更正提交语句。

本地

…进行一些更改。。。

git diff # look at unstaged changes

git commit -am"partial description of changes"

…回忆更多提交中未提及的更改。。。

gitdifforigin/master#查看暂存但未推送的更改

…修改分段提交语句。。。

git commit --amend -m"i missed mentioning these changes ...."

git push

其他回答

Emacs中的Magit模式是另一个让这变得简单的工具。它的默认视图列出了暂存和未暂存的更改。它就像类固醇上的git add-p,因为您可以使用编辑器命令轻松地分段或取消分段大块(甚至是单行代码)。了解标准的git瓷器很重要,但我很少再使用git diff缓存。

https://magit.vc/

gitgui和gitcola是图形实用程序,可用于查看和操作索引。两者都包括用于暂存文件的简单视觉差异,git-cola还可以推出更复杂的并排视觉差异工具。

在如何从git中的索引中删除文件?,以及Git-GUI客户端的官方目录。

注意,gitstatus-v还显示了阶段性的更改!(这意味着您需要进行阶段性的--git-add--一些更改。没有阶段性的更改,没有与git-status-v的差异。自2006年2月Git 1.2.0以来,它就做到了这一点)

在其长格式(默认)中,gitstatus有一个未记录的“verbose”选项,它实际上显示了HEAD和索引之间的差异。

它将变得更加完整:请参阅“在gitdiff中显示阶段树和工作树?”(git2.3.4+,2015年第二季度):

git status -v -v

如果您有多个文件进行了阶段性更改,那么使用git add-i,然后选择6:diff,最后选择您感兴趣的文件可能更实用。

如果您的意图是将目标推送到远程回购分支,并且提交更改日志的第一次传递不完整,则可以在这样推送之前更正提交语句。

本地

…进行一些更改。。。

git diff # look at unstaged changes

git commit -am"partial description of changes"

…回忆更多提交中未提及的更改。。。

gitdifforigin/master#查看暂存但未推送的更改

…修改分段提交语句。。。

git commit --amend -m"i missed mentioning these changes ...."

git push