git-cliff 是一个可以从 Git 历史记录中自动生成变更日志的小工具,并且能通过模板定义格式内容,最终导出 CHANGELOG.md 文件。@Appinn
git-cliff 能够整合在 git
之中,使用的时候只需要:
git cliff --output CHANGELOG.md
它会根据 git 提交记录,匹配如 fix|修复、doc|文档、style|样式、perf|性能 等描述语,然后自动生成 .md 文档。
默认文档匹配是这样的,按需修改即可。
{ message = "^feat", group = "<!-- 0 --> Features" },
{ message = "^fix", group = "<!-- 1 --> Bug Fixes" },
{ message = "^doc", group = "<!-- 3 --> Documentation" },
{ message = "^perf", group = "<!-- 4 --> Performance" },
{ message = "^refactor", group = "<!-- 2 --> Refactor" },
{ message = "^style", group = "<!-- 5 --> Styling" },
{ message = "^test", group = "<!-- 6 --> Testing" },
{ message = "^chore\\(release\\): prepare for", skip = true },
{ message = "^chore\\(deps.*\\)", skip = true },
{ message = "^chore\\(pr\\)", skip = true },
{ message = "^chore\\(pull\\)", skip = true },
{ message = "^chore|^ci", group = "<!-- 7 --> Miscellaneous Tasks" },
{ body = ".*security", group = "<!-- 8 --> Security" },
{ message = "^revert", group = "<!-- 9 --> Revert" },
可以为特定的部分 git 历史记录生成变成日志,比如:
git cliff --current
git cliff --unreleased --tag 1.0.0
也可以指定范围:
git cliff 4c7b043..a440c6e
git cliff 4c7b043..HEAD
git cliff HEAD~2..
git cliff v2.2.1..
git cliff v0.1.0..HEAD
更具体的用法参见例子。
有需求的同学可以试试。
具体的案例,可以 git-cliff 自己的 CHANGELOG.md 文件。
原文:https://www.appinn.com/git-cliff/