git本地分支和stash内容报错消失

本地一个长期更新的项目,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:

  1. 查看 .git/objects 文件夹, 发现提交都在, 说明有救

  2. ls .git/refs/heads 文件夹, 发现自己的project-dev分支不见了.

  3. 平常我都是在secureCRT环境下作业, 并自动保存操作记录. 所以,很容易通过 grep -rn 'git log’找回原来提交的commit信息. 于是, 找到project-dev分支的最新的提交commit id是1f37a1b5706b3877c693bab220a31d312043fc1c.

  4. 于是执行 vi .git/refs/heads/project-dev, 并把1f37a1b5706b3877c693bab220a31d312043fc1c保存在此文件中.

  5. git log和git branch -v, 原来提交信息都回来了.

二. 解决git stash list内容不见的问题.

  1. 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内容看看, 正确.

  1. 再次执行以下指令保存此stash为diff文件:
git show 8866f78b20047093ff8d1a517868ccce688a5c4b > wifi.bt.diff
  1. 最后, 执行git apply打入diff文件.
git apply wifi.bt.diff
  1. 对其他想保存的stash id内容做同样的操作.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 当使用git stash pop命令恢复内容时,有可能会遇到报错的情况。其中一种可能的报错是"needs merge unable to refresh index"。这个错误通常是由于在存储stash时没有使用"-a"选项导致的。这意味着新增加的文件没有被存储为stash。当你在另一个分支上进行修改后切换回来并尝试恢复内容时,就会出现这个错误。为了解决这个问题,你可以先使用git stash apply命令来恢复内容,然后手动解决冲突并提交修改。另外,还有一种报错是"Your local changes to the following files would be overwritten by merge"。这个错误通常是在再次提交代码时出现的。它表示你的本地修改与合并时的文件冲突,需要先提交或存储这些修改,然后再进行合并操作。你可以使用git stash命令来存储修改,然后再进行合并操作。 #### 引用[.reference_title] - *1* *2* [git statsh命令报错解决](https://blog.csdn.net/weixin_33858249/article/details/86258956)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [[已解决]Git stash pop 异常](https://blog.csdn.net/qq_43020525/article/details/94197480)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值