Skip to main content

Deterministic calendar versioning from git history

Project description

gitcalver

A Python implementation of GitCalVer, which derives calendar-based version numbers from git history.

Each commit on the default branch gets a unique, strictly increasing version of the form YYYYMMDD.N, where N is the number of commits on that UTC date.

See the GitCalVer specification for full details.

Installation

uv add gitcalver
# or
pip install gitcalver

See Requirements below.

CLI usage

gitcalver [OPTIONS] [REVISION | VERSION]

With no arguments, prints the version for HEAD:

$ gitcalver
20260411.3

Pass a revision to compute its version:

$ gitcalver HEAD~1
20260411.2

Version prefix

Use --prefix to prepend a literal string:

Use case Command Example output
Default gitcalver 20260411.3
SemVer gitcalver --prefix "0." 0.20260411.3
Go gitcalver --prefix "v0." v0.20260411.3

Dirty workspace

By default, gitcalver exits with status 2 if the workspace has uncommitted changes. Use --dirty STRING to produce a version instead; the output will include the given string and a short commit hash (e.g. --dirty "-dirty" produces 20260411.3-dirty.abc1234).

Use --no-dirty-hash with --dirty to suppress the hash suffix. Use --no-dirty to explicitly refuse dirty versions (overrides --dirty).

Dirty versions are a convenience and are not necessarily unique.

Reverse lookup

Pass a version number to get the corresponding commit hash:

$ gitcalver 20260411.3
a1b2c3d4e5f6...

$ gitcalver --short --prefix "0." 0.20260411.3
a1b2c3d

If the version was generated with --prefix, pass the same --prefix for reverse lookup. Dirty versions cannot be reversed.

Options

Option Description
--prefix PREFIX Literal string prepended to version
--dirty STRING Enable dirty versions; append STRING.HASH
--no-dirty Refuse dirty versions (overrides --dirty)
--no-dirty-hash Suppress .HASH suffix (requires --dirty)
--branch BRANCH Base branch name; overrides auto-detection. This is the branch versions are minted on, not the branch you are working on.
--short Output short commit hash (reverse lookup mode)
--help Show help

Exit codes

Code Meaning
0 Success
1 Error (not a git repo, no commits, non-monotonic dates, shallow clone)
2 Dirty workspace or off default branch (without --dirty)
3 Cannot trace to default branch

Python API

import gitcalver

# Forward: compute a version for HEAD (or a specific revision).
version = gitcalver.get_version(repo="/path/to/repo")
# e.g. "20260411.3"

version = gitcalver.get_version(
    repo="/path/to/repo",
    revision="HEAD~1",
    prefix="v0.",
    dirty="-dirty",
)

# Reverse: resolve a version back to a commit hash.
commit = gitcalver.find_commit("20260411.3", repo="/path/to/repo")

# If the version was generated with --prefix, pass the same prefix:
commit = gitcalver.find_commit(
    "v0.20260411.3", prefix="v0.", repo="/path/to/repo"
)

Errors are raised as gitcalver.ExitError, which carries a code attribute matching the CLI exit codes above.

Hatch plugin

gitcalver ships a Hatch version source plugin. To use it in pyproject.toml:

[build-system]
requires = ["hatchling", "gitcalver"]
build-backend = "hatchling.build"

[tool.hatch.version]
source = "gitcalver"
# Optional:
# prefix = "0."
# dirty = "-dirty"
# no-dirty-hash = true
# branch = "main"

Requirements

  • Python 3.10+
  • git on $PATH
  • Full commit history (shallow clones made with --depth are rejected; partial clones made with --filter=blob:none are fine)

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

gitcalver-20260517.1.tar.gz (38.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

gitcalver-20260517.1-py3-none-any.whl (13.1 kB view details)

Uploaded Python 3

File details

Details for the file gitcalver-20260517.1.tar.gz.

File metadata

  • Download URL: gitcalver-20260517.1.tar.gz
  • Upload date:
  • Size: 38.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for gitcalver-20260517.1.tar.gz
Algorithm Hash digest
SHA256 659014dfccd6e56e97292ac5c348bce07f6ad25363fc21f19ddbc9ab134681cc
MD5 150c7a32a0eb259de2bee365c8a0a787
BLAKE2b-256 284d0f2d3ac87813080e1b043baff308331f3579d11690844d5ae5add67cfc95

See more details on using hashes here.

Provenance

The following attestation bundles were made for gitcalver-20260517.1.tar.gz:

Publisher: ci.yml on gitcalver/python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file gitcalver-20260517.1-py3-none-any.whl.

File metadata

  • Download URL: gitcalver-20260517.1-py3-none-any.whl
  • Upload date:
  • Size: 13.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.13

File hashes

Hashes for gitcalver-20260517.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1f170702c21686da9b2bb303aeae415286647f872b4d8ac2cdff8caa5c5ae452
MD5 6d579f797c407b52f39c94dd1d5b40d0
BLAKE2b-256 da19b755a968f07fc63fb78c7b3ea2cad5fb564878ebb9e7aed8acbdedec9b71

See more details on using hashes here.

Provenance

The following attestation bundles were made for gitcalver-20260517.1-py3-none-any.whl:

Publisher: ci.yml on gitcalver/python

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page