热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

编写良好的提交信息:实用指南

要创建有用的修订历史记录,团队应该首先就要使用的提交消息约定达成一致,这也适用于个人项目。最近,我在Hashnode上问了一个问题

要创建有用的修订历史记录,团队应该首先就要使用的提交消息约定达成一致,这也适用于个人项目。

最近,我在Hashnode上问了一个问题,询问用户 他们在工作中使用哪种提交消息约定? ”,当用户解释他们在工作中以及用于个人项目的约定时,我得到了相当多的反响。

在本文中,我将介绍为什么您应该编写良好的提交消息以及如何编写良好的提交消息。

Git版本控制简介

版本控制软件是每天现代软件开发人员实践中必不可少的部分。

到目前为止, Git是当今世界上使用最广泛的现代版本控制系统。 它是一个分布式且积极维护的开源项目,最初由Linux操作系统内核的著名创建者Linus Torvalds于2005年开发。

刚接触Git? 查看官方的入门指南或我过去的演讲中的这张幻灯片 。

什么是提交消息?

在Git中暂存后,使用commit命令将更改保存到本地存储库。 但是,在保存Git更改之前,您必须告诉Git您要保存哪些更改,因为您可能已经进行了大量更改。 做到这一点的一种好方法是添加一个提交消息以标识您的更改。

提交选项

  • -m <消息>

此选项设置提交的消息。

git add static/admin/config.yml
git commit -m "Setup multiple roles for netlify-cms git gateway"

  • -a或--all

此选项自动提交所有&#xff08;包括新的&#xff09;跟踪&#xff0c;修改或删除的文件。

git commit - a -m "Add a new role for netlify-cms git gateway"

  • - 修改

此选项将使用当前已暂存的任何更改或新的提交消息重写最后的提交&#xff0c;并且仅应在尚未推送到远程存储库的提交上执行。

git add .
git commit --amend -m "Update roles for netlify-cms git gateway"

为什么要编写良好的提交消息&#xff1f;

您可能会说“这只是一个个人项目”&#xff0c;但是是的&#xff0c;您现在一个人工作&#xff0c;但是当您与团队合作或为开源做贡献时会发生什么&#xff1f;

精心设计的Git提交消息是与从事该项目的其他开发人员以及您未来的自我沟通有关变更的上下文的最佳方法。 您是否尝试过运行旧项目之一的&#96;git log&#96;来查看自开始以来就使用过的“怪异”提交消息&#xff1f; 您很难解释过去为什么要进行一些更改&#xff0c;并且希望您现在之前已经阅读过本文&#xff1a;)。

提交消息可以充分告诉您为什么进行了更改&#xff0c;并且了解为什么进行了更改可以使开发和协作更加高效。

如何使用Git编写提交消息

在此之前&#xff0c;我只在个人项目上使用了git commit -m "Fix X to allow Y to use Z" &#xff0c;并且仅提供了一个主题&#xff0c;没有附加描述。 这非常适合进行小而清晰的修复&#xff0c;例如git commit -m "Fix typo in README.md中的git commit -m "Fix typo in README.md但是在更广泛的更改的情况下&#xff0c;您需要添加一些额外的细节。

编辑器方法

运行没有消息或选项的git commit &#xff0c;它将打开您的默认文本编辑器以编写提交消息。

>要配置“默认”编辑器&#xff1a;

git config --global core.editor nano

这会将git配置为使用nano作为默认编辑器。 将“ nano”替换为“ emacs”&#xff0c;“ vim”或您的偏好。

在打开的编辑器中&#xff0c;第一行是主题&#xff08;简短描述&#xff09;&#xff0c;其后留空行&#xff0c;其他所有内容都是扩展描述&#xff08;正文&#xff09;。

change ( s ) in around 50 characters or less >
detailed explanatory description of the change wrapped into about 72
characters >

命令行方式

git commit -m "Subject" -m "Description..."

第一个-m选项是主题&#xff08;简短描述&#xff09;&#xff0c;第二个是扩展描述&#xff08;正文&#xff09;。

如何编写良好的提交消息

