Version source plugins¶
Known third-party¶
- hatch-vcs - uses your preferred version control system (like Git)
- hatch-nodejs-version - uses the
version
field of NodeJSpackage.json
files
VersionSourceInterface
¶
Example usage:
from hatchling.version.source.plugin.interface import VersionSourceInterface
class SpecialVersionSource(VersionSourceInterface):
PLUGIN_NAME = 'special'
...
from hatchling.plugin import hookimpl
from .plugin import SpecialVersionSource
@hookimpl
def hatch_register_version_source():
return SpecialVersionSource
Source code in hatchling/version/source/plugin/interface.py
class VersionSourceInterface(ABC): # no cov
"""
Example usage:
=== ":octicons-file-code-16: plugin.py"
```python
from hatchling.version.source.plugin.interface import VersionSourceInterface
class SpecialVersionSource(VersionSourceInterface):
PLUGIN_NAME = 'special'
...
```
=== ":octicons-file-code-16: hooks.py"
```python
from hatchling.plugin import hookimpl
from .plugin import SpecialVersionSource
@hookimpl
def hatch_register_version_source():
return SpecialVersionSource
```
"""
PLUGIN_NAME = ''
"""The name used for selection."""
def __init__(self, root, config):
self.__root = root
self.__config = config
@property
def root(self):
"""
The root of the project tree as a string.
"""
return self.__root
@property
def config(self):
"""
=== ":octicons-file-code-16: pyproject.toml"
```toml
[tool.hatch.version]
```
=== ":octicons-file-code-16: hatch.toml"
```toml
[version]
```
"""
return self.__config
@abstractmethod
def get_version_data(self) -> dict:
"""
This should return a mapping with a `version` key representing the current version of the project and will be
displayed when invoking the [`version`](../../cli/reference.md#hatch-version) command without any arguments.
The mapping can contain anything else and will be passed to
[set_version](reference.md#hatchling.version.source.plugin.interface.VersionSourceInterface.set_version)
when updating the version.
"""
def set_version(self, version: str, version_data: dict):
"""
This should update the version to the first argument with the data provided during retrieval.
"""
raise NotImplementedError
PLUGIN_NAME = ''
class-attribute
¶
The name used for selection.
root()
property
¶
The root of the project tree as a string.
Source code in hatchling/version/source/plugin/interface.py
@property
def root(self):
"""
The root of the project tree as a string.
"""
return self.__root
config()
property
¶
[tool.hatch.version]
[version]
Source code in hatchling/version/source/plugin/interface.py
@property
def config(self):
"""
=== ":octicons-file-code-16: pyproject.toml"
```toml
[tool.hatch.version]
```
=== ":octicons-file-code-16: hatch.toml"
```toml
[version]
```
"""
return self.__config
get_version_data() -> dict
abstractmethod
¶
This should return a mapping with a version
key representing the current version of the project and will be displayed when invoking the version
command without any arguments.
The mapping can contain anything else and will be passed to set_version when updating the version.
Source code in hatchling/version/source/plugin/interface.py
@abstractmethod
def get_version_data(self) -> dict:
"""
This should return a mapping with a `version` key representing the current version of the project and will be
displayed when invoking the [`version`](../../cli/reference.md#hatch-version) command without any arguments.
The mapping can contain anything else and will be passed to
[set_version](reference.md#hatchling.version.source.plugin.interface.VersionSourceInterface.set_version)
when updating the version.
"""
set_version(version: str, version_data: dict)
¶
This should update the version to the first argument with the data provided during retrieval.
Source code in hatchling/version/source/plugin/interface.py
def set_version(self, version: str, version_data: dict):
"""
This should update the version to the first argument with the data provided during retrieval.
"""
raise NotImplementedError
Last update: July 2, 2022