51工具盒子

依楼听风雨
笑看云卷云舒,淡观潮起潮落

git提交规范

# git 提交规范 {#git-提交规范}

本文讲述 git 版本控制系统的 git 提交规范。大多数开发团队并没有统一的代码提交规范。若遵守统一的提交规范,方便日后 review 代码,以及了解历史功能的修改方法,甚至可以自动化生成工程的 changelog 文件。

# 1. Commit message 的格式 {#_1-commit-message-的格式}

Commit message 包含 3 部分:Header、Body、Footer。
Header 必填,Body 和 Footer 选填。

<type>(<scope>): <subject>
// 空一行
<body>
// 空一行
<footer>

# 1.1 Header {#_1-1-header}

Header 部分包括 3 个字段:type(必需)、scope(可选)和 subject(必需)。

  • type
    type 用于说明 commit 的类别,只允许使用下面 7 个标识。

    feat:新功能(feature)
    fix:修补bug
    docs:文档(documentation)
    style: 格式(不影响代码运行的变动)
    refactor:重构(即不是新增功能,也不是修改bug的代码变动)
    test:增加测试
    chore:构建过程或辅助工具的变动
    

    如果 type 为 feat 和 fix,则该 commit 将肯定出现在 Change log 之中。其他情况(docs、chore、style、refactor、test)由你决定,要不要放入 Change log,建议是不要。

  • scope
    scope 用于说明 commit 影响的范围,比如数据层、控制层、视图层等等,视项目不同而不同。

  • subject
    subject 是 commit 目的的简短描述,不超过 50 个字符。

# 1.2 Body {#_1-2-body}

Body 部分是对本次 commit 的详细描述,可以分成多行。下面是一个范例。

More detailed explanatory text, if necessary.  Wrap it to
about 72 characters or so.

Further paragraphs come after blank lines.

- Bullet points are okay, too
- Use a hanging indent

# 1.3 Footer {#_1-3-footer}

Footer 部分只用于两种情况。

  • 不兼容变动
    如果当前代码与上一个版本不兼容,则 Footer 部分以 BREAKING CHANGE 开头,后面是对变动的描述、以及变动理由和迁移方法。

    BREAKING CHANGE: isolate scope bindings definition has changed.

      To migrate the code follow the example below:
    
      Before:
    
      scope: {
        myAttr: 'attribute',
      }
    
      After:
    
      scope: {
        myAttr: '@',
      }
    
      The removed `inject` wasn't generaly useful for directives so there should be no code using it.
    
  • 关闭 Issue
    如果当前 commit 针对某个 issue,那么可以在 Footer 部分关闭这个 issue 。

    Closes #234
    

    也可以一次关闭多个 issue 。

    Closes #123, #245, #992
    

# 1.4 Revert {#_1-4-revert}

有一种特殊情况,如果当前 commit 用于撤销以前的 commit,则必须以 revert:开头,后面跟着被撤销 Commit 的 Header。

revert: feat(pencil): add 'graphiteWidth' option

This reverts commit 667ecc1654a317a13331b17617d973392f415f02.

Body 部分的格式是固定的,必须写成 This reverts commit <hash>.,其中的 hash 是被撤销 commit 的 SHA 标识符。

如果当前 commit 与被撤销的 commit,在同一个发布(release)里面,那么它们都不会出现在 Change log 里面。如果两者在不同的发布,那么当前 commit,会出现在 Change log 的 Reverts 小标题下面。

# 2. 辅助工具 {#_2-辅助工具}

手工编写符合规范的 Commit message,可能容易出错,那么我们可以借助工具 commitizen 来约束。

# 2.1 安装 commitizen {#_2-1-安装-commitizen}

执行如下命令即可完成 commitizen 的安装。

npm install -g commitizen cz-conventional-changelog

# 2.2 配置 commitizen {#_2-2-配置-commitizen}

执行如下命令为 commitizen 配置提交规范

echo '{ "path": "cz-conventional-changelog" }' > ~/.czrc

若您的操作系统是 windows,需要将如上的第 2 个命令转换为 windows 上的写法。
cz-conventional-changelog 代表的是Angular 团队规范 ,这样 commitizen 就会按照Angular 团队规范生成 commit message。

# 2.3 commitizen 工具的使用 {#_2-3-commitizen-工具的使用}

安装完 commitizen 后,在 git 工程目录下执行 git-cz 或 git cz 即可。

> git cz
cz-cli@4.0.3, cz-conventional-changelog@3.0.2
? Select the type of change that you're committing: (Use arrow keys)
> feat:        A new feature
  fix:         A bug fix
  improvement: An improvement to a current feature
  docs:        Documentation only changes
  style:       Changes that do not affect the meaning of the code (white-space, formatting, missing semi-colons, etc)
  refactor:    A code change that neither fixes a bug nor adds a feature
  perf:        A code change that improves performance
(Move up and down to reveal more choices)

# 3. 为项目生成 Change log 文件 {#_3-为项目生成-change-log-文件}

想生成 Change log 文件的前提是 commit message 需要符合 Angular 规范。
生成的 Change log 文件为 markdown 格式。

# 3.1 安装工具 {#_3-1-安装工具}

yarn global add conventional-changelog-cli

# 3.2 生成 Change log 文件 {#_3-2-生成-change-log-文件}

在工程目录下执行如下命令即可:
conventional-changelog -p angular -i ./CHANGELOG.md -s

该命令不会覆盖以前的 Change log,只会在 CHANGELOG.md 的头部补充自从上次发布以来的变动。
若想生成所有发布的 Change log, 则执行如下命令
conventional-changelog -p angular -i CHANGELOG.md -s -r 0

生成的 CHANGELOG.md 文件的格式如下:

# 1.0.0 (2019-11-06)
### Features
- **自动化:** 新增自动生成 CHANGELOG 相关功能 ([a9ebf7e](https://github.com/godbasin/wxapp-typescript-demo/commit/a9ebf7ee0ca53a4906ed77106b65f6d6bef92f9b))
赞(5)
未经允许不得转载:工具盒子 » git提交规范