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

作者:marsowou 时间:2023-10-19 01:48:47 

本地一个长期更新的项目,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内容做同样的操作.

来源:https://blog.csdn.net/elimio/article/details/111189950

标签:git,本地分支,stash,报错
0
投稿

猜你喜欢

  • python对象转字典的两种实现方式示例

    2023-12-06 15:47:05
  • 利用Python实现快速批量转换HEIC文件

    2022-08-01 08:41:35
  • 谈非线性任务流程的窗口打开方式

    2008-08-28 12:47:00
  • Python实现破解网站登录密码(带token验证)

    2021-09-29 06:22:22
  • 浅谈Node.js之异步流控制

    2024-05-02 17:36:23
  • python中MySQLdb模块用法实例

    2024-01-25 01:19:27
  • SQLServer 使用ADSI执行分布式查询ActiveDorectory对象

    2024-01-18 11:22:18
  • 10个简化PHP开发的工具

    2023-07-14 18:02:05
  • 在python里创建一个任务(Task)实例

    2023-09-12 23:24:16
  • Django项目后台不挂断运行的方法

    2021-09-28 05:04:54
  • Jupyter Notebook 远程访问配置详解

    2023-09-11 03:19:06
  • 判断网页编码的方法python版

    2022-06-29 10:01:18
  • Oracle 常用的SQL语句

    2024-01-17 08:55:26
  • MySQL数据库之UPDATE更新语句精解

    2009-03-20 15:21:00
  • python去除字符串中的换行符

    2021-07-11 12:35:23
  • MySql循环插入数据

    2010-10-14 13:50:00
  • vue3中7种路由守卫的使用大全举例

    2024-05-29 22:43:52
  • Python 批量合并多个txt文件的实例讲解

    2022-09-18 07:39:47
  • 加快Vue项目的开发速度的方法

    2024-04-28 10:50:20
  • python list使用示例 list中找连续的数字

    2022-10-16 19:49:46
  • asp之家 网络编程 m.aspxhome.com