git stash drop 误用恢复

场景

代码正在开发中不想commit,但是要切换其它分支去处理临时紧急任务,于是git stash 备份当前的工作区的内容。
切换回来时不小心使用了:git stash drop ,于是暂存的修改全部没有了。

 

方法一  知道删除的ID号

知道删除的ID号如

然后通过命令git fsck –lost-found找到最近的一些删除的提交,找到f3106e*,然后git show f3106e*查看修改情况,git stash apply f3106e*即可修复删除掉的内容了。

 

方法二  不知道删除的ID号但是大概记得自己修改了哪些内容


step1 内容存入文件

git fsck --lost-found >> 1.txt
或
git fsck --unreachable >> 2.txt 

然后两个文件的内容格式如下

git stash drop 误用恢复_第1张图片git stash drop 误用恢复_第2张图片

step2 筛选指定信息并记住ID,创建脚本快速查找

#!/bin/sh
READFILENAME="1.txt"      #上步文件名【1.txt dangling commit,2.txt对应unreachable commit】
RETFILENAME="./ret.txt"   #筛选结果文件名
while read -r line       
do 	
    VAR=`echo $line | awk '/dangling commit/ {print $3}'`
    if [ $VAR ]; then
        git show $VAR >> $RETFILENAME    
        echo "-------------------------------------\n" >>$RETFILENAME #每条记录用---分割开
    fi
done < $READFILENAME

step3 根据结果找回删除的代码

git stash drop 误用恢复_第3张图片

如我删除的是commit 8a6229188074d5ce270ac4405179323d7c01b78e

然后 git stash apply 8a6229188074d5ce270ac4405179323d7c01b78e即可

你可能感兴趣的:(Linux应用开发)