Skip to content

0xJatto/git_commit_message

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 

Repository files navigation

Git commit message

How to write a great Git commit message:

  1. Begin the commit message with a short title that summarizes the change.

  2. Start the title with an imperative present active verb: Add, Fix, Optimize, etc.

  3. Format the title: start with a capital word, use up to 50 characters, and end without a period.

  4. Optionally follow the title by a blank line, then a more thorough description.

Title examples

Title examples of good commit messages:

  • Add feature for foo
  • Drop feature for foo
  • Fix bug when foo is missing
  • Bump version of foo dependency
  • Make foo integration script
  • Start foo feature flag
  • Stop foo feature flag
  • Refactor foo for clarity
  • Reformat foo to remove whitespace
  • Optimize foo for speed and memory
  • Document foo protocol

Specifics

Capitalize the title.

  • Right: Add feature
  • Wrong: add feature

Do not end the title with a period:

  • Right: Add feature
  • Wrong: Add feature.

Use imperative mood: present tense, active voice, and lead verb.

  • Right: Add feature
  • Wrong: Adds feature (this is indicative mood, not imperative mood)
  • Wrong: Added feature (this is past tense, not present tense)
  • Wrong: Adding feature (this lead is a gerund, not a verb)
  • Wrong: Feature added (this is passive voice, not active voice)

Keep the title within 50 characters.

  • This is the git documentation convention.

Use a blank line after the title.

  • This is the same convention as writing an email message.

Wrap the body at 72 characters.

  • This is the same convention as writing an email message.

For more about these see How to Write a Git Commit Message

Imperatives

My team uses a title convention that helps us read fast, and helps us write tools to parse messages.

We agree on a short list of imperatives i.e. imperative mood, present tense, active voice, verbs:

  • Add = Create a capability e.g. feature, test, dependency.
  • Drop = Delete a capability e.g. feature, test, dependency.
  • Fix = Fix an issue e.g. bug, typo, accident, misstatement.
  • Bump = Increase the version of something e.g. a dependency.
  • Make = Change the build process, or tools, or infrastructure.
  • Start = Begin doing something; e.g. enable a toggle, feature flag, etc.
  • Stop = End doing something; e.g. disable a toggle, feature flag, etc.
  • Refactor = A change that MUST be just refactoring.
  • Reformat = A change that MUST be just formatting, e.g. omit whitespace.
  • Optimize = A change that MUST be just about performance, e.g. speed up code.
  • Document = A change that MUST be only in the documentation, e.g. help files.

Reasoning

We primarily care that our team communicates effectively with our shared understanding.

We secondarily like these verbs above because they're easy to read, easy to type, and clear in many cultures.

If you and your team prefer other words, that's fine too; use what works for you.

Reject these formats

We reject some kinds of git commit message formats:

  • [bug] ...
  • (release) ...
  • #12345 ...
  • jira:https:// ...
  • docs: ...

We reject the commit style of projets such as Angular, Commitizen defaults, etc.

  • Because these use a leading tag that is sometimes a word, sometimes an abbreviation, sometimes a plural noun, etc.

  • Examples are using "feat" for feature, "docs" for document, "perf" for performance improvement, etc.

  • Instead we use "Add" for adding a feature, "Document" for documenting help, "Optimize" for performance improvement, etc.

  • Active verbs are easier to skim, and easier to use for people from other cultures who may be less-comfortable using English.

We reject using an id number or URL in the title.

  • We use fully-qualified URLs in the commit message body.

  • This is because many of our projects use multiple tracking systems, and multiple ways of launching a URL.

  • We want URL tracking to be easy to use by a wide range of systems, scripts, and teams.

Optional: use contact email addresses

We sometimes have more than one person working on a commit. For example, we do do pair programming.

To keep track of this, we write a git commit message body that lists each person's role and email address. We one per line because this is easy to parse.

Example:

To make this easy in practice, we use a git template that helps fill in this info.

Optional: use task tracking links

We sometimes connect a git commit to a task tracking system. For example, we use GitHub, Trello, Jira, and many other bug tracking systems and project management software systems.

To keep track of these, we use a git commit message body that lists each URL, one per line because this is easy to parse.

Example:

Add feature foo

See: https://github.com/user/repo/issues/789
See: https://jira.com/tasks/123
See: https://trello.com/projects/456

To make this easy in practice, we use a git template that helps fill in this info.

Optional: use keywords, importance, references, etc.

We like to use commit message keywords to help us skim, search, and prioritize.

To keep track of these, we write a git commit message body that uses email header conventions.

Example:

Fix foo

Keywords: security, encryption, authentication
Importance: high
References: ...
Supersedes: ...
Obsoletes: ...
See-Also: ...

We use some of these to help our teams focus on the most important work.

  • When a commit message says "Importance: high" then it gets priority for code review and also for testing on the continuous integration server.

  • When a commit message says "Supersedes", "References", "Obsoletes", then we can easily look up the earlier commits or URLs.

Related links

About

Git commit message: how to write a good git commit message

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published