原文: http://chris.beams.io/posts/git-commit/

介绍:为什么好的commit message很重要

你浏览项目commit message的时候或多或少会有些困扰的地方. 例如, 下面是我早前的commit message:

$ git log --oneline -5 --author cbeams --before "Fri Mar 26 2009"

e5f4b49 Re-adding ConfigurationPostProcessorTests after its brief removal in r814. @Ignore-ing the testCglibClassesAreLoadedJustInTimeForEnhancement() method as it turns out this was one of the culprits in the recent build breakage. The classloader hacking causes subtle downstream effects, breaking unrelated tests. The test method is still useful, but should only be run on a manual basis to ensure CGLIB is not prematurely classloaded, and should not be run as part of the automated build.
2db0f12 fixed two build-breaking issues: + reverted ClassMetadataReadingVisitor to revision 794 + eliminated ConfigurationPostProcessorTests until further investigation determines why it causes downstream tests to fail (such as the seemingly unrelated ClassPathXmlApplicationContextTests)
147709f Tweaks to package-info.java files
22b25e0 Consolidated Util and MutableAnnotationUtils classes into existing AsmUtils
7f96f57 polishing

再来看看我最近的commit message:

$ git log --oneline -5 --author pwebb --before "Sat Aug 30 2014"

5ba3db6 Fix failing CompositePropertySourceTests
84564a0 Rework @PropertySource early parsing logic
e142fd1 Add tests for ImportSelector meta-data
887815f Update docbook dependency and generate epub
ac8326d Polish mockito usage

显然第二种更易读一些.第一种长度和形式都不一样, 第二种风格比较统一.

一个好的commit message应该遵循的7条规则

  1. 主题和内容用空白行隔开
  2. 主题的限制在50个字符内
  3. 主题首字母大写
  4. 主题结尾不要有标点符号
  5. 主题用祈始语句
  6. 正文一行最多72个字符
  7. 内容里解释做了什么,和为什么这么做

例子:

Summarize changes in around 50 characters or less

More detailed explanatory text, if necessary. Wrap it to about 72
characters or so. In some contexts, the first line is treated as the
subject of the commit and the rest of the text as the body. The
blank line separating the summary from the body is critical (unless
you omit the body entirely); various tools like `log`, `shortlog`
and `rebase` can get confused if you run the two together. Explain the problem that this commit is solving. Focus on why you
are making this change as opposed to how (the code explains that).
Are there side effects or other unintuitive consequenses of this
change? Here's the place to explain them. Further paragraphs come after blank lines. - Bullet points are okay, too - Typically a hyphen or asterisk is used for the bullet, preceded
by a single space, with blank lines in between, but conventions
vary here If you use an issue tracker, put references to them at the bottom,
like this: Resolves: #123
See also: #456, #789

1.主题和内容用空白行隔开

来子git commit manapage:

不是必须, 但是最好是用一个简短的行(小于50个字符)作为主题描述这次修改, 然后空一行后写详细的描述. 第一个空白行上面的文字会被git做为标题对待.

首先, 不是每一个commit message都需要主题和内容. 有的时候一行就行了, 特别是在修改比较简单的情况下.例如:

Fix typo in introduction to user guide

不需要多说什么. 如果实在想看这个拼写是什么, 可以使用git show git diff git log -p.

如果你的committing是上面这种很简单的一个主题就能描述清楚的事情, 使用git commit -m就行了:

$ git commit -m"Fix typo in introduction to user guide"

如果你的committing比较复杂, 需要多点内容进行描述的时候,使用-m就不方便了. 这是你commit的时候不要加-m在弹出来的编辑器里面进行描述会比较好.

主题和内容用空白行隔开是好的. 下面是一个完整的log纪录:

$ git log
commit 42e769bdf4894310333942ffc5a15151222a87be
Author: Kevin Flynn <kevin@flynnsarcade.com>
Date: Fri Jan 01 00:00:00 1982 -0200 Derezz the master control program MCP turned out to be evil and had become intent on world domination.
This commit throws Tron's disc into MCP (causing its deresolution)
and turns it back into a chess game.

使用 git log --oneline, 就只打印出来主题行了:

$ git log --oneline
42e769 Derezz the master control program

使用git shortlog 按作者分组显示的时候也只会打印出主题行:

$ git shortlog
Kevin Flynn (1):
Derezz the master control program Alan Bradley (1):
Introduce security program "Tron" Ed Dillinger (3):
Rename chess program to "MCP"
Modify chess program
Upgrade chess program Walter Gibbs (1):
Introduce protoype chess program

2.限制主题在50个字符之内

50个字符不是一个硬性规定. 把主题限制在50个字符之内会让这个主题更易读, 而且还会使得作者尽量用精简的语句来描述发什么了什么.

tip:如果你很难简短的慨括这个修改, 你可能是一次commit了太多的修改了. 要尽量做到一次commit就干一件事情做到原子提交.

GitHub的界面就知道这个约定. 如果你的message超过了50个字符, 他会给你一个警告:

标题超过69这个长度之后的字符会被...:

3.主题首字母大写

主题的首字母大写. 例如:

