Skip to main content

A dynamic version source plugin for uv workspaces.

Project description

uv-workspace-dynamic-versioning

PyPI version CI Status Coverage SLSA Level 3 License

A powerful Hatch plugin for dynamic versioning and dependency injection in uv workspaces.


📖 Context & Origin

This project was created to address a specific limitation in the existing uv-dynamic-versioning plugin when used within complex monorepos and uv workspaces.

As discussed in ninoseki/uv-dynamic-versioning#81, the standard implementation often calculates version distance and commit hashes based on the entire repository history. In a workspace with multiple packages, this leads to:

  1. False Positives: Packages bumping versions when unrelated code in the workspace changes.
  2. Inaccurate Metadata: Commit hashes reflecting global repo state rather than the state of the specific package.

uv-workspace-dynamic-versioning introduces Directory-Specific Patching. It re-calculates the Git distance and commit hash by filtering the history to the specific package subdirectory, ensuring that versions only reflect changes relevant to that package.


🚀 Key Features

  • VCS-Powered Versioning: Automatically derive versions from Git, Mercurial, and more via Dunamai.
  • Workspace Aware: Accurate distance and commit hash calculation restricted to the project subdirectory.
  • Dynamic Dependencies: Inject versions into dependencies using Jinja2 templates (e.g., pkg == {{ version.base }}).
  • Secure by Design: Sandboxed Jinja2 environment and Path Traversal protection.
  • Highly Configurable: Custom formats, bumping logic, and fallback versions.

🛠 Quick Start

1. Installation

Add the plugin to your build-system.requires in pyproject.toml:

[build-system]
requires = ["hatchling", "uv-workspace-dynamic-versioning"]
build-backend = "hatchling.build"

2. Basic Configuration

Enable the version source and mark the version as dynamic:

[project]
name = "my-awesome-package"
dynamic = ["version"]

[tool.hatch.version]
source = "uv-workspace-dynamic-versioning"

📚 Documentation

For full guides and API reference, visit our Documentation Site.


⚖️ License

Distributed under the terms of the MIT license.

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

uv_workspace_dynamic_versioning-0.1.5.tar.gz (108.7 kB view details)

Uploaded Source

Built Distribution

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

File details

Details for the file uv_workspace_dynamic_versioning-0.1.5.tar.gz.

File metadata

File hashes

Hashes for uv_workspace_dynamic_versioning-0.1.5.tar.gz
Algorithm Hash digest
SHA256 fd263f17c2488393e9f51840cdddd7f66aa1592eea3cdaf235327a88f768a185
MD5 454c14d490160213e140c91cf43423c2
BLAKE2b-256 717739e847f98ef13a499a0c3fd5f68cf0ad79dc772548b927eadb4ec3727dbb

See more details on using hashes here.

Provenance

The following attestation bundles were made for uv_workspace_dynamic_versioning-0.1.5.tar.gz:

Publisher: ci.yml on indiVar0508/uv-workspace-dynamic-versioning

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

File details

Details for the file uv_workspace_dynamic_versioning-0.1.5-py3-none-any.whl.

File metadata

File hashes

Hashes for uv_workspace_dynamic_versioning-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 b2c37691b6ac1b81f69d2bf2598346a3429afecb56761b5dbd5e6f9d0bc62d98
MD5 a064983a493063bda1bba392ff9cb649
BLAKE2b-256 a6ec5f9f19595a474ce534f5850bb3df16e8aac4d0fc2416a663d398c2662d1b

See more details on using hashes here.

Provenance

The following attestation bundles were made for uv_workspace_dynamic_versioning-0.1.5-py3-none-any.whl:

Publisher: ci.yml on indiVar0508/uv-workspace-dynamic-versioning

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