在使用 git add -p 对索引添加一些更改后,我发出了一个 git stash 但忘记添加 --keep-index。然后我愚蠢地做了一个 git stash pop,我对索引的所有更改都消失了。有没有办法将索引恢复到 git stash 之前的状态?
问问题
4067 次
2 回答
9
当您刚刚完成git stash pop
时,输出中的最后一行是:
Dropped refs/stash@{0} (ca82a6dff817ec66f44342007202690a93763949)
如果您丢失了它,请参阅如何在 Git 中恢复丢失的存储?找到提交哈希。
一旦你有了哈希,要么:
删除所有当前更改(应用存储):
git reset --hard
并使用其 id 重新应用存储,这次使用索引:
git stash apply ca82a6d --index
只重置索引,这里的重点是索引被保存为存储的第二个父级:
git reset ca82a6d^2 .
注意最后的点。如果您不指定它,它也会将 HEAD 移动到索引(索引将显示为提交)。在这种情况下,运行
git reset --soft HEAD@{1}
以将 HEAD 返回到之前的位置。
于 2017-10-09T21:31:25.217 回答
6
这将完成这项工作:
git stash apply --index
编辑:考虑到索引已经丢失,您应该运行 agit fsck --unreachable
并检查它提供的最新提交。您必须能够在那里看到丢失的索引。之后你就可以git cherry-pick
了。
于 2013-11-30T22:35:14.027 回答