# Conventional Commit Messages
See how a minor change to your commit message style can make a difference. [Examples](#examples)
**Have a look at CLI util [git-conventional-commits](https://github.com/qoomon/git-conventional-commits) to ensure this conventions and generate changelogs**
## Commit Formats
### Default
<type>(<optional scope>): <description> empty separator line <optional body> empty separator line <optional footer>### Merge Commit
Merge branch '<branch name>'Follows default git merge message ### Revert Commit
Revert "<reverted commit subject line>"Follows default git revert message ### Types * API relevant changes * `feat` Commits, that adds a new feature * `fix` Commits, that fixes a bug * `refactor` Commits, that rewrite/restructure your code, however does not change any behaviour * `perf` Commits are special `refactor` commits, that improve performance * `style` Commits, that do not affect the meaning (white-space, formatting, missing semi-colons, etc) * `test` Commits, that add missing tests or correcting existing tests * `docs` Commits, that affect documentation only * `build` Commits, that affect build components like build tool, ci pipeline, dependencies, project version, ... * `ops` Commits, that affect operational components like infrastructure, deployment, backup, recovery, ... * `chore` Miscellaneous commits e.g. modifying `.gitignore` ### Scopes The `scope` provides additional contextual information. * Is an **optional** part of the format * Allowed Scopes depends on the specific project * Don't use issue identifiers as scopes ### Breaking Changes Indicator Breaking changes should be indicated by an `!` before the `:` in the subject line e.g. `feat(api)!: remove status endpoint` * Is an **optional** part of the format ### Description The `description` contains a concise description of the change. * Is a **mandatory** part of the format * Use the imperative, present tense: "change" not "changed" nor "changes" * Think of `This commit will...` or `This commit should...` * Don't capitalize the first letter * No dot (.) at the end ### Body The `body` should include the motivation for the change and contrast this with previous behavior. * Is an **optional** part of the format * Use the imperative, present tense: "change" not "changed" nor "changes" * This is the place to mention issue identifiers and their relations ### Footer The `footer` should contain any information about **Breaking Changes** and is also the place to **reference Issues** that this commit refers to. * Is an **optional** part of the format * **optionally** reference an issue by its id. * **Breaking Changes** should start with the word `BREAKING CHANGES:` followed by space or two newlines. The rest of the commit message is then used for this. ### Examples * `feat`: (this commit will) add email notifications on new direct messages * `fix(api)`: (this commit will) handle empty message in request body * `fix(api)`: (this commit will) fix wrong calculation of request body checksum * `perf`: (this commit will) decrease memory footprint for determine uniqe visitors by using HyperLogLog * `build`: (this commit will) update dependencies * `build(release)`: (this commit will) bump version to 1.0.0 * `feat(shopping cart)`: (this commit will) add the amazing button * `refactor:` implement fibonacci number calculation as recursion * `style`: remove empty line * ``` feat: remove ticket list endpoint refers to JIRA-1337 BREAKING CHANGES: ticket enpoints no longer supports list all entites. ``` * ``` fix: add missing parameter to service call The error occurred because of