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 钩子:

相关推荐
TDengine (老段)5 小时前
TDengine 超级表/子表/普通表 — 设计理念与内部表示
android·大数据·数据库·物联网·时序数据库·tdengine·涛思数据
shuaiqinke5 小时前
【分享】Edge浏览器|内置扩展仓库|支持油猴|上网无限制
android·前端·人工智能·edge
OsDepK6 小时前
AudioSplit音频多轨免费分离工具即将发布
ide·git·python·音视频·集成学习
jiayong236 小时前
Git 常见错误与详细解决方案
大数据·git·elasticsearch
Carson带你学Android6 小时前
见证历史!Swift 6.3 官方支持 Android,跨平台要变天了?
android
jiayong237 小时前
Git 分支命名、区别、联系与顺序关系说明
大数据·git·elasticsearch
plainGeekDev7 小时前
Android性能优化面试题:你说你会优化,结果连ANR都排查不了
android·面试
richard_yuu7 小时前
鸿蒙本地数据存储实战|Preferences 封装、数据隔离与隐私合规存储方案
android·华为·harmonyos
无风听海7 小时前
Git 对象存储模型深度解析
git