git stash
隐藏工作区内修改但未提交的代码,git stash list
查看stash
的历史记录,git stash clear
清除所有的 stash 栈。
有时候可能不小心git stash clear
掉了所有的记录,可是那些代码还有用。哎呀,杯具了!不用慌,可用下面的方法找回:
git fsck --no-reflogs 2>&1 | awk '/dangling commit/ {print $3}' | xargs git show --stat
上述命令得到了所有 dangling commit,其描述,以及修改的文件列表。
观察一下,stash
记录描述以WIP
开头(work in progress 缩写,进行中的工作),结合修改文件列表就能找到那个 commit 了。
然后执行git cherry-pick commitid
或者git stash apply commitid
命令就可以恢复了。
解析:
git fsck
找出所有 dangling 的对象,也可以不加--no-reflogs
参数。2>&1
为了隐藏烦人的错误输出,可不加。awk
过滤commit 类型,并输出 commit id 值。xargs git show --stat
对所有 commit_id 执行git show --stat
命令。
如果此方法不行,可以尝试另一种方法:git stash clear/drop 恢复
原文:https://liumengjun.github.io/2019/01/15/recover-after-git-stash-clear.html