我想检查一个隐藏,并找出它会做出什么改变,如果我将它应用到工作树在其当前状态。

我知道我可以在stash上做一个git差异,但这向我展示了工作树和stash之间的所有差异,而我只是想知道stash应用将会改变什么。


当前回答

查看已存储更改的列表

git stash list

用于查看特定存储中更改的文件列表

git stash show -p stash@{0} --name-only

用于查看stash中的特定文件

git show stash@{0} path/to/file

其他回答

除了gitk的建议在是否可以预览隐藏内容在git?你可以安装tig并调用tig stash。这个免费/开放的控制台程序还允许你选择哪个收藏进行比较

我用这个来查看我所有的存储与颜色差异高亮(在Fedora 21):

git stash list | 
  awk -F: '{ print "\n\n\n\n"; print $0; print "\n\n"; 
  system("git -c color.ui=always stash show -p " $1); }' | 
  less -R

(改编自Git:在不应用stash的情况下查看隐藏的内容)

Git存储显示将显示您最近存储中更改的文件。您可以添加-p选项来显示差异。

git stash show -p

如果你感兴趣的存储不是最近的,那么在命令的末尾添加存储的名称:

git stash show -p stash@{2}

你可以用gitlen扩展查看VSCode中隐藏的更改

gitlen存储的截图

首先,我们可以使用git的stash列表来获取所有的stash项目:

$git stash list
stash@{0}: WIP on ...
stash@{1}: WIP on ....
stash@{2}: WIP on ...

然后我们可以使用git stash show stash@{N}来检查特定的stash N下的文件。如果我们触发它,那么我们可能会得到:

$ git stash show stash@{2}
fatal: ambiguous argument 'stash@2': unknown revision or path not in the working tree.
Use '--' to separate paths from revisions, like this:
'git <command> [<revision>...] -- [<file>...]'

原因可能是shell正在消耗花括号,git看到stash@2而不是stash@{2}。为了解决这个问题,我们需要使用单引号作为大括号:

git stash show stash@'{2'}
com/java/myproject/my-xml-impl.xml                     | 16 ++++++++--------
com/java/myproject/MyJavaClass.java                    | 16 ++++++++--------
etc.