Generate and process semantic version numbers
Project description
VerNum
Configurable GitLab CI/CD-powered version numbering for project releases
(Similar to GitVersion)
Python module/CLI installation
The VerNum Python module is distributed as a PyPI module and can be installed like any other.
Install with system-level Python
pip3 install vernum
Install with pipx to avoid dependency collisions
pipx install vernum
Install with a venv (depends on venv location)
.venv/bin/pip install vernum
... or install as a Poetry dev dependency
Commands
The vernum max command
Takes a list of version numbers and based on the configued numbering scheme, returns the highest value in the list.
echo "1.4.0\n1.4.1\n1.5.0" | vernum max
The vernum next command
Takes a single version number and, based on the configured numbering scheme and the selected increment, outputs the next version number.
echo "3.4.5" | vernum next patch
The vernum limit command
Takes a single version number and, based on the onfigured numbering scheme and provided limits, triggers an error if the version number falls outside the limit. Only a minimum limit is currently supported (see configuration below).
Schemes
VerNum supports multiple "schemes" for version numbering.
| Scheme | Description | Increments | Example |
|---|---|---|---|
major |
Just a single version number | major |
4 |
minor |
Major, dot, minor | major minor |
4.2 |
patch |
Major, dot, minor, dot patch | major minor patch |
4.2.1 |
minor-alpha-beta |
Major, dot, minor, dot, and either a patch, alpha, or beta | major, minor, patch, alpha, beta |
4.3.alpha2 |
Schemes support an optional "v" before the version number for inputs, including from Git, but output the result without a "v".
The default scheme is patch.
Schemes with prerelease versions
Some schemes have prerelease versions (alpha, beta) with varying syntax. The basic approach to incrementing is to assume a preference for starting with alpha, then going to beta. So, for example, if the current version is at 1.2.3 and the operator requests a patch update, the version becomes, for example, 1.2.4-alpha (depending on the scheme itself).
Increments only go forward, so avoid attempting to move from beta to alpha.
FOr the minor-alpha-beta scheme:
majorchanges e.g. 5.6.2 to 6.0.alpha1major-zerochanges e.g. 5.6.2 to 6.0.0minorchanges e.g. 5.6.2 to 5.7.alpha1minor-zerochanges e.g. 5.6.2 to 5.7.0betachanges e.g. 5.7.beta3 to 5.7.beta4alphachanges e.g. 5.7.alpha8 to 5.7.alpha9patchchanges e.g. 5.6.beta6 to 5.6.0patchchanges e.g. 5.6.2 to 5.6.3
For the patch-hyphen-al-be scheme:
majorchanges e.g. 5.6.2 to 6.0.0-alphamajor-zerochanges e.g. 5.6.2 to 6.0.0minorchanges e.g. 5.6.2 to 5.7.0-alphaminor-zerochanges e.g. 5.6.2 to 5.7.0patchchanges e.g. 5.6.2 to 5.6.3-alphapatch-zerochanges e.g. 5.6.2 to 5.6.3betachanges e.g. 5.7.3-alpha to 5.7.3-betapatchchanges e.g. 5.7.3-alpha to 5.7.3patch-zerochanges e.g. 5.7.3-beta to 5.7.3- The
major,major-zero,minor, andminor-zeroincrements work as expected
Use with Git tags
We designed VerNum to use with Git tags, and recommend using the history of tags in the default branch as the source of truth for version numbers.
The example below demonstrates one way to use VerNum with Git tags.
git tag --list --merged HEAD | vernum max | vernum next patch > .version
git tag -a "$(cat .version)" -m "$(cat .version)"
Keep the following pointers in mind when using VerNum with Git.
- CD to the root of the project before running it
- Be on the branch that you use for releases (i.e.
master) - Be fully up-to-date in git (i.e. merged, committed, and pushed)
Configuration and input
VerNum uses the WizLib framework for configuration and input control.
- Input to commands can come through stdin
- Alternatively, use the
vernum --input <filename>to pull input from a file - The scheme can be selected with an environment variable
$VERNUM_SCHEME - Alternatively, the scheme can be set in a YAML configuration file; the application will try, in order:
- A config file location designated with
vernum --config <filename> - A config file location designated with a
$VERNUM_CONFIGenvironment variable .vernum.ymlin the local directory.vernum.ymlin the user's home directory
- A config file location designated with
We recommend placing a .vernum.yml file in the project directory and committing it to the project's Git repository, so different environments use the same scheme.
The format for the YAML file is simple (allowing for other forms of configuration in the future):
vernum:
scheme: minor
limit:
min: '4.2'
Usage (GitLab CICD)
See the ProCICD documentation for usage within GitLab CICD.
Project details
Release history Release notifications | RSS feed
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 vernum-7.4.0.tar.gz.
File metadata
- Download URL: vernum-7.4.0.tar.gz
- Upload date:
- Size: 6.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.2.0 CPython/3.13.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
24456de1e246be70f0a085cbfbea4f8f0251891ab8ac61132b37fa213875fa63
|
|
| MD5 |
26ebc4b651862765ae2aca730e9f44a5
|
|
| BLAKE2b-256 |
e811b858d99b5732f83f7ea153f656c11203df703c69378ca86117375dc35ecf
|
File details
Details for the file vernum-7.4.0-py3-none-any.whl.
File metadata
- Download URL: vernum-7.4.0-py3-none-any.whl
- Upload date:
- Size: 11.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.2.0 CPython/3.13.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3b9e5ed51c2ff84bd08ce0e20d4cfec1b4a71e5649f57bd24e41fc97359a65a7
|
|
| MD5 |
ff661ca08def417ab744fd60cee96b70
|
|
| BLAKE2b-256 |
e9a6d19f32fbdab437052ff2e35e89a0f60d80fa1ab11db18973d057c33fc5ac
|