30 releases
0.6.1 | Oct 8, 2024 |
---|---|
0.5.2 | Jul 23, 2024 |
0.5.1 | Mar 8, 2024 |
0.5.0 | Dec 8, 2023 |
0.1.1 | Dec 29, 2019 |
#37 in Build Utils
161 downloads per month
130KB
3K
SLoC
Convco
A Conventional commit cli.
Documentation: https://convco.github.io.
convco
gives tools to work with Conventional Commits.
It provides the following commands:
convco changelog
: Create a changelog file.convco check
: Checks if a range of commits is following the convention.convco commit
: Helps to make conventional commits.convco version
: Finds out the current or next version.
Installation
cargo install convco
Building from source
Rust 1.60 or newer is required.
Building with cargo
depends on git2
and cmake
due to linking with zlib-ng
.
You can optionally disable this by changing the defaults for a build:
cargo build --no-default-features
Configuration
convco
uses follows the conventional-changelog-config-spec.
The configuration file is loaded in the following order
- Load the internal defaults
- specified in src/conventional/config.rs,
- see these defaults at
convco config --default
.
- Then override with values from the command line,
convco -c|--config path/to/.convco
- Or, if not specified via
-c|--config
, load${PWD}/.convco
if it exists (or${PWD}/.versionrc
for compatibility with conventional-changelog).
To get the final derived configuration run convco config
.
The host: ...
, owner: ...
and repository: ...
when not supplied via custom or the .versionrc
are loaded
from the git remote origin
value.
Docker usage
# build the convco image
docker build -t convco .
# run it on any codebase
docker run -v "$PWD:/tmp" --workdir /tmp --rm convco
or use it from the Docker Hub:
docker run -v "$PWD:/tmp" --workdir /tmp --rm convco/convco
Use it in .gitlab-ci.yml
If you've created an image and pushed it into your private registry
convco:check:
stage: test
image:
name: convco/convco:latest
script:
- check
Tools
Changelog
A changelog can be generated using the conventional commits. It is inspired by conventional changelog and the configuration file allows changes to the generated the output.
convco changelog > CHANGELOG.md
Check
Check a range of revisions for compliance.
It returns a non zero exit code if some commits are not conventional. This is useful in a pre-push hook.
convco check $remote_sha..$local_sha
Commit
Helps to make conventional commits. A scope, description, body, breaking change and issues will be prompted. Convco will recover the previous message in case git failed to create the commit.
convco commit --feat
convco commit
can also be used as git core.editor.
In this case convco commit
will not invoke git commit
, but git
will invoke convco commit
e.g.:
GIT_EDITOR='convco commit' git commit -p
When persisting the git editor also set sequence.editor
when editing the todo list of an interactive rebase.
Or configure a git alias:
git config --global alias.convco '!GIT_EDITOR="convco commit" git commit'
Version
When no options are given it will return the current version.
When --bump
is provided, the next version will be printed out.
Conventional commits are used to calculate the next major, minor or patch.
If needed one can provide --major
, --minor
or --patch
to overrule the convention.
convco version --bump
It is useful to use it with release tools, such as cargo-release
:
cargo release $(convco version --bump)
Dependencies
~23–35MB
~611K SLoC