我进行了一些更改以提交。如何查看为下一次提交准备的所有文件的差异?有一个方便的内衬吗?
gitstatus只显示暂存文件的名称,但我想查看实际的差异。
gitdiff(1)手册页显示:
git diff[--选项][--][…]此表单用于查看相对于索引所做的更改(下一次提交的暂存区域)。换句话说,这些差异是您可以告诉git进一步添加到索引中的,但您仍然没有。您可以使用gitadd(1)暂存这些更改。
我进行了一些更改以提交。如何查看为下一次提交准备的所有文件的差异?有一个方便的内衬吗?
gitstatus只显示暂存文件的名称,但我想查看实际的差异。
gitdiff(1)手册页显示:
git diff[--选项][--][…]此表单用于查看相对于索引所做的更改(下一次提交的暂存区域)。换句话说,这些差异是您可以告诉git进一步添加到索引中的,但您仍然没有。您可以使用gitadd(1)暂存这些更改。
当前回答
简单的图形使这一点更加清晰:
差异比较
显示工作目录和索引之间的更改。这将显示已更改但未准备提交的内容。
git diff—缓存
显示索引和HEAD之间的更改(这是该分支上的最后一次提交)。这将显示已添加到索引中并为提交而暂存的内容。
git diff头
显示工作目录和HEAD之间的所有更改(包括索引中的更改)。这将显示自上次提交以来的所有更改,无论它们是否为提交而暂存。
也:
365Git上有更多细节。
其他回答
缓存对我不起作用。。。其中,灵感来自git log
gitdifforigin/<branch><branch>完成。
如果您有多个文件进行了阶段性更改,那么使用git add-i,然后选择6:diff,最后选择您感兴趣的文件可能更实用。
Emacs中的Magit模式是另一个让这变得简单的工具。它的默认视图列出了暂存和未暂存的更改。它就像类固醇上的git add-p,因为您可以使用编辑器命令轻松地分段或取消分段大块(甚至是单行代码)。了解标准的git瓷器很重要,但我很少再使用git diff缓存。
https://magit.vc/
您可以使用此命令。
git diff --cached --name-only
gitdiff的--cached选项表示获取暂存文件,--name only选项表示只获取文件的名称。
gitgui和gitcola是图形实用程序,可用于查看和操作索引。两者都包括用于暂存文件的简单视觉差异,git-cola还可以推出更复杂的并排视觉差异工具。
在如何从git中的索引中删除文件?,以及Git-GUI客户端的官方目录。