Git commit messages standard
Notice: This thread is very old.
- David Grudl
- Nette Core | 8194
I'd like to create a coding style for commit messages. It might help contributors in writing comprehensive summaries.
Subject is the first line of the commit message which should be enough to know what it is about.
- Subject should be not longer than 70 characters.
- Subject must be in the past tense (writing commits and reading a commit history is much more natural, so please, don't discuss this now).
- It is needed to easily distinguish between fixing, adding/changing nad
merging commits. So subject must start with one of these verbs:
- Added (new feature)
- Fixed (bug fix, may include #issue-number)
- Refactored (change in code without changing its behavior)
- Merge/Revert (generated only by Git)
- Typos (I know, it is not a verb…)
- other verbs could be allowed for “changing” commits (Changed, Updated, Removed, Deprecated, …)
- Subject must cleary identify part of framework which commit affects (Database, tests, …)
- The BC break must be indicated in subject.
In other words: it should be possible to generate changelog like this from commit log.
After a subject there can be one empty line and other description, link to forum etc.
- David Grudl
- Nette Core | 8194
Ideas, examples:
Latte: fixed multi template rendering [Closes #269]
Latte: fixed #269 multi template rendering
[Latte] Fixed #269 multi template rendering
[Fixed #269] Latte: multi template rendering
Example of bad commit message is
UI\Presenter: user services are passed via constructor instead of setContext()
.
Better:
UI\Presenter: changed the method used to pass user services to presenter from setContext() to constructor
[Application] Changed the method used to pass user services to presenter from setContext() to constructor
- Milo
- Nette Core | 1283
I like the first one too. Square brackets evoke some kind of link.
What about deeper namespace classes? First example seems fine to me.
Database: fixed method getColumns() in PgSqlDriver
Database: PgSqlDriver: fixed method getColumns()
PgSqlDriver: fixed method getColumns()