Version scheme plugins¶
Built-in¶
Standard¶
See the documentation for versioning.
Configuration¶
The version scheme plugin name is standard
.
[tool.hatch.version]
scheme = "standard"
[version]
scheme = "standard"
VersionSchemeInterface
¶
Example usage:
from hatchling.version.scheme.plugin.interface import VersionSchemeInterface
class SpecialVersionScheme(VersionSchemeInterface):
PLUGIN_NAME = 'special'
...
from hatchling.plugin import hookimpl
from .plugin import SpecialVersionScheme
@hookimpl
def hatch_register_version_scheme():
return SpecialVersionScheme
Source code in hatchling/version/scheme/plugin/interface.py
class VersionSchemeInterface(object): # no cov
"""
Example usage:
=== ":octicons-file-code-16: plugin.py"
```python
from hatchling.version.scheme.plugin.interface import VersionSchemeInterface
class SpecialVersionScheme(VersionSchemeInterface):
PLUGIN_NAME = 'special'
...
```
=== ":octicons-file-code-16: hooks.py"
```python
from hatchling.plugin import hookimpl
from .plugin import SpecialVersionScheme
@hookimpl
def hatch_register_version_scheme():
return SpecialVersionScheme
```
"""
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
def update(self, desired_version, original_version, version_data):
"""
:material-align-horizontal-left: **REQUIRED** :material-align-horizontal-right:
This should return a normalized form of the desired version and verify that it
is higher than the original version.
"""
raise NotImplementedError
PLUGIN_NAME
¶
The name used for selection.
config
property
readonly
¶
[tool.hatch.version]
[version]
root
property
readonly
¶
The root of the project tree as a string.
update(self, desired_version, original_version, version_data)
¶
REQUIRED
This should return a normalized form of the desired version and verify that it is higher than the original version.
Source code in hatchling/version/scheme/plugin/interface.py
def update(self, desired_version, original_version, version_data):
"""
:material-align-horizontal-left: **REQUIRED** :material-align-horizontal-right:
This should return a normalized form of the desired version and verify that it
is higher than the original version.
"""
raise NotImplementedError
Last update: April 28, 2022