在使用 git add -p 对索引添加一些更改后,我发布了一个 git stash 但忘记添加 --keep-index。然后我就傻傻的做了一个git stash pop,我对索引的修改都没有了。有没有办法将索引恢复到git stash之前的状态?
最佳答案
当你刚刚完成 git stash pop
时,输出的最后一行是:
Dropped refs/stash@{0} (ca82a6dff817ec66f44342007202690a93763949)
如果您丢失了它,请参阅 How to recover a dropped stash in Git?找到提交哈希。
一旦你有了哈希,要么:
删除所有当前更改(已应用的存储):
git reset --hard
然后使用其 id 重新应用存储,这次使用索引:
git stash apply ca82a6d --index
只重置索引,这里的重点是索引被保存为存储的第二个父级:
git reset ca82a6d^2 .
注意末尾的点。如果您不指定它,它还会将 HEAD 移动到索引(索引将显示为提交)。在这种情况下,运行
git reset --soft HEAD@{1}
将 HEAD 返回到之前的位置。
关于git - 如何在 git stash/git stash pop 之后恢复索引?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14264467/