Adds a command to dynamically get the version from the VCS of choice
Project description
Get version from version control instead of hardcoding it into setup.py
⚠ DEPRECATION NOTICE ⚠
This package is no longer maintained. It will not evolve along with the Python packaging ecosystem. Specifically, as of November 2021, it will not work with static metadata defined in setup.cfg as opposed to metadata defined in setup.py.
There is a good alternative: use setuptools-scm instead. This is easy to set up in a setup.cfg, see the PyPA Packaging Python projects tutorial.
introduction
Instead of hardcoding the version in setup.py like this:
setup(
name='some-dist-name',
version='1.0',
...)
This package allows specifying a VCS command like this:
setup(
name='some-dist-name',
version_command='git describe',
...)
…Which will then update the version into some-dist-name.egg-info/version.txt, so that the version can also be found if setup.py is being run from an sdist or something.
When it can find the version from either some-dist-name.egg-info/version.txt or the output of the version_command, it will update the version key that is normally used for the version, such as what’s used in the sdist filename and so on.
setup keyword
Instead of specifying the version keyword argument, specify the version_command keyword argument. It can either be a str or a tuple. If it’s a str, it’s interpreted as just the command to execute, for example git describe. If it’s a tuple, it must have two or three elements, and have the form (command, pep440_mode[, post_mode]). pep440_mode can only be specified in the tuple of version_argument, not as separate argument of setup.
A list of possible values for tuples passed to the version_command keyword argument:
- command:
Must be "git describe", but could also support other VCS in the future.
- pep440_mode = None:
Takes output of command as is, so ignores PEP440. pip and setuptools will throw warnings.
- pep440_mode = "pep440-git-local":
Moves number of commits and hash as local identifier:
Change 1.2.3 to 1.2.3
Change 1.2.3-10-abc1234 to 1.2.3+git-10-abc1234
- pep440_mode = "pep440-git-dev":
(Deprecated) Adds rhe number of commits since a git tag as a .dev tag:
Change 1.2.3-N-abc1234 to 1.2.3.devN
This is against PEP440-specification and supported only for backwards compatibility. It may be removed in time.
- pep440_mode = "pep440-git":
Works with pre-release versions (alpha, beta, rc etc), post-release versions (post, rev, etc) and dev versions.
Leave 1.2.3.dev and 1.2.3.dev0 as they are
Change 1.2.3.dev-N-abc1234 to 1.2.3.devN
Change 1.2.3a-N-ab1234 to 1.2.3aN
Change 1.2.3 to 1.2.3
Change 1.2.3-10-abcd123 to 1.2.3.post10, or 1.2.3-rev10, as you prefer
In other words, a tag can be absent, open (implicitly or explicitly 0), or closed (have a number greater than zero). If the last Git tag is an open dev tag, that’s the one that will be used for the revision number. If the last Git tag is an open post-release tag, then that will be used. If the last Git tag is an open pre-release tag, that will be used. In other cases, a post-release tag will be added.
- pep440_mode = "pep440-git-full:
Similar to "pep440-git" but includes the commit hash and dirty marker (if present) in the local version portion.
Change 1.2.3.dev-N-abc1234 to 1.2.3.devN+gabc1234
Change 1.2.3-dirty to 1.2.3+dirty
Change 1.2.3-10-abcd123-dirty to 1.2.3.post10+gabcd123.dirty
The inclusion of the hash in the local identifier helps avoid ambiguity between two versions that are the same number of commits from the latest tag.
The inclusion of the dirty flag (which requires command value to include the --dirty option) ensures that local uncommitted changes are considered newer than the last set of committed changes.
- post_mode:
Template for adding post-release tags. Optional separator (dot, dash or underscore), followed by "post", "rev" or "r", followed by another optional separator. Can also be a single dash. Default is ".post".
Given a git describe output of 1.2a3-4-abcd123:
".post" gives 1.2a3.post4
".rev_" gives 1.2a3.rev_4
"-" gives 1.2a3-4
installation
To use it, just do this:
pip install setuptools-version-command
With the pip of the global python. (Or use --user.)
testing
To test it, run ./setup.py --version.
developing
Within a checkout of this repo:
virtualenv env
env/bin/pip install --editable .
env/bin/python setup.py --version
Make sure that you change the setup.py so that it actually makes use of setuptools-version-command.
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
File details
Details for the file setuptools-version-command-99.9.tar.gz
.
File metadata
- Download URL: setuptools-version-command-99.9.tar.gz
- Upload date:
- Size: 7.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.6.0 importlib_metadata/4.8.2 pkginfo/1.8.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4a0f42f3a686fc7a9b936a6122ba03d9d437754aa25c284c37322d21e5488935 |
|
MD5 | fb1f4e111d418940a3ff64bdbb0246ff |
|
BLAKE2b-256 | 16d3efc77f6d8359494a05d035b10420db0927ed97bfbb411c7e68e91edf9f41 |
File details
Details for the file setuptools_version_command-99.9-py2.py3-none-any.whl
.
File metadata
- Download URL: setuptools_version_command-99.9-py2.py3-none-any.whl
- Upload date:
- Size: 7.6 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.6.0 importlib_metadata/4.8.2 pkginfo/1.8.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c183536ec74df2d29964e757e0f00a109d734de919d82a84f8bc4b8ab2af9909 |
|
MD5 | 40058032e46674a4025e477cfa352eb8 |
|
BLAKE2b-256 | 3b08fc5c68dd97eaf8e8807d045712a71af475d6a79eef7f7028b53568faae37 |