Easy git branch friendly changelogs
Project description
Easy Changelog
Allow to create and merge part log files to avoid git conflits or problems with a global changelog file.
This is a command line (ezchlog) tool.
It is available, at your convenance, as a python or rust binary.
You can include it in your CI: see this project as example.
Installation
Python version
Install this repository from Pypi:
pip install ezchlog
Or any other means (pipx, uvx or a package manager).
Python 3.10+ required.
Rust version
Download a pre-compiled version from releases.
Don’t forget to download the checksum file and check for corruption.
You should rename the binary to ezchlog and place it on your PATH.
You can also compile the ezchlog rust binary from source (you should have rustc and cargo available):
make release
After installation
Then you’ll have a command to handle your logs:
ezchlog --help
Add a changelog
$ ezchlog add "New url for example API"
Changed new_url_for_example_api
$ ezchlog add -p "Fix example API" Fixed 142
_CHANGELOGS/Fixed/142-fix_example_api.md
The file is automatically added to git index unless --no-git is used.
Create a git branch
If you use git, you can automatically create a git branch along the part log file.
For that use the -b or --branch parameter for the add commmand.
[master] $ ezchlog add -b "Fix example API" Fixed 142
Fixed 142-fix_example_api
[142_fix_example_api] $
You can configure the branch name using the branch_format, branch_separator and branch_lowercase_for config parameters.
List changelogs
$ ezchlog list
Fixed 142-fix_example_api
Changed new_url_for_example_api
$ ezchlog list -p
_CHANGELOGS/Fixed/142-fix_example_api.md
_CHANGELOGS/Changed/new_url_for_example_api.md
Commit with git
If you use git, you can automatically create a git commit with its message using part log files.
By default it will use the only part log file in the git index as base for the git commit summary message.
If you have multiple files in the index, specify which one is the main one, i.e. which one will be use as the summary message.
All part log files in the index will be used in the full git message.
$ ezchlog commit
[master (root-commit) c0cc282] 142: Fix example API
2 files changed, 3 insertions(+)
create mode 100644 _CHANGELOGS/Fixed/142-fix_example_api.md
create mode 100644 example/api_doc.md
The summary message format is {Ref}: {Title} if there is a reference, or simply {Title}.
Titleis the part log first line, without the reference and without any markdown list prefix.Refis what is between brackets on the part log first line, withRefadded upfront if the reference start with a sharp#(because it’s a comment for git)
Merge changelogs
$ ezchlog merge 1.2.3
$ cat CHANGELOG.md
# Changelog
All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.1.0/)
and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).
## 1.2.3
### 🔧 Fixed
- Fix example API (142)
### 📝 Changed
- New url for example API
Files are automatically updated in the git index unless --no-git is used.
You can also add more configuration:
$ ezchlog merge \
--with-date \
--link=https://gitlab.com/snake_coders/ezchlog/-/compare/v1.0.2...v1.1.0 \
--subtitle "[](https://gitlab.com/snake_coders/ezchlog/-/commits/master)" \
1.1.0
$ cat CHANGELOG.md
# Changelog
All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.1.0/)
and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).
## [1.1.0] – 2025-11-07
[1.1.0]: https://gitlab.com/snake_coders/ezchlog/-/compare/v1.0.2...v1.1.0
[](https://gitlab.com/snake_coders/ezchlog/-/commits/master)
### 🔧 Fixed
- Fix example API (142)
### 📝 Changed
- New url for example API
Configuration
The following configuration parameters could be specified as environment variables or in a .ezchlog.toml file (or pyproject.toml file for the python version).
EZCHLOG_EDITORdefault toEDITORorvimEZCHLOG_LOG_DIRdefault to_CHANGELOGSEZCHLOG_LOG_FILEdefault toCHANGELOG.mdEZCHLOG_CATEGORY_LISTdefault toBreaking:💣,Security:🛡️,Fixed:🔧,Changed:📝,Added:➕,Removed:➖,Deprecated:⚠️. Usename:iconto specify an icon for the category. You can also use it with plainnamewithout any icon.EZCHLOG_CATEGORY_DEFAULTdefault toChangedEZCHLOG_DEFAULT_CHANGELOGdefault to
# Changelog
All notable changes to this project will be documented in this file.
The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.1.0/)
and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).
EZCHLOG_WITH_DATEdefault toFalseEZCHLOG_NO_GITdefault toFalseEZCHLOG_BRANCH_FORMATdefault to%{ref}%{sep}%{name}, allowed variables:ref,cat,name,sepEZCHLOG_BRANCH_SEPARATORdefault to_EZCHLOG_BRANCH_LOWERCASE_FORdefault tocat,name, allowed variables:ref,cat,name
For .ezchlog.toml or pyproject.toml config key, use the environment variable name in lowercase without the EZCHLOG prefix, for instance log_dir or category_list keys.
For pyproject.toml, the config resides in the tool.ezchlog table.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ezchlog-1.4.0.tar.gz.
File metadata
- Download URL: ezchlog-1.4.0.tar.gz
- Upload date:
- Size: 15.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Alpine Linux","version":"3.23.2","id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2f0157825c015667c178c3210f35dafa884adaa86a708a75a187593835e0e45f
|
|
| MD5 |
5f710fd03578be911c79bfe2b63db12f
|
|
| BLAKE2b-256 |
0843d75a7dfa0ee4ff55eeeb4fd6cee71aca904bf3a4baad4914337d50766163
|
File details
Details for the file ezchlog-1.4.0-py3-none-any.whl.
File metadata
- Download URL: ezchlog-1.4.0-py3-none-any.whl
- Upload date:
- Size: 13.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Alpine Linux","version":"3.23.2","id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
62d45320e5ba5878e8f2afd5aebac9733e3874e5a14a97b7e8e519a2f8d09426
|
|
| MD5 |
5da5f92b2dd7ec8956f4b0d7148d174c
|
|
| BLAKE2b-256 |
9bf07022bdce4fc41b8be5f98acaeb3ea824c3429db2587f2c0072d1336f76f7
|