cliff.toml 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. # git-cliff 配置文件
  2. # https://git-cliff.org/docs/configuration
  3. #
  4. # 以 "#" 开头的行是注释。
  5. # 配置选项按表和键组织。
  6. # 更多可用选项请参阅文档。
  7. [changelog]
  8. # 变更日志的标题模板
  9. header = """
  10. # GoHUB 项目主要提供的是 Web 服务, 且具备命令行功能
  11. Web 服务功能会封装到子命令 serve 中,命令行功能会封装到子命令 cli 中。
  12. ## 除了 serve 命令,我们还会有以下命令
  13. 1. key 命令生成 app key
  14. 2. make 命令
  15. 3. seed 数据填充
  16. 4. migrate 数据库迁移
  17. 5. cache 缓存处理
  18. ## 变更日志\n
  19. 本文件记录了本项目的所有重要变更。\n
  20. """
  21. # 变更日志的内容模板
  22. # https://keats.github.io/tera/docs/#introduction
  23. body = """
  24. {% if version %}\
  25. ### [{{ version | trim_start_matches(pat="v") }}] - {{ timestamp | date(format="%Y-%m-%d") }}
  26. {% else %}\
  27. ### [未发布]
  28. {% endif %}\
  29. {% for group, commits in commits | group_by(attribute="group") %}
  30. #### {{ group | striptags | trim | upper_first }}
  31. {% for commit in commits %}
  32. - {% if commit.scope %}*({{ commit.scope }})* {% endif %}\
  33. {% if commit.breaking %}[**破坏性变更**] {% endif %}\
  34. {{ commit.message | upper_first }}\
  35. {% endfor %}
  36. {% endfor %}\n
  37. """
  38. # 变更日志的页脚模板
  39. footer = """
  40. <!-- 由 git-cliff 生成 -->
  41. """
  42. # 移除内容前后的空白
  43. trim = true
  44. # 后处理器
  45. postprocessors = [
  46. # { pattern = '<REPO>', replace = "https://github.com/orhun/git-cliff" }, # 替换仓库 URL
  47. ]
  48. # 即使没有发布版本也渲染内容
  49. # render_always = true
  50. # 输出文件路径
  51. output = "CHANGELOG.md"
  52. [git]
  53. # 基于 https://www.conventionalcommits.org 解析提交信息
  54. conventional_commits = true
  55. # 过滤掉不符合规范的提交
  56. filter_unconventional = true
  57. # 将提交的每一行作为单独的提交处理
  58. split_commits = false
  59. # 提交信息的预处理正则表达式
  60. commit_preprocessors = [
  61. # 替换问题编号
  62. #{ pattern = '$(\w+\s)?#([0-9]+)$', replace = "([#${2}](<REPO>/issues/${2}))"},
  63. # 使用 https://github.com/crate-ci/typos 检查提交信息的拼写
  64. # 如果拼写错误,会自动修正。
  65. #{ pattern = '.*', replace_command = 'typos --write-changes -' },
  66. ]
  67. # 提交信息的解析和分组规则
  68. commit_parsers = [
  69. { message = "^feat", group = "🚀 新功能" },
  70. { message = "^fix", group = "🐛 Bug 修复" },
  71. { message = "^docs", group = "📚 文档更新" },
  72. { message = "^style", group = "🎨 代码样式" },
  73. { message = "^refactor", group = "🚜 代码重构" },
  74. { message = "^perf", group = "⚡ 性能优化" },
  75. { message = "^test", group = "🧪 测试相关" },
  76. { message = "^build", group = "📦 构建系统" },
  77. { message = "^ci", group = "🔧 CI 配置" },
  78. { message = "^chore", group = "⚙️ 辅助工具的变动" },
  79. { message = "^revert", group = "◀️ 回滚变更" },
  80. { message = "^security", group = "🛡️ 安全相关" },
  81. { message = "^wip", group = "🚧 进行中" },
  82. { message = "^deps", group = "📦 依赖更新" },
  83. { message = "^init", group = "🎉 初始化" },
  84. { message = "^config", group = "⚙️ 配置变更" },
  85. { message = "^release", group = "🏷️ 版本发布" },
  86. { message = "^hotfix", group = "🔥 紧急修复" },
  87. { message = "^breaking", group = "💥 破坏性变更" },
  88. { message = ".*", group = "💼 其他" },
  89. ]
  90. # 过滤掉未被提交解析器匹配的提交
  91. filter_commits = false
  92. # 按拓扑顺序排序标签
  93. topo_order = true
  94. # 按提交时间排序(oldest 或 newest)
  95. sort_commits = "newest"