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-20260418.6.tar.gz (38.3 kB view details)

Uploaded Source

Built Distribution

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

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

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for gitcalver-20260418.6.tar.gz
Algorithm Hash digest
SHA256 29015127ad0c4cbe069818b8c9918309022d478229a989307d0c209c3643e61a
MD5 c8c91084adc32a3bfea84550865593be
BLAKE2b-256 63bfb05edcd71099a49754c341849bc02a2538c94c94afd65e6ac3f48dbe1365

See more details on using hashes here.

Provenance

The following attestation bundles were made for gitcalver-20260418.6.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-20260418.6-py3-none-any.whl.

File metadata

  • Download URL: gitcalver-20260418.6-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-20260418.6-py3-none-any.whl
Algorithm Hash digest
SHA256 081ff7c29f7e7fc4927cc635b21e262ff97899fd2d19dcad230e0e88e7926e70
MD5 bacd3ac60b857fe3f9697468c9705b88
BLAKE2b-256 7a29532b82656252a31954e63b2a6db78ed935f5b8b3f375cd6326f1f1a13b62

See more details on using hashes here.

Provenance

The following attestation bundles were made for gitcalver-20260418.6-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