Bump Version
This tool helps to increment the version number of a project.
You can download the tool here: download.schukai.com/tools/version/.
echo "1.0.0" | version patch
# 1.0.1
echo "1.0.0" | version minor
# 1.1.0
echo "1.0.0" | version major
# 2.0.0
You can also replace directly in files.
YAML
my:
version: 1.0.0
version patch --path my.yaml --selector my.version
JSON
{
"my": {
"version": "1.0.0"
}
}
version patch --path my.json --selector my.version
Git
Or set git tags directly
version patch --git
Build
With the command build the current build date can be output.
version build
Auto
The 'auto' feature allows the tool to automatically determine the next version based on the project's git commit history since the last tag.
It uses semantic commit messages to determine the type of version bump. If a commit message starts with "feat:", it will trigger a minor version bump. If a commit message starts with "fix:" or if it includes "BREAKING CHANGE", it will trigger a patch or a major version bump respectively.
Here is how you can use the 'auto' feature:
version auto
This command implies the '--git' flag, which means that the tool will tag the git repository with the new version. The tag name will be the new version number.
It is important to note that this feature requires that your commit messages follow the Conventional Commits message format.
The exit-code-if-no-bump
flag can be used to make the command exit with a non-zero exit.
This is useful for CI/CD pipelines.
version auto --exit-code-if-no-bump
In this case, the command will exit with the exit code 1 if no version bump is required.
Predict
The predict
command allows you to predict the next version based on the
project's git commit history since the last tag. Other than the auto
command,
this command does not write the result to a file or tag the git repository.
version predict
Makefile
build:
version patch --path $(PROJECT_ROOT)version.json --selector "version"
$(eval VERSION := $(shell cat version.json | jq -r .version))
$(eval BUILD := $(shell version date))
echo "Compiling for every OS and Platform $(VERSION) $(BUILD)"