我想知道是否可以从git stash中提取单个文件或diff文件,而不会弹出存储变更集。
任何人都可以提供一些关于此的建议/想法吗?
#1楼
您可以使用“ git show stash@{0} ”获取存储的差异(或者无论存储的数量是什么;请参阅“git stash list”)。 为单个文件提取diff的部分很容易。
#2楼
如果您使用git stash apply而不是git stash pop ,它会将存储应用于您的工作树但仍保留存储。
完成此操作后,您可以add / commit所需的文件,然后重置其余更改。
#3楼
在git stash手册页上,您可以阅读(在“讨论”部分,在“选项”描述之后):
存储表示为提交,其树记录工作目录的状态,其第一个父节点是创建存储时HEAD的提交。
因此,您可以将stash(例如stash@{0}是第一个/最顶层的存储)视为合并提交,并使用:
$ git diff stash@{0}^1 stash@{0} --
说明: stash@{0}^1表示给定存储的第一个父节点,如上面的解释中所述,是存储更改的提交。 我们使用这种形式的“git diff”(有两次提交),因为stash@{0} / refs/stash是一个合并提交,我们必须告诉git我们要对哪个父进行区分。 更神秘:
$ git diff stash@{0}^! --
也应该工作(有关rev^!语法的解释,请参阅git rev-parse手册页,在“指定范围”部分)。
同样,