git Rebase 为任意一笔提交补上 Change-Id

查看最近三笔提交

bash 复制代码
git log -3

2. 交互式 Rebase

假设你需要处理最近的 3 笔提交,执行以下命令:

Bash

css 复制代码
git rebase -i HEAD~3

3. 编辑提交历史 (VIM 操作)

命令执行后,VIM 会打开一个包含提交记录的文本文件:

  1. i 键进入插入模式
  2. 将你想要修改的那一笔提交前的 pick 改为 edit
  3. Esc 键回到命令模式
  4. 输入 :wq 并回车以保存并退出

4. 添加 Change-Id

Git 会暂停在刚才标记为 edit 的提交上。此时执行:

Bash

css 复制代码
git commit --amend --no-edit

提示:如果配置了正确的 commit-msg hook,此命令会自动补全 Change-Id。如果未配置,需手动在提交信息的末尾添加 Change-Id: Ixxxxxxxx...

5. 完成 Rebase

继续执行后续的提交应用:

Bash

kotlin 复制代码
git rebase --continue

注:如果在过程中遇到冲突,请解决冲突后执行 git add .,再执行 git rebase --continue

6. 验证与推送

确认所有提交均已补全 Change-Id

Bash

bash 复制代码
git log -n 3

确认无误后,推送到 Gerrit:

Bash

ruby 复制代码
git push origin HEAD:refs/for/你的分支名

💡 进阶:如何避免再次遗忘?

为了避免手动添加 Change-Id,建议安装 Gerrit 的 commit-msg 钩子:

相关推荐
_codemonster14 小时前
Codex 核心进阶玩法(技能/MCP/派生/分叉/Git/钩子/子智能体)
git
测试开发-学习笔记14 小时前
Android studio安装
android·ide·android studio
宋拾壹14 小时前
同时添加多个类目
android·开发语言·javascript
逻极14 小时前
Git 从入门到精通:版本控制协作实战指南
git·github·分支管理·版本控制
恋喵大鲤鱼14 小时前
git clean
git·git clean
Patrick_Wilson15 小时前
为省一次回归测试,该不该把多个改动堆进一条分支?
git·ci/cd·架构
●VON15 小时前
AtomGit Flutter鸿蒙客户端:数据模型
android·服务器·安全·flutter·harmonyos·鸿蒙
恋喵大鲤鱼15 小时前
git blame
git·git blame
火柴就是我16 小时前
记录一个文本随手指缩放的功能
android
yeflx16 小时前
Git操作
git