本地一个长期更新的项目,git log突然报错:
xxx@yyy:~/android/project/kernel/.git$ git log .
fatal: your current branch 'project-dev' does not have any commits yet
如果git status,发现文件全部是new状态.
如果git branch -v, 发现本地分支信息消失.
如果git stash list, 也没有任何消息.
看来, 即使git本身如此优秀, 也是避免不了他自己出错的时候-_-
一. 解决git log:
查看 .git/objects 文件夹, 发现提交都在, 说明有救
ls .git/refs/heads 文件夹, 发现自己的project-dev分支不见了.
平常我都是在secureCRT环境下作业, 并自动保存操作记录. 所以,很容易通过 grep -rn 'git log'找回原来提交的commit信息. 于是, 找到project-dev分支的最新的提交commit id是1f37a1b5706b3877c693bab220a31d312043fc1c.
于是执行 vi .git/refs/heads/project-dev, 并把1f37a1b5706b3877c693bab220a31d312043fc1c保存在此文件中.
git log和git branch -v, 原来提交信息都回来了.
二. 解决git stash list内容不见的问题.
cat .git/logs/refs/stash 文件,找到自己想要的stash id:
xxx@yyy:~/android/project/kernel$ cat .git/logs/refs/stash
0000000000000000000000000000000000000000 6d83090b5d140597866f32b5dbbca642acab3cba ... On project-dev: enable HDMI display
...//...表示省略内容
25ccdba070ac09929c6f2a1f13b7d29a4b59df5b 8866f78b20047093ff8d1a517868ccce688a5c4b ... On project-dev: wifi&bt temp
以上中, 0000000000000000000000000000000000000000是最原始的内容,不对应任何stash提交, 6d83090b5d140597866f32b5dbbca642acab3cba是第一个. 8866f78b20047093ff8d1a517868ccce688a5c4b是最后一个. 想找的内容是 "wifi&bt temp"提交的内容, 对应提交就是8866f78b20047093ff8d1a517868ccce688a5c4b.
于是, 执行git show 8866f78b20047093ff8d1a517868ccce688a5c4b内容看看, 正确.
再次执行以下指令保存此stash为diff文件:
git show 8866f78b20047093ff8d1a517868ccce688a5c4b > wifi.bt.diff
最后, 执行git apply打入diff文件.
git apply wifi.bt.diff
对其他想保存的stash id内容做同样的操作.
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 吴奇隆.2016-旅程【太阳动力】【WAV+CUE】
- 群星.2010-80S百花齐唱6CD【华纳】【WAV+CUE】
- 物华弥新迷踪盘第二十二关怎么过 迷踪盘第二十二关通关方法
- 物华弥新迷踪盘第二十三关怎么过 迷踪盘第二十三关通关方法
- 物华弥新迷踪盘第二十四关怎么过 迷踪盘第二十四关通关方法
- 龙千玉2020-出嫁[豪记][WAV+CUE]
- KOKIA-WachingfromAbove[WAV]
- 罗大佑.2022-安可曲【种子音乐】【FLAC分轨】
- 《真人快打1》“祖国人”先导预告:开打前先喝奶
- 民主的胜利!Steam开始为《地狱潜者2》超2小时玩家退款
- 《地狱潜者2》鼓励玩家打差评:这样就能和索尼谈判
- 林忆莲《十年珍藏》[WAV分轨][668M]
- 蔡琴《蔡琴经典歌曲合集》[WAV+CUE][502.6MB]
- 群星《十大发烧·靓绝男声》 3CD[APE+CUE][1.1G]
- 彭正.2024-十年【福茂】【FLAC分轨】