162 lines
5.8 KiB
Markdown
162 lines
5.8 KiB
Markdown
# 提交信息规范(Commit Messages)
|
||
|
||
提交信息用于清晰表达变更意图、范围和原因,便于回溯与自动化发布。
|
||
|
||
## 1. 目标
|
||
|
||
- 让每次提交都能被独立理解。
|
||
- 支持快速定位问题与版本回滚。
|
||
- 可被工具解析(变更日志/发布流程)。
|
||
|
||
## 2. 格式
|
||
|
||
推荐使用以下结构(emoji 可选):
|
||
|
||
```
|
||
:emoji: type(scope): subject
|
||
|
||
body
|
||
|
||
footer
|
||
```
|
||
|
||
- `emoji`:可选,位于首行行首;若使用,必须与 `type` 一一对应(见 4)。
|
||
- `type`:变更类型,必须从 4 的对应表中选取。
|
||
- `scope`:可选,业务域/组件名(`lower_snake_case`),用于辅助定位影响范围。
|
||
- `subject`:一句话概述,使用祈使句/现在时,首字母小写,不加句号。
|
||
- `body`:可选,说明动机、关键实现、影响面;每行建议 ≤ 72 字符。
|
||
- `footer`:可选,关联任务/缺陷号,或 `BREAKING CHANGE:` 说明不兼容变更。
|
||
|
||
不使用 emoji 时,首行直接写 `type(scope): subject` 即可。
|
||
|
||
## 3. 约定
|
||
|
||
### 3.1 一次提交的边界
|
||
|
||
- 一个提交对应一个**逻辑变更**,而不是一个文件或一个模块。
|
||
- 可以同时修改多个 `unit/class/function`,只要它们属于同一逻辑变更。
|
||
- **允许合并的情况**:联动修改是变更所必需的同步/适配(不一起提会导致编译失败、测试失败或行为不一致)。
|
||
- 例:改了 A 的接口签名,同时更新 B 的调用点。
|
||
- **应当拆分的情况**:改动彼此独立,仅是“顺手优化/无关重构/额外功能”。
|
||
- 例:在修复 A 的 bug 时顺便重构 B 的内部实现。
|
||
- 实用判断:
|
||
1. 这次提交能用一句话概括吗?若需要两句话,考虑拆分。
|
||
2. 若只回滚其中一部分,系统还能保持正确吗?不能则不拆。
|
||
3. 每个提交是否都能保持可运行/可构建/测试不更坏?做不到则合并。
|
||
|
||
### 3.2 大模块重构的提交拆分
|
||
|
||
当重构整个模块并影响到其他模块时,建议按“可回滚的小步”拆分提交:
|
||
|
||
1. **前置整理**:仅做无行为影响的清理(重命名、抽函数、补注释/类型、补测试)。
|
||
2. **核心重构**:在模块内部做结构调整,尽量保持对外接口不变;必要时加适配层。
|
||
3. **迁移调用方**:逐步把其他模块迁移到新接口/新行为上。
|
||
4. **清理旧接口**:确认无人使用后再删除适配层/旧代码。
|
||
|
||
若重构为破坏性变更,优先采用“两阶段”:先引入新接口并兼容旧接口(deprecated),迁移完成后再删除旧接口。
|
||
|
||
### 3.3 其他约定
|
||
|
||
- `subject` 尽量 ≤ 72 字符;必要时用 `body` 补充细节。
|
||
- `body/footer` 说明“为什么改、影响什么”,而不是复述代码。
|
||
|
||
## 4. 提交类型与 Emoji 对应
|
||
|
||
本仓库采用固定的 `type`/emoji 一一对应关系;使用 emoji 时必须使用对应的那一个,不得错配。
|
||
|
||
| type | emoji(预览 / 代码) | 说明 |
|
||
| ----------- | --------------------------------- | ---------------------------- |
|
||
| `init` | :tada: `:tada:` | 初始化/首次发布 |
|
||
| `feat` | :sparkles: `:sparkles:` | 新功能 |
|
||
| `fix` | :bug: `:bug:` | Bug 修复 |
|
||
| `perf` | :rocket: `:rocket:` | 性能优化 |
|
||
| `refactor` | :recycle: `:recycle:` | 重构(行为不变) |
|
||
| `style` | :art: `:art:` | 代码样式/格式(行为不变) |
|
||
| `docs` | :memo: `:memo:` | 文档更新 |
|
||
| `test` | :white_check_mark: `:white_check_mark:` | 测试新增/修正 |
|
||
| `deps` | :package: `:package:` | 依赖更新 |
|
||
| `security` | :lock: `:lock:` | 安全修复 |
|
||
| `deprecate` | :warning: `:warning:` | 废弃/弃用标记 |
|
||
| `remove` | :wastebasket: `:wastebasket:` | 删除功能/代码 |
|
||
| `chore` | :wrench: `:wrench:` | 构建/配置/工具/维护性改动 |
|
||
| `contrib` | :busts_in_silhouette: `:busts_in_silhouette:` | 贡献者/致谢相关 |
|
||
| `release` | :bookmark: `:bookmark:` | 发布/打版本标签 |
|
||
|
||
注:`:white_check_mark:` 为补充图例,用于 `test` 类型。
|
||
|
||
如需新增新的 `type`,必须同时补充对应 emoji 与说明。
|
||
|
||
---
|
||
|
||
## 5. 版本号规范(SemVer)
|
||
|
||
遵循语义化版本规范。
|
||
|
||
### 5.1 格式
|
||
|
||
```txt
|
||
MAJOR.MINOR.PATCH
|
||
```
|
||
|
||
### 5.2 字段说明
|
||
|
||
| 字段 | 说明 | 何时递增 |
|
||
| --------- | -------- | ------------------ |
|
||
| **MAJOR** | 主版本号 | 不兼容的 API 修改 |
|
||
| **MINOR** | 次版本号 | 向后兼容的功能新增 |
|
||
| **PATCH** | 修订号 | 向后兼容的问题修正 |
|
||
|
||
### 5.3 更新规则
|
||
|
||
- **MAJOR(主版本)**:破坏性变更,不向后兼容。递增后 MINOR 和 PATCH 重置为 0。
|
||
- **MINOR(次版本)**:新增功能但保持兼容。递增后 PATCH 重置为 0。
|
||
- **PATCH(修订)**:仅修复 bug,不新增功能。
|
||
|
||
### 5.4 示例
|
||
|
||
```txt
|
||
1.0.0 # 首个稳定版
|
||
1.1.0 # 新增功能
|
||
1.1.1 # Bug 修复
|
||
2.0.0 # 破坏性变更
|
||
```
|
||
|
||
### 5.5 Pre-release 版本
|
||
|
||
```txt
|
||
1.0.0-alpha.1
|
||
1.0.0-beta
|
||
1.0.0-rc.1
|
||
1.0.0
|
||
```
|
||
|
||
### 5.6 初始开发阶段
|
||
|
||
```txt
|
||
0.1.0 # 初始版本
|
||
0.2.0 # API 未稳定
|
||
1.0.0 # 首个稳定版
|
||
```
|
||
|
||
注意:`0.x.x` 版本可以随时破坏兼容性。
|
||
|
||
---
|
||
|
||
## 6. 示例
|
||
|
||
带 emoji:
|
||
|
||
```
|
||
:sparkles: feat(order): add batch cancel api
|
||
|
||
support canceling multiple orders in one request; keep old api unchanged.
|
||
|
||
Refs: TSL-1234
|
||
```
|
||
|
||
不带 emoji:
|
||
|
||
```
|
||
refactor(order): simplify cancel flow
|
||
```
|