Accelerate to 88 miles per hour

替代

accelerate to 88 miles per hour

4.主题的结尾不要有标点符号  

结尾的标点一点用处都没有, 还会从50个字符里面占掉1个字符.例如:

Open the pod bay doors

替代

open the pod bay doors.

5.主题用祈始语句

祈始语句就像是命令的语句.

  • Clean your room
  • Close the door
  • Take out the trash

祈始语句好像有点粗鲁, 但是它直接明了. 另外merge commit的message也是祈始语句:

Merge branch 'myfeature'

git revert也是祈始语句:

Revert "Add the thing with the stuff"

This reverts commit cc87791524aedd593cff5a74532befe7ab69ce9d.

  

[译]How to Write a Git Commit Message的更多相关文章

  1. 如何写好git commit message

    1.触发事件 我有这样一个版本库,里面包含两个学习用的练习项目:BookStore(以下简称BS)和PictureFriend(以下简称PF) 我在更改PF以后,未进行提交,同时又到BS中优化了一下文 ...

  2. git第四节----git commit message

    @git  commit message 什么是git commit message :git commit -m '每次提交时编辑的内容' git commit message的好处:      1 ...

  3. Git Commit Message 规范

    今天来说说团队开发中,对于 Git commit message 规范问题. 社区上有各种 Commit message 的规范,本文介绍 Angular 规范,目前使用较广,比较合理和系统化,并且有 ...

  4. 我是怎么写 Git Commit message 的?

    目录 作用 用的什么规范? type scope subject body footer 参考文章 用的什么辅助工具? 作用 编写格式化的 commit message 能够大大提高代码的维护效率. ...

  5. Git commit message和工作流规范

    目的 统一团队Git commit日志标准,便于后续代码review,版本发布以及日志自动化生成等等. 统一团队的Git工作流,包括分支使用.tag规范.issue等 Git commit日志参考案例 ...

  6. git使用总结(包含git commit message 和 changelog 工具的介绍)

    [git的配置] 1.配置用户名和邮箱: 分为全局配置和局部配置 --system 系统配置  --global 全局配置    --local 局部配置 Git读取时:优先从local>glo ...

  7. commitizen和cz-customizable配置git commit message

    起因 团队对提交的commit message格式有约定俗称的要求,但是没有一个统一的规范,导致大家提交的commit message或多或少不太一样.因此,需要一个工具来帮助大家统一commit m ...

  8. 优化 Git Commit Message

    目前很多项目都是通过 Git 进行管理的,Git 每次提交代码的过程中 提交说明 commit message 是必须的.但仅仅必须是不够的,好的提交说明可以帮助我们提高项目的整体质量. 作用与优点 ...

  9. IDEA 中 Git Commit message 编写

    IDEA安装插件 Git Commit Template 1. HeaderHeader的部分只有一行,包括三个字段: type(必需), scope(可选), subject(必需) 对应到idea ...

随机推荐

  1. [译]Thinking in React

    编者按 使用React的思想来构建应用对我在实际项目中以及帮助他人解决实际问题时起到了很大作用,所以我翻译此文来向那些正在或即将陷入React或React-Native深坑的同胞们表示慰问.网上已经有 ...

  2. L2-011. 玩转二叉树

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAA28AAAHQCAIAAAC5rsUiAAAgAElEQVR4nO3dzYts953n+foXcpUL0Q

  3. Heartbeat使用梳理

    在日常的集群系统架构中,一般用到Heartbeat的主要就2种:1)高可用(High Availability)HA集群, 使用Heartbeat实现,也称为"双机热备", &qu ...

  4. BZOJ1500[NOI2005]维修数列

    Description Input 输入的第1 行包含两个数N 和M(M ≤20 000),N 表示初始时数列中数的个数,M表示要进行的操作数目.第2行包含N个数字,描述初始时的数列.以下M行,每行一 ...

  5. 百度地图demo

    以下代码拷贝成html,直接运行即能看到百度地图 <!DOCTYPE html><html> <head> <meta http-equiv="Co ...

  6. C#记录程序运行时间记录显示

    //引入命名空间            using System.Diagnostics;            //清空导入时间 lbImportTime.Text = ""; ...

  7. Tomcat基于虚拟路径的发布和web.xml配置

    <Connector port="8888" protocol="HTTP/1.1" connectionTimeout="20000" ...

  8. 日货EmEditor的使用小技巧

    1.查看->大纲向导,可层级显示HTML 2.工具->插件->资源管理器,可在左侧显示资源管理器 3.工具->插件->单词自动完成,可实现单词智能提示功能

  9. HAProxy的日志配置以及ACL规则实现负载均衡

    HAProxy配置日志策略 默认情况下,HAProxy是没有配置日志的在centos6.3下默认管理日志的是rsyslog,可以实现UDP日志的接收,将日志写入文件,写入数据库先检测rsyslog是否 ...

  10. ES6深入学习记录(一)class方法相关

    今天学习class相关的一些使用方法,着重在于class extends class之间可以通过extends关键字实现继承,这比ES5的通过修改原型链实现继承,要清晰和方便很多. 上面的代码定义了一 ...