一些团队和开发人员使用多种约定来编写良好的提交消息。 我只概述一些用于编写提交消息的一般规则和技巧&#xff0c;您将不得不决定要遵循的约定&#xff0c;并且如果您在公司工作或为开源做贡献&#xff0c;则必须适应它们的约定&#xff1a;)。

为了保持一致性&#xff0c;您可以在工作中使用一种约定&#xff0c;而在个人项目中使用另一种约定&#xff0c;因为您有时可能会更改工作&#xff0c;并且约定可能会更改。

确保检查此线程以了解一些惊人的提交消息约定&#xff0c;或添加您的约定以帮助某人做出决定。

这是Tim Pope最初编写的良好提交消息的一个很好的模板

大写的简短&#xff08;不超过50个字符&#xff09;摘要
如有必要&#xff0c;提供更详细的说明文字。 将其包装到大约72个字符左右。 在某些情况下&#xff0c;第一行被视为电子邮件的主题&#xff0c;其余文本被视为正文。 将摘要与正文分开的空白行很重要&#xff08;除非您完全省略正文&#xff09;&#xff1b; 如果将两者一起运行&#xff0c;诸如rebase之类的工具可能会感到困惑。
请务必将提交消息写在“修复错误”而不是“修复错误”或“修复错误”中。 该约定与git merge和git revert等命令生成的提交消息匹配。
空白段之后是其他段落。
-子弹点也可以
-通常在项目符号上使用连字符或星号&#xff0c;后跟一个空格&#xff0c;中间留有空白行&#xff0c;但约定在此处有所不同
-使用悬挂式缩进
如果您使用问题跟踪器&#xff0c;请在其底部添加一个引用&#xff0c;如下所示&#xff1a;解决&#xff1a;&#xff03;123

看起来不错吧&#xff1f; 您也可以通过以下方法使自己的实力变得出色&#xff1a;

  1. 1.指定提交类型&#xff1a;

  • 壮举 &#xff1a;您要添加到特定应用程序的新功能
  • fix &#xff1a;一个错误修复
  • 样式 &#xff1a;与样式相关的功能和更新
  • 重构 &#xff1a;重构代码库的特定部分
  • 测试 &#xff1a;与测试相关的所有内容
  • docs &#xff1a;与文档相关的所有内容
  • 杂务 &#xff1a;常规代码维护。
  1. [您也可以使用表情符号来代表提交类型]

    2.用空白行将主体与身体分开

    3.您的提交消息不应包含任何空格错误

    4.删除不必要的标点符号

    5.不要以句号结尾主题行

    6.大写主题行和每个段落

    7.在主题行中使用祈使语气

    8.用正文解释您进行了哪些更改以及进行更改的原因。

    9.不要以为审阅者了解原始问题是什么&#xff0c;请确保将其添加。

    10.不要认为您的代码是不言自明的

    11.遵循团队定义的提交约定

结论

提交消息最​​重要的部分是它应该清晰且有意义。 从长远来看&#xff0c;编写良好的提交消息可以表明您有多大协作者&#xff0c;而编写良好的提交消息所带来的好处不仅限于您的团队&#xff0c;而且还不仅限于您自己&#xff0c;还包括未来的贡献者。

想要了解有关Git的更多信息并成为专业的“版本控制器”&#xff0c;请查看以下优秀资源&#xff1a;

  • https://try.github.io/
  • https://git-scm.com/book/zh/v2
  • https://www.git-tower.com/learn/
  • https://learngitbranching.js.org/xxxx

先前发布在https://bolajiayodeji.com/writing-good-commit-messages-a-practical-guide-ck3izs56t00sed0s11z515m1j

From: https://hackernoon.com/writing-good-commit-messages-a-practical-guide-1j11i3y4c



