执行repo sync -c -d -j4以后,提交未git push的代码看不到了。要怎么恢复?

执行repo sync -c -d -j4以后,提交未git push的代码看不到了。要怎么恢复?

先理解为什么代码会消失

repo sync 中的 -d 参数是关键:它会让每个项目仓库(repo 管理的子 git 仓库)丢弃本地的分支检出状态,强制切换到与远程清单一致的提交版本 ,相当于对每个子仓库执行了类似 git checkout --detach + 丢弃本地未提交 / 未推送的变更(尤其是未跟踪的分支或游离状态的提交)。

但幸运的是,git 不会轻易彻底删除提交记录,哪怕是被 "覆盖" 的提交,也会在本地保留日志,git reflog 就是用来找回这些 "隐藏" 提交的。

完整恢复步骤

复制代码
git reflog

git show b26a8f71

方法1:

git checkout b26a8f71

方法2:

# 1. 确保当前在你需要的分支(比如master)

git checkout master

# 2. 捡取丢失的提交到当前分支

git cherry-pick b26a8f71


以后这样操作,不要加 -d选项
# 1. 切换到开发分支
repo forall -c 'git checkout feature/my-feature'
repo forall -c 'git checkout al_dev'
 
# 2. 只同步这个分支的最新代码
repo sync -c -j8
相关推荐
cen__y5 小时前
Linux12(Git01)
linux·运维·服务器·c语言·开发语言·git
bukeyiwanshui8 小时前
20260518 Swift实验
git·swift
qziovv8 小时前
Git 回退场景
大数据·git·elasticsearch
来自大山深处的Doge_11 小时前
解决Git提交更新更改时出错: detected dubious ownership in repository at ...
git
嵌入式爱好者hsw13 小时前
Git 部署本地仓库
git
C137的本贾尼14 小时前
Git基本操作(三):版本回退,坐上“时光机”
git
ylifs15 小时前
目的驱动式Git用法
git
来尔君16 小时前
Git Bash 提示符简化(就是每次敲命令时上面显示的那一行信息)
git·命令行
我叫张小白。17 小时前
PyCharm 集成 Git 与 Gitee
git·pycharm·gitee
小雨青年17 小时前
Git Bisect 实战:用二分法快速找到引入 Bug 的提交
git·bug