Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Conventional commits, changelog, versioning, validation

License

NotificationsYou must be signed in to change notification settings

convco/convco

Repository files navigation

GitHub Workflow StatusCrates.io

A Conventional commit cli.

Documentation:https://convco.github.io.

convco gives tools to work withConventional 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.
  • convco completions: Generates tab completions for shells (exists only with the featurecompletions enabled).

Installation

cargo install convco

Building from source

Rust 1.60 or newer is required.

Building withcargo depends ongit2 andcmake due to linking withzlib-ng.You can optionally disable this by changing the defaults for a build:

cargo build --no-default-features

Configuration

convco uses follows theconventional-changelog-config-spec.

The configuration file is loaded in the following order

  1. Load the internal defaults
  2. Then override with values from the command line,convco -c|--config path/to/.convco
  3. 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 runconvco config.

Thehost: ...,owner: ... andrepository: ... when not supplied via custom or the.versionrc are loadedfrom thegit remote origin value.

Docker usage

# build the convco imagedocker build -t convco.# run it on any codebasedocker 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:testimage:name:convco/convco:latestscript:    -check

Tools

Changelog

A changelog can be generated using the conventional commits.It is inspired byconventional changelog and theconfiguration 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 gitcore.editor.In this caseconvco commit will not invokegit commit, butgit will invokeconvco commit

e.g.:

GIT_EDITOR='convco commit' git commit -p

When persisting the git editor also setsequence.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 ascargo-release:

cargo release$(convco version --bump)

Completions

Note

This subcommand requires the featurecompletions to be enabled.

Generates tab completion for the current shell

convco completions

If your shell cannot be detected (the$SHELL variable isn't present) you can specify the shell you want completions generated for.

convco completions bash

The tab completions will be outputed to the stdout so you may want to output them to a certain file to save them for future use. Here are some example files for given shells:

  • Bash:/usr/share/bash-completion/completions/convco
  • Zsh:/usr/share/zsh/site-functions/_convco
  • Fish:/usr/share/fish/vendor_completions.d/convco.fish
  • Elvish:/usr/share/elvish/lib/convco.elv

[8]ページ先頭

©2009-2026 Movatter.jp