git本地分支和stash内容报错消失的问题
本地一个长期更新的项目,gitlog突然报错:
xxx@yyy:~/android/project/kernel/.git$gitlog.
fatal:yourcurrentbranch'project-dev'doesnothaveanycommitsyet
如果gitstatus,发现文件全部是new状态.
如果gitbranch-v,发现本地分支信息消失.
如果gitstashlist,也没有任何消息.
看来,即使git本身如此优秀,也是避免不了他自己出错的时候-_-
一.解决gitlog:
查看.git/objects文件夹,发现提交都在,说明有救
ls.git/refs/heads文件夹,发现自己的project-dev分支不见了.
平常我都是在secureCRT环境下作业,并自动保存操作记录.所以,很容易通过grep-rn'gitlog'找回原来提交的commit信息.于是,找到project-dev分支的最新的提交commitid是1f37a1b5706b3877c693bab220a31d312043fc1c.
于是执行vi.git/refs/heads/project-dev,并把1f37a1b5706b3877c693bab220a31d312043fc1c保存在此文件中.
gitlog和gitbranch-v,原来提交信息都回来了.
二.解决gitstashlist内容不见的问题.
cat.git/logs/refs/stash文件,找到自己想要的stashid:
xxx@yyy:~/android/project/kernel$cat.git/logs/refs/stash
00000000000000000000000000000000000000006d83090b5d140597866f32b5dbbca642acab3cba... Onproject-dev:enableHDMIdisplay
...//...表示省略内容
25ccdba070ac09929c6f2a1f13b7d29a4b59df5b8866f78b20047093ff8d1a517868ccce688a5c4b... Onproject-dev:wifi&bttemp
以上中,0000000000000000000000000000000000000000是最原始的内容,不对应任何stash提交,6d83090b5d140597866f32b5dbbca642acab3cba是第一个.8866f78b20047093ff8d1a517868ccce688a5c4b是最后一个.想找的内容是"wifi&bttemp"提交的内容,对应提交就是8866f78b20047093ff8d1a517868ccce688a5c4b.
于是,执行gitshow8866f78b20047093ff8d1a517868ccce688a5c4b内容看看,正确.
再次执行以下指令保存此stash为diff文件:
gitshow8866f78b20047093ff8d1a517868ccce688a5c4b>wifi.bt.diff
最后,执行gitapply打入diff文件.
gitapplywifi.bt.diff
对其他想保存的stashid内容做同样的操作.
到此这篇关于git本地分支和stash内容报错消失的文章就介绍到这了,更多相关git本地分支和stash报错内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!