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

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


当前回答

您可以通过以下命令查看所有的存储列表:

$ git stash list

stash@{0}: WIP on dev: ddd4d75 spelling fix

stash@{1}: WIP on dev: 40e65a8 setting width for messages

......

......

......


stash@{12}: WIP on dev: 264fdab added token based auth

最新藏的是第一个。

您可以简单地选择上述列表中提供的stash的索引n,并使用以下命令查看已存储的详细信息

git stash show -p stash@{3}

同样的,

git stash show -p stash@{n}

也可以使用以下命令检查diff:

git diff HEAD stash@{n} -- /path/to/file

其他回答

是的,查看修改内容的最好方法是保存在这样的文件中:

git stash show -p stash@{0} > stash.txt

首先,我们可以使用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.

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

gitlen存储的截图

查看当前收藏列表:

git stash list

你会看到这样一个列表:

stash@{0}: WIP on ...
stash@{1}: ...
stash@{2}: ...
...

查看差异对任何这些存储:

git stash show -p stash@{n}
git stash show -p <index number of stash stack>

查找索引号:

Git藏匿清单

示例:git stash show -p 1