2021-06-13 02:14:27 +03:00
< p align = "center" >
< a href = "https://github.com/orhun/git-cliff" >
< img src = "https://user-images.githubusercontent.com/24392180/121790699-8808dc80-cbea-11eb-8ab6-2fb6b08b66d8.png" width = "300" > < / a >
< br >
2021-07-14 21:53:00 +03:00
< a href = "https://github.com/orhun/git-cliff/releases" >
< img src = "https://img.shields.io/github/v/release/orhun/git-cliff?style=flat&labelColor=1C2C2E&color=C96329&logo=GitHub&logoColor=white" >
< / a >
< a href = "https://crates.io/crates/git-cliff/" >
< img src = "https://img.shields.io/crates/v/git-cliff?style=flat&labelColor=1C2C2E&color=C96329&logo=Rust&logoColor=white" >
< / a >
< a href = "https://codecov.io/gh/orhun/git-cliff" >
< img src = "https://img.shields.io/codecov/c/gh/orhun/git-cliff?style=flat&labelColor=1C2C2E&color=C96329&logo=Codecov&logoColor=white" >
< / a >
< br >
< a href = "https://github.com/orhun/git-cliff/actions?query=workflow%3A%22Continuous+Integration%22" >
< img src = "https://img.shields.io/github/workflow/status/orhun/git-cliff/Continuous%20Integration?style=flat&labelColor=1C2C2E&color=BEC5C9&logo=GitHub%20Actions&logoColor=BEC5C9" >
< / a >
< a href = "https://github.com/orhun/git-cliff/actions?query=workflow%3A%22Continuous+Deployment%22" >
< img src = "https://img.shields.io/github/workflow/status/orhun/git-cliff/Continuous%20Deployment?style=flat&labelColor=1C2C2E&color=BEC5C9&logo=GitHub%20Actions&logoColor=BEC5C9&label=deploy" >
< / a >
< a href = "https://hub.docker.com/r/orhunp/git-cliff" >
< img src = "https://img.shields.io/docker/cloud/build/orhunp/git-cliff?style=flat&labelColor=1C2C2E&color=BEC5C9&label=docker&logo=Docker&logoColor=BEC5C9" >
< / a >
< a href = "https://docs.rs/git-cliff-core/" >
< img src = "https://img.shields.io/docsrs/git-cliff-core?style=flat&labelColor=1C2C2E&color=BEC5C9&logo=Rust&logoColor=BEC5C9E" >
< / a >
2021-09-08 14:20:45 +03:00
< br >
< a href = "https://matrix.to/#/#git-cliff:matrix.org" >
< img src = "https://img.shields.io/matrix/git-cliff:matrix.org?style=flat&labelColor=1C2C2E&color=BEC5C9&logo=matrix&logoColor=BEC5C9E&label=join%20matrix" >
< / a >
2021-06-13 02:14:27 +03:00
< / p >
2021-07-14 21:38:53 +03:00
## About
**git-cliff** can generate [changelog ](https://en.wikipedia.org/wiki/Changelog ) files from the [Git ](https://git-scm.com/ ) history by utilizing [conventional commits ](#conventional_commits ) as well as regex-powered [custom parsers ](#commit_parsers ). The [changelog template ](#templating ) can be customized with a [configuration file ](#configuration-file ) to match the desired format.
2021-08-08 22:23:13 +03:00
![preview ](https://user-images.githubusercontent.com/24392180/128637997-5713ba25-d8f3-40c7-8ba8-ea7f333ead88.png )
2021-07-14 22:49:22 +03:00
< details >
< summary > Table of Contents< / summary >
2021-07-14 21:38:53 +03:00
- [About ](#about )
- [Installation ](#installation )
- [From crates.io ](#from-cratesio )
2021-09-04 20:40:04 +03:00
- [Using pacman ](#using-pacman )
2021-09-28 01:27:09 +03:00
- [Binary releases ](#binary-releases )
- [Build from source ](#build-from-source )
2021-07-14 21:38:53 +03:00
- [Usage ](#usage )
- [Command Line Arguments ](#command-line-arguments )
2021-07-22 23:30:51 +03:00
- [Examples ](#examples )
- [Docker ](#docker )
2022-03-06 21:29:27 +03:00
- [GitHub Actions ](#github-actions )
- [git-cliff-action ](#git-cliff-action )
- [setup-git-cliff ](#setup-git-cliff )
2021-10-19 21:17:18 +03:00
- [GitLab CI/CD ](#gitlab-cicd )
2021-07-14 21:38:53 +03:00
- [Configuration File ](#configuration-file )
- [changelog ](#changelog )
- [header ](#header )
- [body ](#body )
- [trim ](#trim )
- [footer ](#footer )
- [git ](#git )
- [conventional_commits ](#conventional_commits )
2021-12-11 15:07:10 +03:00
- [filter_unconventional ](#filter_unconventional )
2022-04-06 15:46:23 +03:00
- [commit_preprocessors ](#commit_preprocessors )
2021-07-14 21:38:53 +03:00
- [commit_parsers ](#commit_parsers )
- [filter_commits ](#filter_commits )
- [tag_pattern ](#tag_pattern )
- [skip_tags ](#skip_tags )
2021-12-07 21:49:37 +03:00
- [ignore_tags ](#ignore_tags )
2022-02-12 19:30:21 +03:00
- [date_order ](#date_order )
2021-11-25 22:45:44 +03:00
- [sort_commits ](#sort_commits )
2022-03-06 21:29:27 +03:00
- [link_parsers ](#link_parsers )
2022-03-27 15:42:33 +03:00
- [Project Integration ](#project-integration )
- [Rust ](#rust )
2021-07-14 21:38:53 +03:00
- [Templating ](#templating )
- [Context ](#context )
- [Conventional Commits ](#conventional-commits )
2021-08-21 00:43:28 +03:00
- [Breaking Changes ](#breaking-changes )
2021-07-14 21:38:53 +03:00
- [Non-Conventional Commits ](#non-conventional-commits )
- [Syntax ](#syntax )
2021-07-22 23:30:51 +03:00
- [Examples ](#examples-1 )
2021-08-03 00:21:05 +03:00
- [Basic ](#basic )
- [Detailed ](#detailed )
- [Scoped ](#scoped )
2021-09-21 16:17:39 +03:00
- [Scoped (Sorted) ](#scoped-sorted )
2021-08-03 00:21:05 +03:00
- [Keep a Changelog ](#keep-a-changelog )
2021-12-11 15:07:10 +03:00
- [Unconventional ](#unconventional )
2021-07-14 21:38:53 +03:00
- [Similar Projects ](#similar-projects )
- [License ](#license )
- [Copyright ](#copyright )
2021-07-14 22:49:22 +03:00
< / details >
2021-06-13 02:14:27 +03:00
## Installation
2021-09-21 16:43:18 +03:00
< details >
< summary > Packaging status< / summary >
[![Packaging status ](https://repology.org/badge/vertical-allrepos/git-cliff.svg )](https://repology.org/project/git-cliff/versions)
< / details >
2021-07-14 21:38:53 +03:00
### From crates.io
[git-cliff ](crates.io/crates/git-cliff ) can be installed from crates.io:
```sh
cargo install git-cliff
```
2021-09-04 20:40:04 +03:00
### Using pacman
2021-08-12 20:13:18 +03:00
2021-09-04 20:40:04 +03:00
If you are using Arch Linux, **git-cliff** can be installed from the [community repository ](https://archlinux.org/packages/community/x86_64/git-cliff/ ):
2021-08-12 20:13:18 +03:00
```sh
2021-09-04 20:40:04 +03:00
pacman -S git-cliff
2021-08-12 20:13:18 +03:00
```
2021-09-28 01:27:09 +03:00
### Binary releases
2021-07-14 21:38:53 +03:00
See the available binaries for different operating systems/architectures from the [releases page ](https://github.com/orhun/git-cliff/releases ).
2021-09-22 00:32:24 +03:00
\* Release tarballs are signed with the following PGP key: [1D2D410A741137EBC544826F4A92FA17B6619297 ](https://keyserver.ubuntu.com/pks/lookup?search=0x4A92FA17B6619297&op=vindex )
2021-09-28 01:27:09 +03:00
### Build from source
* Linux dependencies: [zlib ](https://zlib.net/ )
```sh
# binary will be located at `target/release/git-cliff`
CARGO_TARGET_DIR=target cargo build --release
```
2021-06-13 02:14:27 +03:00
## Usage
2021-07-14 21:38:53 +03:00
### Command Line Arguments
2021-06-16 22:42:54 +03:00
```
2022-02-01 01:06:57 +03:00
git-cliff [FLAGS] [OPTIONS] [--] [RANGE]
2021-06-16 22:42:54 +03:00
```
**Flags:**
```
-v, --verbose Increases the logging verbosity
2021-08-18 23:51:11 +03:00
-i, --init Writes the default configuration file to cliff.toml
2021-06-16 22:42:54 +03:00
-l, --latest Processes the commits starting from the latest tag
2021-12-02 10:01:10 +03:00
--current Processes the commits that belong to the current tag
2021-06-16 22:42:54 +03:00
-u, --unreleased Processes the commits that do not belong to a tag
2022-02-12 19:30:21 +03:00
--date-order Sorts the tags chronologically
2022-03-27 00:36:24 +03:00
--context Prints changelog context as JSON
2021-06-16 22:42:54 +03:00
-h, --help Prints help information
-V, --version Prints version information
```
**Options:**
```
2022-04-05 01:17:18 +03:00
-c, --config < PATH > Sets the configuration file [env: GIT_CLIFF_CONFIG=] [default: cliff.toml]
-w, --workdir < PATH > Sets the working directory [env: GIT_CLIFF_WORKDIR=]
-r, --repository < PATH > Sets the git repository [env: GIT_CLIFF_REPOSITORY=]
--include-path < PATTERN > ... Sets the path to include related commits [env: GIT_CLIFF_INCLUDE_PATH=]
--exclude-path < PATTERN > ... Sets the path to exclude related commits [env: GIT_CLIFF_EXCLUDE_PATH=]
--with-commit < MSG > ... Sets custom commit messages to include in the changelog [env: GIT_CLIFF_WITH_COMMIT=]
-p, --prepend < PATH > Prepends entries to the given changelog file [env: GIT_CLIFF_PREPEND=]
-o, --output < PATH > Writes output to the given file [env: GIT_CLIFF_OUTPUT=]
-t, --tag < TAG > Sets the tag for the latest version [env: GIT_CLIFF_TAG=]
-b, --body < TEMPLATE > Sets the template for the changelog body [env: GIT_CLIFF_TEMPLATE=]
2022-02-01 01:06:57 +03:00
-s, --strip < PART > Strips the given parts from the changelog [possible values: header, footer, all]
--sort < SORT > Sets sorting of the commits inside sections [default: oldest] [possible values: oldest, newest]
2021-06-16 22:42:54 +03:00
```
**Args:**
```
< RANGE > Sets the commit range to process
```
2021-07-22 23:30:51 +03:00
### Examples
2021-08-18 03:51:04 +03:00
The default [configuration file ](#configuration-file ) (`cliff.toml`) can be generated using the `--init` flag:
```sh
# create cliff.toml
git cliff --init
```
Then simply create a changelog at your projects git root directory:
2021-07-22 23:30:51 +03:00
```sh
# same as running `git-cliff --config cliff.toml --repository .`
# same as running `git-cliff --workdir .`
git cliff
```
Set a tag for the "unreleased" changes:
```sh
git cliff --tag 1.0.0
```
2021-09-09 00:34:25 +03:00
Generate a changelog for a certain part of git history:
2021-07-22 23:30:51 +03:00
```sh
# only takes the latest tag into account
git cliff --latest
2021-12-02 10:01:10 +03:00
# only takes the current tag into account
# useful if you checkout a specific tag (e.g. `git checkout v0.0.1`)
# (requires a tag to be present for the current commit (i.e. HEAD))
git cliff --current
2021-07-22 23:30:51 +03:00
# generate changelog for unreleased commits
git cliff --unreleased
git cliff --unreleased --tag 1.0.0
# generate changelog for a specific commit range
git cliff 4c7b043..a440c6e
git cliff 4c7b043..HEAD
git cliff HEAD~2..
```
2021-09-09 00:34:25 +03:00
Generate a changelog scoped to a specific directory (useful for monorepos):
```sh
2021-12-01 22:58:49 +03:00
git cliff --include-path "**/*.toml" --include-path "*.md"
2021-12-01 22:50:12 +03:00
git cliff --exclude-path ".github/*"
2021-09-09 00:34:25 +03:00
```
2021-12-11 19:14:29 +03:00
Generate a changelog that includes yet unexisting commit messages:
```sh
commit_msg="chore(release): update CHANGELOG.md for 1.0.0"
# You might need to include the commit messages that do not exist
# for testing purposes or solving the chicken-egg problem.
2021-12-11 19:19:42 +03:00
git cliff --with-commit "$commit_msg" -o CHANGELOG.md
2021-12-11 19:14:29 +03:00
2021-12-11 19:19:42 +03:00
git add CHANGELOG.md & & git commit -m "$commit_msg"
2021-12-11 19:14:29 +03:00
```
2021-09-28 22:58:05 +03:00
Sort the commits inside sections:
```sh
# The oldest commit will be on top.
# (default)
git cliff --sort oldest
# The newest commit will be on top.
git cliff --sort newest
```
2022-02-12 19:30:21 +03:00
Sort the tags in chronological order:
2021-10-30 01:02:00 +03:00
```sh
2022-02-12 19:30:21 +03:00
# Process in chronological order instead of topological.
git cliff --date-order
2021-10-30 01:02:00 +03:00
```
2021-07-22 23:30:51 +03:00
Save the changelog file to the specified file:
```sh
git cliff --output CHANGELOG.md
```
2022-03-27 00:36:24 +03:00
Print the changelog [context ](#context ) as JSON:
```sh
# print context to stdout
git cliff --context
# save context to a file
git cliff --context --output context.json
```
2021-07-22 23:30:51 +03:00
Prepend new changes to an existing changelog file:
```sh
# 1- changelog header is removed from CHANGELOG.md
# 2- new entries are prepended to CHANGELOG.md without footer part
git cliff --unreleased --tag 1.0.0 --prepend CHANGELOG.md
```
Set/remove the changelog parts:
```sh
git cliff --body $template --strip footer
```
Also, see the [release script ](./release.sh ) of this project which sets the changelog as a message of an annotated tag.
## Docker
The easiest way of running **git-cliff** (in the git root directory with [configuration file ](#configuration-file ) present) is to use the [available tags ](https://hub.docker.com/repository/docker/orhunp/git-cliff/tags ) from [Docker Hub ](https://hub.docker.com/repository/docker/orhunp/git-cliff ):
```sh
2021-09-04 17:20:36 +03:00
docker run -t -v "$(pwd)/.git":/app/ orhunp/git-cliff:latest
2021-07-22 23:30:51 +03:00
```
Or you can use the image from the [GitHub Package Registry ](https://github.com/orhun/git-cliff/packages/841947 ):
```sh
2021-09-04 17:20:36 +03:00
docker run -t -v "$(pwd)/.git":/app/ docker.pkg.github.com/orhun/git-cliff/git-cliff:latest
2021-07-22 23:30:51 +03:00
```
Also, you can build the image yourself using `docker build -t git-cliff .` command.
2022-03-06 21:29:27 +03:00
## GitHub Actions
### git-cliff-action
2021-07-22 23:30:51 +03:00
It is possible to generate changelogs using [GitHub Actions ](https://docs.github.com/en/actions ) via [git-cliff-action ](https://github.com/orhun/git-cliff-action ).
```yml
- name: Generate a changelog
uses: orhun/git-cliff-action@v1
with:
config: cliff.toml
args: --verbose
env:
OUTPUT: CHANGELOG.md
```
See the [repository ](https://github.com/orhun/git-cliff-action ) for other [examples ](https://github.com/orhun/git-cliff-action#examples ).
Also, see the [continuous deployment workflow ](./.github/workflows/cd.yml ) of this project which sets the release notes for GitHub releases using this action.
2022-03-06 21:29:27 +03:00
### setup-git-cliff
There is also another GitHub Action which is [setup-git-cliff ](https://github.com/kenji-miyake/setup-git-cliff ).
While `git-cliff-action` uses the Docker image generated by [docker.yml ](https://github.com/orhun/git-cliff/blob/main/.github/workflows/docker.yml ), `setup-git-cliff` installs the binary executable in the [release artifacts ](https://github.com/orhun/git-cliff/releases/latest ):
```yml
- name: Check out repository
uses: actions/checkout@v2
- name: Set up git-cliff
uses: kenji-miyake/setup-git-cliff@v1
- name: Run git-cliff
run: |
git cliff
```
See a practical example [here ](https://github.com/autowarefoundation/autoware-github-actions/blob/v1/generate-changelog/action.yaml ).
2021-10-19 21:12:57 +03:00
## GitLab CI/CD
It is possible to generate changelogs using [GitLab CI/CD ](https://docs.gitlab.com/ee/ci/ ).
2021-10-19 21:17:18 +03:00
This minimal example creates artifacts that can be used on another job.
2021-10-19 21:12:57 +03:00
```yml
- changelog:
image:
name: orhunp/git-cliff:latest
entrypoint: [""]
variables:
GIT_STRATEGY: clone # clone entire repo instead of reusing workspace
GIT_DEPTH: 0 # avoid shallow clone to give cliff all the info it needs
stage: doc
script:
- git-cliff -r . > CHANGELOG.md
artifacts:
paths:
2021-10-19 21:17:18 +03:00
- CHANGELOG.md
2021-10-19 21:12:57 +03:00
```
2021-12-31 21:10:37 +03:00
Please note that the stage is `doc` and has to be changed accordingly to your need.
2021-10-19 21:12:57 +03:00
2021-07-14 21:38:53 +03:00
## Configuration File
**git-cliff** configuration file supports [TOML ](https://github.com/toml-lang/toml ) (preferred) and [YAML ](https://yaml.org ) formats.
2021-08-18 23:46:37 +03:00
The configuration file is read from `$HOME/git-cliff/cliff.toml` if the file exists. This location depends on the platform, for example:
- on Linux: `/home/<user>/.config/git-cliff/cliff.toml`
- on Windows: `C:\Users\<user>\AppData\Roaming\git-cliff\cliff.toml`
- on macOS: `/Users/<user>/Library/Application Support/git-cliff/cliff.toml`
See [config/cliff.toml ](./config/cliff.toml ) for the default configuration values.
2021-07-14 21:38:53 +03:00
### changelog
This section contains the configuration options for changelog generation.
```toml
[changelog]
header = "Changelog"
body = """
{% for group, commits in commits | group_by(attribute="group") %}
### {{ group | upper_first }}
{% for commit in commits %}
- {{ commit.message | upper_first }}
{% endfor %}
{% endfor %}
"""
trim = true
footer = "<!-- generated by git - cliff --> "
```
#### header
Header text that will be added to the beginning of the changelog.
#### body
Body template that represents a single release in the changelog.
See [templating ](#templating ) for more detail.
#### trim
2022-02-08 18:11:11 +03:00
If set to `true` , leading and trailing whitespace are removed from the [body ](#body ).
2021-07-14 21:38:53 +03:00
It is useful for adding indentation to the template for readability, as shown [in the example ](#changelog ).
#### footer
Footer text that will be added to the end of the changelog.
### git
This section contains the parsing and git related configuration options.
```toml
[git]
conventional_commits = true
2021-12-11 15:07:10 +03:00
filter_unconventional = true
2021-07-14 21:38:53 +03:00
commit_parsers = [
2021-09-08 21:58:02 +03:00
{ message = "^feat", group = "Features"},
{ message = "^fix", group = "Bug Fixes"},
{ message = "^doc", group = "Documentation"},
{ message = "^perf", group = "Performance"},
{ message = "^refactor", group = "Refactor"},
{ message = "^style", group = "Styling"},
{ message = "^test", group = "Testing"},
2021-07-14 21:38:53 +03:00
]
filter_commits = false
tag_pattern = "v[0-9]*"
skip_tags = "v0.1.0-beta.1"
2021-12-07 21:49:37 +03:00
ignore_tags = ""
2022-02-12 19:30:21 +03:00
date_order = false
2021-11-25 22:45:44 +03:00
sort_commits = "oldest"
2021-12-31 21:10:37 +03:00
link_parsers = [
{ pattern = "#(\\d+)", href = "https://github.com/orhun/git-cliff/issues/$1"},
{ pattern = "RFC(\\d+)", text = "ietf-rfc$1", href = "https://datatracker.ietf.org/doc/html/rfc$1"},
]
2021-07-14 21:38:53 +03:00
```
#### conventional_commits
2021-12-11 15:07:10 +03:00
If set to `true` , commits are parsed according to the [Conventional Commits specifications ](https://www.conventionalcommits.org ).
2021-07-14 21:38:53 +03:00
> The Conventional Commits specification is a lightweight convention on top of commit messages. It provides an easy set of rules for creating an explicit commit history; which makes it easier to write automated tools on top of. This convention dovetails with SemVer, by describing the features, fixes, and breaking changes made in commit messages.
> The commit message should be structured as follows:
```
< type > [optional scope]: < description >
[optional body]
[optional footer(s)]
```
e.g. `feat(parser): add ability to parse arrays`
2021-12-11 15:07:10 +03:00
#### filter_unconventional
If set to `true` , commits that are not conventional are excluded. This option can be used to generate changelogs with conventional and unconvential commits mixed together. For example:
```toml
conventional_commits = true
filter_unconventional = false
commit_parsers = [
{ message = ".*", group = "Other", default_scope = "other"},
]
```
With the configuration above, conventional commits are parsed as usual and unconventional commits will be also included in the changelog as "Other".
To completely exclude unconventional commits from the changelog:
```toml
# default behaviour
conventional_commits = true
filter_unconventional = true
```
To include any type of commit in the changelog without parsing:
```toml
conventional_commits = false
filter_unconventional = false
```
2022-04-06 15:46:23 +03:00
#### commit_preprocessors
An array of commit preprocessors for manipulating the commit messages before parsing/grouping them. These regex-based preprocessors can be used for removing or selecting certain parts of the commit message/body to be used in the following processes.
Examples:
- `{ pattern = "foo", replace = "bar"}`
- Replace text
- `{ pattern = 'Merged PR #[0-9]: (.*)', replace = "$1"}`
- Remove prefix
- `{ pattern = " +", replace = " "}`
- Replace multiple spaces with a single space
- `{ pattern = "\\(#([0-9]+)\\)", replace = "([#${1}](https://github.com/orhun/git-cliff/issues/${1}))"}`
- Replace the issue number with the link
- `{ pattern = "https://github.com/.*/issues/([0-9]+)", replace = "[Issue #${1}]"}`
- Replace the issue link with the number
2021-07-14 21:38:53 +03:00
#### commit_parsers
An array of commit parsers for determining the commit groups by using regex.
Examples:
2021-09-08 21:40:29 +03:00
- `{ message = "^feat", group = "Features"}`
2021-07-14 21:38:53 +03:00
- Group the commit as "Features" if the commit message (description) starts with "feat".
- `{ body = ".*security", group = "Security"}`
- Group the commit as "Security" if the commit body contains "security".
- `{ message = ".*deprecated", body = ".*deprecated", group = "Deprecation"}`
- Group the commit as "Deprecation" if the commit body and message contains "deprecated".
2021-09-08 21:40:29 +03:00
- `{ message = "^revert", skip = true}`
2021-07-14 21:38:53 +03:00
- Skip processing the commit if the commit message (description) starts with "revert".
2021-09-08 21:58:02 +03:00
- `{ message = "^doc", group = "Documentation", default_scope = "other"},`
2021-09-07 00:23:08 +03:00
- If the commit starts with "doc", group the commit as "Documentation" and set the default scope to "other". (e.g. `docs: xyz` will be processed as `docs(other): xyz` )
2021-07-14 21:38:53 +03:00
#### filter_commits
2021-06-13 02:14:27 +03:00
2021-07-14 21:38:53 +03:00
If set to `true` , commits that are not matched by [commit parsers ](#commit_parsers ) are filtered out.
#### tag_pattern
A glob pattern for matching the git tags.
e.g. It processes the same tags as the output of the following git command:
```sh
git tag --list 'v[0-9]*'
```
#### skip_tags
A regex for skip processing the matched tags.
2021-12-07 21:49:37 +03:00
#### ignore_tags
A regex for ignore processing the matched tags.
While `skip_tags` drop commits from the changelog, `ignore_tags` include ignored commits into the next tag.
2022-02-12 19:30:21 +03:00
#### date_order
2021-11-25 22:45:44 +03:00
If set to `true` , tags are processed in topological order instead of chronological.
2022-02-12 19:30:21 +03:00
This can also be achieved by using the `--date-order` command line flag.
2021-11-25 22:45:44 +03:00
#### sort_commits
Sort the commits inside sections by specified order.
Possible values:
- `oldest`
- `newest`
This can also be achieved by specifying the `--sort` command line argument.
2021-12-31 21:10:37 +03:00
#### link_parsers
An array of link parsers for extracting external references, and turning them into URLs, using regex.
Examples:
- `{ pattern = "#(\\d+)", href = "https://github.com/orhun/git-cliff/issues/$1"}`
- Extract all GitLab issues and PRs and generate URLs linking to them. The link text will be the matching pattern.
- `{ pattern = "RFC(\\d+)", text = "ietf-rfc$1", href = "https://datatracker.ietf.org/doc/html/rfc$1"}` ,
2022-01-17 00:17:54 +03:00
- Extract mentions of IETF RFCs and generate URLs linking to them. It also rewrites the text as "ietf-rfc...".
2021-12-31 21:10:37 +03:00
2022-03-27 15:42:33 +03:00
## Project Integration
### Rust
For Rust projects, **git-cliff** can be configured in `Cargo.toml` via [metadata table ](https://doc.rust-lang.org/cargo/reference/manifest.html#the-metadata-table ). To do this, simply replace the available configuration sections with `[package.metadata.git-cliff.<section>]` and place them inside `Cargo.toml` . For example:
```toml
[package]
name = "..."
[dependencies]
# ...
[package.metadata.git-cliff.changelog]
header = "All notable changes to this project will be documented in this file."
body = "..."
footer = "<!-- generated by git - cliff --> "
# see [changelog] section for more keys
[package.metadata.git-cliff.git]
conventional_commits = true
commit_parsers = []
filter_commits = false
# see [git] section for more keys
```
For Cargo workspaces, [`workspace.metadata` ](https://doc.rust-lang.org/cargo/reference/workspaces.html#the-workspacemetadata-table ) table can be used. (e.g. `[workspace.metadata.git-cliff.<section>]` )
2021-07-14 21:38:53 +03:00
## Templating
A template is a text where variables and expressions get replaced with values when it is rendered.
### Context
Context is the model that holds the required data for a template rendering. The [JSON ](https://en.wikipedia.org/wiki/JSON ) format is used in the following examples for the representation of a context.
#### Conventional Commits
> conventional_commits = **true**
For a [conventional commit ](#conventional_commits ) like this,
```
< type > [scope]: < description >
[body]
2021-07-18 19:00:02 +03:00
[footer(s)]
2021-07-14 21:38:53 +03:00
```
following context is generated to use for templating:
```json
{
"version": "v0.1.0-rc.21",
"commits": [
{
"id": "e795460c9bb7275294d1fa53a9d73258fb51eb10",
2021-07-14 22:21:13 +03:00
"group": "< type > (overrided by commit_parsers)",
2021-07-14 21:38:53 +03:00
"scope": "[scope]",
"message": "< description > ",
"body": "[body]",
2021-07-18 19:00:02 +03:00
"footers": ["[footer]", "[footer]"],
2021-08-21 00:43:28 +03:00
"breaking_description": "< description > ",
2021-12-11 15:07:10 +03:00
"breaking": false,
2021-12-31 21:10:37 +03:00
"conventional": true,
2022-01-17 00:21:37 +03:00
"links": [{"text": "(set by link_parsers)", "href": "(set by link_parsers)"}]
2021-07-14 21:38:53 +03:00
}
],
2021-07-14 22:21:13 +03:00
"commit_id": "a440c6eb26404be4877b7e3ad592bfaa5d4eb210 (release commit)",
2021-07-14 21:38:53 +03:00
"timestamp": 1625169301,
2021-07-14 22:21:13 +03:00
"previous": {
2021-07-18 19:00:02 +03:00
"version": "previous release"
2021-07-14 22:21:13 +03:00
}
2021-07-14 21:38:53 +03:00
}
```
2021-08-21 00:43:28 +03:00
##### Breaking Changes
`breaking` flag is set to `true` when the commit has an exclamation mark after the commit type and scope, e.g.:
```
feat(scope)!: this is a breaking change
```
Or when the `BREAKING CHANGE:` footer is defined:
```
feat: add xyz
BREAKING CHANGE: this is a breaking change
```
`breaking_description` is set to the explanation of the breaking change. This description is expected to be present in the `BREAKING CHANGE` footer. However, if it's not provided, the `message` is expected to describe the breaking change.
2021-07-14 21:38:53 +03:00
#### Non-Conventional Commits
> conventional_commits = **false**
If [conventional_commits ](#conventional_commits ) is set to `false` , then some of the fields are omitted from the context or squashed into the `message` field:
```json
{
"version": "v0.1.0-rc.21",
"commits": [
{
"id": "e795460c9bb7275294d1fa53a9d73258fb51eb10",
2021-07-14 22:21:13 +03:00
"group": "(overrided by commit_parsers)",
2021-12-11 15:07:10 +03:00
"scope": "(overrided by commit_parsers)",
"message": "(full commit message including description, footers, etc.)",
"conventional": false,
2022-01-17 00:21:37 +03:00
"links": [{"text": "(set by link_parsers)", "href": "(set by link_parsers)"}]
2021-07-14 21:38:53 +03:00
}
],
2021-07-14 22:21:13 +03:00
"commit_id": "a440c6eb26404be4877b7e3ad592bfaa5d4eb210 (release commit)",
2021-07-14 21:38:53 +03:00
"timestamp": 1625169301,
2021-07-14 22:21:13 +03:00
"previous": {
2021-07-18 19:00:02 +03:00
"version": "previous release"
2021-07-14 22:21:13 +03:00
}
2021-07-14 21:38:53 +03:00
}
```
### Syntax
2021-07-22 23:30:51 +03:00
**git-cliff** uses [Tera ](https://github.com/Keats/tera ) as the template engine. It has a syntax based on [Jinja2 ](http://jinja.pocoo.org/ ) and [Django ](https://docs.djangoproject.com/en/3.1/topics/templates/ ) templates.
2021-07-14 21:38:53 +03:00
There are 3 kinds of delimiters and those cannot be changed:
- `{{` and `}}` for expressions
- `{%` or `{%-` and `%}` or `-%}` for statements
- `{#` and `#}` for comments
2021-07-18 19:00:02 +03:00
See the [Tera Documentation ](https://tera.netlify.app/docs/#templates ) for more information about [control structures ](https://tera.netlify.app/docs/#control-structures ), [built-ins filters ](https://tera.netlify.app/docs/#built-ins ), etc.
Custom built-in filters that **git-cliff** uses:
- `upper_first` : Converts the first character of a string to uppercase.
2021-07-14 21:38:53 +03:00
2021-07-22 23:30:51 +03:00
### Examples
2021-07-14 21:38:53 +03:00
2021-07-18 19:00:02 +03:00
Examples are based on the following Git history:
```log
* df6aef4 (HEAD -> master) feat(cache): use cache while fetching pages
* a9d4050 feat(config): support multiple file formats
2021-07-22 23:30:51 +03:00
* 06412ac (tag: v1.0.1) chore(release): add release script
2021-07-18 19:00:02 +03:00
* e4fd3cf refactor(parser): expose string functions
2021-07-22 23:30:51 +03:00
* ad27b43 (tag: v1.0.0) docs(example)!: add tested usage example
2021-07-18 19:00:02 +03:00
* 9add0d4 fix(args): rename help argument due to conflict
* a140cef feat(parser): add ability to parse arrays
* 81fbc63 docs(project): add README.md
* a78bc36 Initial commit
```
2021-08-03 00:21:05 +03:00
See [examples ](./examples/ ) directory for example configuration files.
2021-08-21 00:48:21 +03:00
If you have a custom configuration file that you are using for your project(s), consider sharing it with us by [submitting a pull request ](./CONTRIBUTING.md )!
2021-08-17 21:49:21 +03:00
#### [Basic](./config/cliff.toml)
2021-08-03 00:21:05 +03:00
< details >
< summary > Raw Output< / summary >
```
# Changelog
2022-02-08 18:11:11 +03:00
2021-08-03 00:21:05 +03:00
All notable changes to this project will be documented in this file.
## [unreleased]
### Features
- Support multiple file formats
- Use cache while fetching pages
## [1.0.1] - 2021-07-18
### Miscellaneous Tasks
- Add release script
### Refactor
- Expose string functions
## [1.0.0] - 2021-07-18
### Bug Fixes
- Rename help argument due to conflict
### Documentation
- Add README.md
- Add tested usage example
### Features
- Add ability to parse arrays
<!-- generated by git - cliff -->
```
< / details >
< details >
< summary > Rendered Output< / summary >
2021-08-03 00:29:32 +03:00
# Changelog
2022-02-08 18:11:11 +03:00
2021-08-03 00:29:32 +03:00
All notable changes to this project will be documented in this file.
## [unreleased]
### Features
- Support multiple file formats
- Use cache while fetching pages
## [1.0.1] - 2021-07-18
### Miscellaneous Tasks
- Add release script
### Refactor
- Expose string functions
## [1.0.0] - 2021-07-18
### Bug Fixes
- Rename help argument due to conflict
### Documentation
- Add README.md
- Add tested usage example
### Features
- Add ability to parse arrays
<!-- generated by git - cliff -->
2021-08-03 00:21:05 +03:00
< / details >
2022-01-29 18:53:26 +03:00
#### [Minimal](./examples/minimal.toml)
< details >
< summary > Raw Output< / summary >
```
## [unreleased]
### Feat
- Support multiple file formats
- Use cache while fetching pages
## [1.0.1] - 2021-07-18
### Chore
- Add release script
### Refactor
- Expose string functions
## [1.0.0] - 2021-07-18
### Docs
- Add README.md
- [**breaking**] Add tested usage example
### Feat
- Add ability to parse arrays
### Fix
- Rename help argument due to conflict
```
< / details >
< details >
< summary > Rendered Output< / summary >
## [unreleased]
### Feat
- Support multiple file formats
- Use cache while fetching pages
## [1.0.1] - 2021-07-18
### Chore
- Add release script
### Refactor
- Expose string functions
## [1.0.0] - 2021-07-18
### Docs
- Add README.md
- [**breaking**] Add tested usage example
### Feat
- Add ability to parse arrays
### Fix
- Rename help argument due to conflict
< / details >
2021-08-03 00:21:05 +03:00
#### [Detailed](./examples/detailed.toml)
< details >
< summary > Raw Output< / summary >
```
# Changelog
2022-02-08 18:11:11 +03:00
2021-08-03 00:21:05 +03:00
All notable changes to this project will be documented in this file.
## [unreleased]
### Features
2021-08-03 00:34:54 +03:00
- Support multiple file formats ([a9d4050](a9d4050212a18f6b3bd76e2e41fbb9045d268b80))
- Use cache while fetching pages ([df6aef4](df6aef41292f3ffe5887754232e6ea7831c50ba5))
2021-08-03 00:21:05 +03:00
## [1.0.1] - 2021-07-18
2021-08-03 00:34:54 +03:00
[ad27b43 ](ad27b43e8032671afb4809a1a3ecf12f45c60e0e )...[06412ac](06412ac1dd4071006c465dde6597a21d4367a158)
2021-08-03 00:21:05 +03:00
### Miscellaneous Tasks
2021-08-03 00:34:54 +03:00
- Add release script ([06412ac](06412ac1dd4071006c465dde6597a21d4367a158))
2021-08-03 00:21:05 +03:00
### Refactor
2021-08-03 00:34:54 +03:00
- Expose string functions ([e4fd3cf](e4fd3cf8e2e6f49c0b57f66416e886c37cbb3715))
2021-08-03 00:21:05 +03:00
## [1.0.0] - 2021-07-18
### Bug Fixes
2021-08-03 00:34:54 +03:00
- Rename help argument due to conflict ([9add0d4](9add0d4616dc95a6ea8b01d5e4d233876b6e5e00))
2021-08-03 00:21:05 +03:00
### Documentation
2021-08-03 00:34:54 +03:00
- Add README.md ([81fbc63](81fbc6365484abf0b4f4b05d384175763ad8db44))
- Add tested usage example ([ad27b43](ad27b43e8032671afb4809a1a3ecf12f45c60e0e))
2021-08-03 00:21:05 +03:00
### Features
2021-08-03 00:34:54 +03:00
- Add ability to parse arrays ([a140cef](a140cef0405e0bcbfb5de44ff59e091527d91b38))
2021-08-03 00:21:05 +03:00
<!-- generated by git - cliff -->
```
< / details >
< details >
< summary > Rendered Output< / summary >
2021-08-03 00:29:32 +03:00
# Changelog
2022-02-08 18:11:11 +03:00
2021-08-03 00:29:32 +03:00
All notable changes to this project will be documented in this file.
## [unreleased]
### Features
2021-08-03 00:34:54 +03:00
- Support multiple file formats ([a9d4050](a9d4050212a18f6b3bd76e2e41fbb9045d268b80))
- Use cache while fetching pages ([df6aef4](df6aef41292f3ffe5887754232e6ea7831c50ba5))
2021-08-03 00:29:32 +03:00
## [1.0.1] - 2021-07-18
2021-08-03 00:34:54 +03:00
[ad27b43 ](ad27b43e8032671afb4809a1a3ecf12f45c60e0e )...[06412ac](06412ac1dd4071006c465dde6597a21d4367a158)
2021-08-03 00:29:32 +03:00
### Miscellaneous Tasks
2021-08-03 00:34:54 +03:00
- Add release script ([06412ac](06412ac1dd4071006c465dde6597a21d4367a158))
2021-08-03 00:29:32 +03:00
### Refactor
2021-08-03 00:34:54 +03:00
- Expose string functions ([e4fd3cf](e4fd3cf8e2e6f49c0b57f66416e886c37cbb3715))
2021-08-03 00:29:32 +03:00
## [1.0.0] - 2021-07-18
### Bug Fixes
2021-08-03 00:34:54 +03:00
- Rename help argument due to conflict ([9add0d4](9add0d4616dc95a6ea8b01d5e4d233876b6e5e00))
2021-08-03 00:29:32 +03:00
### Documentation
2021-08-03 00:34:54 +03:00
- Add README.md ([81fbc63](81fbc6365484abf0b4f4b05d384175763ad8db44))
- Add tested usage example ([ad27b43](ad27b43e8032671afb4809a1a3ecf12f45c60e0e))
2021-08-03 00:29:32 +03:00
### Features
2021-08-03 00:34:54 +03:00
- Add ability to parse arrays ([a140cef](a140cef0405e0bcbfb5de44ff59e091527d91b38))
2021-08-03 00:29:32 +03:00
<!-- generated by git - cliff -->
2021-08-03 00:21:05 +03:00
< / details >
#### [Scoped](./examples/scoped.toml)
< details >
< summary > Raw Output< / summary >
```
# Changelog
2022-02-08 18:11:11 +03:00
2021-08-03 00:21:05 +03:00
All notable changes to this project will be documented in this file.
## [unreleased]
### Features
#### Cache
- Use cache while fetching pages
#### Config
- Support multiple file formats
## [1.0.1] - 2021-07-18
### Miscellaneous Tasks
#### Release
- Add release script
### Refactor
#### Parser
- Expose string functions
## [1.0.0] - 2021-07-18
### Bug Fixes
#### Args
- Rename help argument due to conflict
### Documentation
#### Example
- Add tested usage example
#### Project
- Add README.md
### Features
#### Parser
- Add ability to parse arrays
<!-- generated by git - cliff -->
```
< / details >
< details >
< summary > Rendered Output< / summary >
2021-08-03 00:29:32 +03:00
# Changelog
2022-02-08 18:11:11 +03:00
2021-08-03 00:29:32 +03:00
All notable changes to this project will be documented in this file.
## [unreleased]
### Features
#### Cache
- Use cache while fetching pages
#### Config
- Support multiple file formats
## [1.0.1] - 2021-07-18
### Miscellaneous Tasks
#### Release
- Add release script
### Refactor
#### Parser
- Expose string functions
## [1.0.0] - 2021-07-18
### Bug Fixes
#### Args
- Rename help argument due to conflict
### Documentation
#### Example
- Add tested usage example
#### Project
- Add README.md
### Features
#### Parser
- Add ability to parse arrays
<!-- generated by git - cliff -->
2021-08-03 00:21:05 +03:00
< / details >
2021-09-21 16:17:39 +03:00
#### [Scoped (Sorted)](./examples/scopesorted.toml)
< details >
< summary > Raw Output< / summary >
2021-09-21 16:40:47 +03:00
```
# Changelog
2022-02-08 18:11:11 +03:00
2021-09-21 16:40:47 +03:00
All notable changes to this project will be documented in this file.
## [unreleased]
### Features
- *(cache)* Use cache while fetching pages
- *(config)* Support multiple file formats
## [1.0.1] - 2021-07-18
### Miscellaneous Tasks
- *(release)* Add release script
### Refactor
- *(parser)* Expose string functions
## [1.0.0] - 2021-07-18
### Bug Fixes
- *(args)* Rename help argument due to conflict
### Documentation
- *(example)* Add tested usage example
- **BREAKING**: add tested usage example
- *(project)* Add README.md
### Features
- *(parser)* Add ability to parse arrays
<!-- generated by git - cliff -->
```
2021-09-21 16:17:39 +03:00
< / details >
< details >
< summary > Rendered Output< / summary >
2021-09-21 16:40:47 +03:00
# Changelog
2022-02-08 18:11:11 +03:00
2021-09-21 16:40:47 +03:00
All notable changes to this project will be documented in this file.
## [unreleased]
### Features
- *(cache)* Use cache while fetching pages
- *(config)* Support multiple file formats
## [1.0.1] - 2021-07-18
### Miscellaneous Tasks
- *(release)* Add release script
### Refactor
- *(parser)* Expose string functions
## [1.0.0] - 2021-07-18
### Bug Fixes
- *(args)* Rename help argument due to conflict
### Documentation
- *(example)* Add tested usage example
- **BREAKING**: add tested usage example
- *(project)* Add README.md
### Features
- *(parser)* Add ability to parse arrays
<!-- generated by git - cliff -->
2021-09-21 16:17:39 +03:00
< / details >
2021-08-03 00:21:05 +03:00
#### [Keep a Changelog](./examples/keepachangelog.toml)
< details >
< summary > Raw Output< / summary >
```
# Changelog
2022-02-08 18:11:11 +03:00
2021-08-03 00:21:05 +03:00
All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog ](https://keepachangelog.com/en/1.0.0/ ),
and this project adheres to [Semantic Versioning ](https://semver.org/spec/v2.0.0.html ).
2022-03-13 13:30:57 +03:00
## [Unreleased]
2021-08-03 00:21:05 +03:00
### Added
- Support multiple file formats
### Changed
- Use cache while fetching pages
## [1.0.1] - 2021-07-18
### Added
- Add release script
### Changed
- Expose string functions
## [1.0.0] - 2021-07-18
### Added
- Add README.md
- Add ability to parse arrays
- Add tested usage example
### Fixed
- Rename help argument due to conflict
<!-- generated by git - cliff -->
```
< / details >
< details >
< summary > Rendered Output< / summary >
2021-08-03 00:29:32 +03:00
# Changelog
2022-02-08 18:11:11 +03:00
2021-08-03 00:29:32 +03:00
All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog ](https://keepachangelog.com/en/1.0.0/ ),
and this project adheres to [Semantic Versioning ](https://semver.org/spec/v2.0.0.html ).
2022-03-13 13:30:57 +03:00
## [Unreleased]
2021-08-03 00:29:32 +03:00
### Added
- Support multiple file formats
### Changed
- Use cache while fetching pages
## [1.0.1] - 2021-07-18
### Added
- Add release script
### Changed
- Expose string functions
## [1.0.0] - 2021-07-18
### Added
- Add README.md
- Add ability to parse arrays
- Add tested usage example
### Fixed
- Rename help argument due to conflict
<!-- generated by git - cliff -->
2021-08-03 00:21:05 +03:00
< / details >
2021-07-18 19:00:02 +03:00
2021-12-11 15:07:10 +03:00
#### [Unconventional](./examples/unconventional.toml)
< details >
< summary > Raw Output< / summary >
```
# Changelog
2022-02-08 18:11:11 +03:00
2021-12-11 15:07:10 +03:00
All notable changes to this project will be documented in this file.
## [unreleased]
### Features
- Support multiple file formats ✔️
- Use cache while fetching pages ✔️
## [1.0.1] - 2021-07-18
### Miscellaneous Tasks
- Add release script ✔️
### Refactor
- Expose string functions ✔️
## [1.0.0] - 2021-07-18
### Bug Fixes
- Rename help argument due to conflict ✔️
### Documentation
- Add README.md ✔️
- Add tested usage example ✔️
### Features
- Add ability to parse arrays ✔️
### Other (unconventional)
- Initial commit ❌
<!-- generated by git - cliff -->
```
< / details >
< details >
< summary > Rendered Output< / summary >
# Changelog
2022-02-08 18:11:11 +03:00
2021-12-11 15:07:10 +03:00
All notable changes to this project will be documented in this file.
## [unreleased]
### Features
- Support multiple file formats ✔️
- Use cache while fetching pages ✔️
## [1.0.1] - 2021-07-18
### Miscellaneous Tasks
- Add release script ✔️
### Refactor
- Expose string functions ✔️
## [1.0.0] - 2021-07-18
### Bug Fixes
- Rename help argument due to conflict ✔️
### Documentation
- Add README.md ✔️
- Add tested usage example ✔️
### Features
- Add ability to parse arrays ✔️
### Other (unconventional)
- Initial commit ❌
<!-- generated by git - cliff -->
< / details >
2021-07-14 21:38:53 +03:00
## Similar Projects
2021-07-18 19:00:02 +03:00
- [git-journal ](https://github.com/saschagrunert/git-journal ) - The Git Commit Message and Changelog Generation Framework
2021-07-14 21:38:53 +03:00
- [clog-cli ](https://github.com/clog-tool/clog-cli ) - Generate beautiful changelogs from your Git commit history
- [relnotes ](https://crates.io/crates/relnotes ) - A tool to automatically generate release notes for your project.
- [cocogitto ](https://github.com/oknozor/cocogitto ) - A set of CLI tools for the conventional commit
and semver specifications.
2021-06-16 22:42:54 +03:00
2021-06-13 02:14:27 +03:00
## License
GNU General Public License ([v3.0](https://www.gnu.org/licenses/gpl.txt))
## Copyright
2022-02-12 21:53:13 +03:00
Copyright © 2021-2022, [git-cliff contributors ](mailto:git-cliff@protonmail.com )