RETIRED, further work has moved to Debian project infrastructure
Go to file
2017-02-28 18:03:10 +02:00
.gitignore Ensure Python 3.2 support with tox 2016-05-15 18:33:49 +02:00
.travis.yml Remove python 3.2 support 2016-08-25 12:30:37 +03:00
CHANGELOG Update changelog and contributors list 2016-11-09 00:45:04 +02:00
CONTRIBUTORS Update changelog and contributors list 2016-11-09 00:45:04 +02:00
LICENSE.txt Add LICENSE file via addalicense.com 2013-07-16 04:49:45 -07:00
MANIFEST.in Include README.rst (instead of README.md) for PyPI 2016-05-15 19:04:27 +02:00
README.rst Add a function to parse a version string to a version info tuple. 2016-10-19 00:03:01 +11:00
semver.py Write docstring on 3.5+ 2017-02-28 18:03:10 +02:00
setup.py Fix flake8 errors 2016-12-19 20:58:28 +01:00
tests.py fix version comparisons 2017-01-16 08:55:02 -07:00
tox.ini Ensure Python 3.2 support with tox 2016-05-15 18:33:49 +02:00

Semver Latest version on PyPI

Build status Python versions Monthly downloads from PyPI Software license

A Python module for semantic versioning. Simplifies comparing versions.

Usage

This module provides just couple of functions, main of which are:

>>> import semver
>>> semver.compare("1.0.0", "2.0.0")
-1
>>> semver.compare("2.0.0", "1.0.0")
1
>>> semver.compare("2.0.0", "2.0.0")
0
>>> semver.match("2.0.0", ">=1.0.0")
True
>>> semver.match("1.0.0", ">1.0.0")
False
>>> semver.format_version(3, 4, 5, 'pre.2', 'build.4')
'3.4.5-pre.2+build.4'
>>> version_parts = semver.parse("3.4.5-pre.2+build.4")
>>> version_parts == {
...     'major': 3, 'minor': 4, 'patch': 5,
...     'prerelease': 'pre.2', 'build': 'build.4'}
True
>>> version_info = semver.parse_version_info("3.4.5-pre.2+build.4")
>>> version_info
VersionInfo(major=3, minor=4, patch=5, prerelease='pre.2', build='build.4')
>>> version_info.major
3
>>> version_info > (1, 0)
True
>>> version_info < (3, 5)
True
>>> semver.bump_major("3.4.5")
'4.0.0'
>>> semver.bump_minor("3.4.5")
'3.5.0'
>>> semver.bump_patch("3.4.5")
'3.4.6'
>>> semver.max_ver("1.0.0", "2.0.0")
'2.0.0'
>>> semver.min_ver("1.0.0", "2.0.0")
'1.0.0'

Installation

For Python 2:

pip install semver

For Python 3:

pip3 install semver

How to Contribute

When you make changes to the code please run the tests before pushing your code to your fork and opening a pull request:

python setup.py test

We use py.test and tox to run tests against all supported Python versions. All test dependencies are resolved automatically, apart from virtualenv, which for the moment you still may have to install manually:

pip install "virtualenv<14.0.0"  # <14.0.0 needed for Python 3.2 only

You can use the clean command to remove build and test files and folders:

python setup.py clean