Undoing accidental git stash pop

前端 未结 3 687
隐瞒了意图╮
隐瞒了意图╮ 2021-01-29 23:34

I stashed some local changes before doing a complicated merge, did the merge, then stupidly forgot to commit before running git stash pop. The pop created some pro

相关标签:
3条回答
  • 2021-01-29 23:54

    From git stash --help

    Recovering stashes that were cleared/dropped erroneously
       If you mistakenly drop or clear stashes, they cannot be recovered through the normal safety mechanisms. However, you can try the
       following incantation to get a list of stashes that are still in your repository, but not reachable any more:
    
           git fsck --unreachable |
           grep commit | cut -d\  -f3 |
           xargs git log --merges --no-walk --grep=WIP
    

    This helped me better than the accepted answer with the same scenario.

    0 讨论(0)
  • 2021-01-29 23:55

    Try using How to recover a dropped stash in Git? to find the stash you popped. I think there are always two commits for a stash, since it preserves the index and the working copy (so often the index commit will be empty). Then git show them to see the diff and use patch -R to unapply them.

    0 讨论(0)
  • 2021-01-29 23:57

    If your merge was not too complicated another option would be to:

    1. Move all the changes including the merge changes back to stash using "git stash"
    2. Run the merge again and commit your changes (without the changes from the dropped stash)
    3. Run a "git stash pop" which should ignore all the changes from your previous merge since the files are identical now.

    After that you are left with only the changes from the stash you dropped too early.

    0 讨论(0)
提交回复
热议问题