问题描述
不小心将刚stash的change删除了,导致之前的工作内容都没有了
分析和解决
方法一
通过git fsck --unreachable
或者git fsck -- lost -found
命令可以列出正常途径无法看见的节点,然后出现一个列表blob/commit/tree + 一串表示版本的字符。
由上而下可以看见最近的一次commit也就是那次stash的内容,可以通过git show "版本号"
查看确定是否是自己要找回的节点,忽略dangling blob 的类型的记录,只找 dangling commit 的记录。
确定之后用git merge “版本号”
命令即可恢复到stash之前的状态。
方法二
利用IDEA自带的功能,
- 首先右键自己的项目或某个文件夹、或者某个文件,选择Local History -> Show History
- 然后就可以看到历史记录了
- 选择对应的记录右键Revert就可以了
参考资料
Recovering stash entries that were cleared/dropped erroneously
If you mistakenly drop or clear stash entries, they cannot be recovered through the normal safety mechanisms. However, you can try the following incantation to get a list of stash entries 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
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/155691.html