推荐阅读
  • 如何在Linux环境中高效地创建、编译与运行C语言代码
    本文面向第一次在linux尝试写C语言程序的新人。有经验的请绕行。C语言用法不是本文介绍的关键,本文只是引入如何第一次在linux系统下编写、编译和执行一个简单的c程序。学会后请自行深入 ... [详细]
  • Git基础操作指南:掌握必备技能
    掌握 Git 基础操作是每个开发者必备的技能。本文详细介绍了 Git 的基本命令和使用方法,包括初始化仓库、配置用户信息、添加文件、提交更改以及查看版本历史等关键步骤。通过这些操作,读者可以快速上手并高效管理代码版本。例如,使用 `git config --global user.name` 和 `git config --global user.email` 来设置全局用户名和邮箱,确保每次提交时都能正确标识提交者信息。 ... [详细]
  • 在MFC开发过程中,利用Windows内置的文件对话框可以显著提高文件操作的效率。本文总结了使用文件对话框进行文件选择和处理的经验,详细介绍了相关API的调用方法和参数设置,如`CFileDialog`类的使用、结构体`OPENFILENAME`的配置以及如何获取选中的文件路径。通过这些技巧,开发者可以快速实现文件的打开、保存等功能,提升应用程序的用户体验。 ... [详细]
  • 速查!Git常用命令大全【汇总推荐】
    开发工具|gitgit开发工具-gitgit常用命令网站源码分享资源,写vscode插件详细教程,ubuntu突然卡,war放tomcat哪,应聘爬虫岗位,php获取数组索引值,张 ... [详细]
  • Python数据分析入门指南:全面了解Python在数据科学中的应用 ... [详细]
  • 在椭圆形状设计中,色彩搭配方案对视觉效果和用户体验至关重要。本文分析了不同色彩组合在椭圆形状设计中的应用效果,特别探讨了白色背景与绿色文字的搭配,指出长期观看这种配色可能会导致视觉疲劳。通过引入多种色彩搭配方案,本文旨在为设计师提供更加科学和舒适的色彩选择建议。 ... [详细]
  • 深入解析 Spring MVC 的核心原理与应用实践
    本文将详细探讨Spring MVC的核心原理及其实际应用,首先从配置web.xml文件入手,解析其在初始化过程中的关键作用,接着深入分析请求处理流程,包括控制器、视图解析器等组件的工作机制,并结合具体案例,展示如何高效利用Spring MVC进行开发,为读者提供全面的技术指导。 ... [详细]
  • 整合百度UEditor编辑器于ASP后端的实现步骤与技巧
    随着微软停止对XP系统的支持,公司已全面升级至Windows 7。早期网站创建时使用的编辑器仅兼容IE6浏览器,而如今系统更新后,原有的编辑器已无法满足新环境的需求。本文详细介绍了如何将百度UEditor编辑器整合到ASP后端,包括实现步骤和实用技巧,确保网站在新系统下仍能高效运行并提供良好的用户体验。 ... [详细]
  • 算术表达式分析与解析技术初探
    本文初步探讨了算术表达式的分析与解析技术,针对作者在职业转型过程中发现自身算法基础薄弱的问题,决定在接下来的三个月内,系统地学习和掌握常用数据结构与算法,以提升个人技术能力。研究内容不仅涵盖了基本的算术表达式解析方法,还深入讨论了其在实际应用中的优化策略,为相关领域的进一步研究奠定了基础。 ... [详细]
  • 2023年6月19日:重要日期回顾与展望
    13.1设置更改root密码更改MySQL数据库root密码1.首次进入数据库是不用密码的,如下所示: usrlocalmysqlbinmysql-uroot       使用绝对 ... [详细]
  • 什么是git-lfsGithub对文件大小的限制如果你在命令行用gitpush50MB的文件,你会收到一个warning,但是你仍然可以正常push,但是100MB的时候就无法 ... [详细]
  • 六百字读懂
    译注:来自HackerSchool的MaryRoseCook实现了一个纯JavaScript(Node.js)写就的Git:Gitlet,包含了最主要的一些命令。这个项目一是为了了 ... [详细]
  • gitcommit-m提交所有本地文件 ... [详细]
  • Day 5 20190120 老男孩python学习第5天 内容整理
    今天继续看MasteringPycharm的视频,一个半小时看git的教学视频:视频1小时44分钟,看了2个半小时以上https:www.youtube ... [详细]
  • GitHub——微信小程序开发资源汇总交互式在线学习Git。好好学习,天天向上https:learngitbranch ... [详细]
author-avatar
Lanboream
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有