git stash隐藏工作区内修改但未提交的代码,
git stash list查看stash的历史记录,
git stash clear清除所有的 stash 栈。

有时候可能不小心git stash clear掉了所有的记录,可是那些代码还有用。哎呀,杯具了!不用慌,可用下面的方法找回:

  1. 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