Skip to content

Latest commit

 

History

History
56 lines (44 loc) · 2.74 KB

VERSIONING.md

File metadata and controls

56 lines (44 loc) · 2.74 KB

Versioning scheme for StaticX

The following versioning scheme has been developed to make it easier to release new versions of StaticX, while allowing users to always have an accurate idea of the version they are running.

Versions are driven by a "base version", which is kept in staticx/version.py and is manually updated before each release. This base version follows Semantic Versioning, and is augmented with additional information, depending on the environment and they way the software has been obtained.

There are two different places the StaticX version is maintained; the goal is to ensure these are always in-sync:

  1. The staticx.version.__version__ attribute. This is what is displayed when staticx --version is run.

  2. The metadata, as seen by Pip and on PyPI.

StaticX can be acquired in various ways, each with its own impact on the versioning scheme. Consider a base version of 1.2.3:

  1. PyPI - StaticX is only deployed to the main PyPI site when a new version is tagged. Thus, the version on PyPI will always be nothing more than the base version.

  2. Test PyPI - StaticX is automatically deployed (via Travis-CI) to the PyPI Testing Site upon each push to the master branch. PyPI requires non-local PEP 440 -compliant versions. Because of this, the Travis CI build number is appended to the base version, excluding any Git information, e.g. 1.2.3.456 where 456 is the build number. This ensures that the latest build on master will always be deployed to PyPI testing as the newest version.

  3. Git clone - StaticX can be run from a local Git repository. In this case, the version presented by StaticX will come from the output of git describe, and will look like this: 1.2.3-45-gabcdef, where -45 is the number of commits since version 1.2.3, and abcdef is the hash of the current commit. The version may also include -dirty if there are any uncommitted modifications to the code.

  4. Git archive - StaticX can be run from an archive of the Git repository, either from git archive or by downloading a source tarball from GitHub. In this case, the version presented by StaticX will come from substituions made by Git during archive creation, controlled by the export-subst attribute. The version will look like this: 1.2.3-gabcdef, where abcdef is the hash of the current commit.

  5. Source distribution - StaticX can be run from a source distribution, created via python setup.py sdist. In this case, the version comes from the egg info generated by setuptools.

In any case, when StaticX is installed, the version comes from importlib.metadata.