14

在使用 git add -p 对索引添加一些更改后,我发出了一个 git stash 但忘记添加 --keep-index。然后我愚蠢地做了一个 git stash pop,我对索引的所有更改都消失了。有没有办法将索引恢复到 git stash 之前的状态?

4

2 回答 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 回答