Simple semver utilities for Python.
Project description
easysemver
This package provides utilities for comparing SemVer versions, with special attention on the correct treatment of prerelease parts.
Installation
easysemver
is currently installed directly from GitHub:
pip install git+https://github.com/stackhpc/easysemver
Usage
Before versions can be compared, they must be converted into Version
objects. If the version
is not valid SemVer, a TypeError
will be raised.
from easysemver import Version
# Not a valid SemVer version, so raises TypeError
version = Version("20230809-1")
# Create a SemVer version
version = Version("1.2.3")
# Prerelease and build parts are supported
version = Version("1.2.3-alpha.0+abcdefg")
# Comparing versions respects prerelease parts
# The following all resolve to True
Version("1.2.3") < Version("1.2.4")
Version("1.2.3") < Version("2.0.0")
Version("1.2.3") < Version("1.2.4-alpha.0")
Version("1.2.3-alpha.0") < Version("1.2.3")
# Prerelease parts that are all digits are compared as numbers
Version("1.2.3-alpha.0") < Version("1.2.3-alpha.100")
# Prerelease parts that are strings are compared as strings
Version("1.2.3-alpha.0") < Version("1.2.3-beta.0")
# Note that build parts don't affect comparison
Version("1.2.3") == Version("1.2.3+abcdefg")
Versions can also be compared to a SemVer range, which consists of a number of constraints
separated by commas. Similar to Version
, a TypeError
will be raised if the constraints
are not valid.
The supported constraints are SemVer versions with an operator, where the supported operators
are ==
, !=
, >=
, >
, <=
and <
.
from easysemver import Range, Version
# Resolves to True
Version("1.2.3") in Range(">=1.0.0,<2.0.0")
# Resolves to False
Version("1.2.3") in Range(">=2.0.0")
# Prerelease versions are only considered part of a range if the lower bound includes a prerelease part
# Resolves to False
Version("1.2.3-alpha.0") in Range(">=1.0.0")
# Resolves to True
Version("1.2.3-alpha.0") in Range(">=1.0.0-0")
# Specific versions can be exclulded
# Resolves to False
Version("1.2.3") in Range(">=1.0.0,<2.0.0,!=1.2.3")
# Resolves to True
Version("1.2.4") in Range(">=1.0.0,<2.0.0,!=1.2.3")
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
Hashes for easysemver-0.1.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 14d033568f93723158b88b75edd035b765bb7742575e3625e682f185951e12ea |
|
MD5 | ae3dd109fe46db47587b3b89ba61a4c5 |
|
BLAKE2b-256 | 8ad772f0dffef1d02d055e00593d0f05303fa864d6c57277cc589ef9a25f1e65 |