内容简介:很长时间以来,我甚至都不知道编写 git 提交(commit)信息也有它自己的“最佳实践”。在我第一次接触 git 时,提交信息的那部分内容被描述为类似这样的话:请看下面的提交信息。如果你想合并它们,你真的不会知道哪些是添加的内容,哪些是修改的内容,它们做了什么或者你为什么需要它们。如果你想在历史记录中搜索某些内容,那么上述的糟糕情况同样会遇到。你向下滚动日志,但它仍是一团糟,并且浪费时间。现在再看下这些提交信息。是不是感觉好多了?反正我是这么觉得。
很长时间以来,我甚至都不知道编写 git 提交(commit)信息也有它自己的“最佳实践”。在我第一次接触 git 时,提交信息的那部分内容被描述为类似这样的话: "...and here you can write something short about what's going on in the commit"
。
不好的提交信息
请看下面的提交信息。如果你想合并它们,你真的不会知道哪些是添加的内容,哪些是修改的内容,它们做了什么或者你为什么需要它们。如果你想在历史记录中搜索某些内容,那么上述的糟糕情况同样会遇到。你向下滚动日志,但它仍是一团糟,并且浪费时间。
cd3e27a contact page aee9d0d comments eac95e5 list of online users, some other changes because of server fae5636 little edit 复制代码
好的提交信息
现在再看下这些提交信息。是不是感觉好多了?反正我是这么觉得。
43ec6aa Fix error when the URL is not reachable 4fe84ab Add error message if something went wrong 753aa05 Add server fingerprint check df3a662 Fix shadow box closing problem 复制代码
如何编写好的提交信息
整个 commit 信息应该有它的格式 - 主题、正文以及可选的由已解决/已关闭的问题组成的结论。
主题
Git 的 commit 帮助页面对提交信息的主题有个很不错的描述:对变更内容进行总结的单行文本(少于50个字符),后跟一个空行。**主题应以大写字母开头且不以句点 .
结尾。**而且重要的是,这必须是一个强制的形式。Chris Beams 为此写了一个简单的规则:
Git 提交信息主题的形式应该总是能够符合这样的句式:如果提交被应用,那么这个提交将“你写的主题”。比如:
【译注】这里可以把“你写的主题”理解成一个动词、一个动作。
- 如果被应用,那么这个提交将 删除(Delete)不需要的行 。
- 如果被应用,那么这个提交将 添加(Add) grep 选项 。
- 如果被应用,那么这个提交将 修复(Fix)协议缺失时错误 。
对于不好的提交信息,就不会符合这个句式:
- 如果被应用,那么这个提交将 Contact page 。
- 如果被应用,那么这个提交将 list of online users, some other changes because of server 。
Git 本身就是使用这种方法。当你要合并某些内容时,Git 会生成一个类似这样的提交信息: "Merge branch..."
,或者回滚时生成 "Revert..."
。
正文
在正文里你可以编写哪些内容被修改了以及为什么修改。正文的每一行不应超过72个字符。当然并不是每次提交都需要有正文。
尾行
最后,你可以添加此次 commit 修复的或相关的 issue。它可以是一个链接、数字或者如果你在使用 GitHub,你可以这样写: Resolves #N / Closes #N ,这里的 N 表示 issue ID。
示例
这是一个来自我的仓库的提交信息示例:
Fix error when protocol is missing First, it checks if the protocol is set. If not, it changes the url and add the basic http protocol on the beginning. Second, it does a "preflight" request and follows all redirects and returns the last URL. The process then continues with this URL. Resolves #17 复制代码
写在最后
感谢你的阅读,希望你从中学到了一些新的东西。如果你有其他的关于如何编写更好的提交消息的提示,或者如何更好地使用此工具,请发表你的评论。
生成变更日志
这样编写提交信息的另一个好处就是很容易生成变更日志。
# show whole commit history $ git log --oneline --decorate --color # show history from one tag to another $ git log 0.0.9..0.0.10 --oneline --decorate --color # show history form tag to head git log 0.0.9..HEAD --oneline --decorate --color 复制代码
这种命令的结果就是你的提交列表。
21629ee Fix getResources bug aa13384 Update docs 44de44c Add HSTS check 复制代码
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- [译]编写react组件最佳实践
- 编写高性能Java代码的最佳实践
- 该如何编写“高性能 Java 代码的实践”
- 爱奇艺网络协程编写高并发应用实践
- (全栈学习实践)三、创建php、添加扩展,其他Dockerfile编写
- EFK 配置geo-ip落地实践(二)fluentd插件编写
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
编程珠玑(续)(修订版)
【美】Jon Bentley 乔恩•本特利 / 钱丽艳、刘田 / 人民邮电出版社 / 2015-2 / CNY 35.00
历史上最伟大的计算机科学著作之一 融深邃思想、实战技术与趣味轶事于一炉的奇书 带你真正领略计算机科学之美 多年以来,当程序员们推选出最心爱的计算机图书时,《编程珠玑》总是位于前列。正如自然界里珍珠出自细沙对牡蛎的磨砺,计算机科学大师Jon Bentley以其独有的洞察力和创造力,从磨砺程序员的实际问题中凝结出一篇篇不朽的编程“珠玑”,成为世界计算机界名刊《ACM通讯》历史上最受欢......一起来看看 《编程珠玑(续)(修订版)》 这本书的介绍吧!