Skip to content

A Commit Style Guide

Mithi Sevilla edited this page Jul 2, 2020 · 6 revisions

Prefixes for commits

These prefixes for commits is a work in progress. Suggestions are welcome.

  1. api-breaking / change-behavior

    • Rename public functions
    • Change parameters of class constructors, methods functions
    • Change return type of existing functions
    • Change functionality of existing function
    • Remove existing properties of objects
  2. major-feat a large feature that's user facing

    • functional: Adding new functionality for the app
  3. minor-feat a small enhancement

    • functional: Small changes in functionality, new small utility functions
  4. style / page-design

    • changes in how the page looks, UI, css, etc
  5. prettier / format

    • Fix formatting for consistency, add missing semi colons, etc
    • Add comments within functions (not module or function docstring)
  6. refactor refactoring production code, Recommended to use these verbs:

    • Remove unused code
    • Rename private variables, private functions and methods
    • Move functions to own module
    • Rearrange relative positions of functions or blocks of code within the same file
    • Extract method move some code from a large function to a helper function
    • Reduce cognitive complexity of blocks of codes
    • Reimplement the same thing, but function is now is more readable ( not necessarily faster)
    • Remove duplication, be dry
    • See also: https://sourcemaking.com/refactoring/refactorings
  7. optimization (small, medium, large)

    • Remove redundancy or unnecessary calculations
    • Modifications that improves speed of the app
  8. fix a bug fix

    • Fix something that is not working as expected
  9. test adding tests, refactoring test; no production code change

  10. docs

    • changes to documentation README
    • Writing docstrings or descriptions of modules, classes, functions, or methods
  11. chore updating build tasks, package manager configs, etc; no production code change

Commit Emojis!

Consider starting the commit message with an applicable emoji: (taken from Atom contribution guide!)

  • 🎨 🎨 when improving the format/structure of the code
  • 🐎 🐎 when improving performance
  • πŸ“ πŸ“ when writing docs
  • πŸ› πŸ› when fixing a bug
  • πŸ”₯ πŸ”₯ when removing code or files
  • βœ… βœ… when adding tests

Commit Message

  • Should be no greater than 50 characters
  • Should begin with a capital letter
  • Should not end with a period
  • Use an imperative tone to describe what a commit does, rather than what it did For example, use change; not changed or changes.

Example Commit Message

feat: Summarize changes in around 50 characters or less

Only add a body if necessary. Explain the problem that this commit is solving. 
Focus on why you are making this change as opposed to how (the code explains that).
Write side effects or other unintuitive consequences of this change if any. 

 - Bullet points are okay, too
 - A hyphen or asterisk is used for the bullet

Resolves: #123
See also: #456, #789