mirror of https://github.com/pypa/hatch.git
76 lines
1.6 KiB
Markdown
76 lines
1.6 KiB
Markdown
# Code version source
|
|
|
|
-----
|
|
|
|
## Updates
|
|
|
|
Setting the version is not supported.
|
|
|
|
## Configuration
|
|
|
|
The version source plugin name is `code`.
|
|
|
|
=== ":octicons-file-code-16: pyproject.toml"
|
|
|
|
```toml
|
|
[tool.hatch.version]
|
|
source = "code"
|
|
```
|
|
|
|
=== ":octicons-file-code-16: hatch.toml"
|
|
|
|
```toml
|
|
[version]
|
|
source = "code"
|
|
```
|
|
|
|
## Options
|
|
|
|
| Option | Description |
|
|
| --- | --- |
|
|
| `path` (required) | A relative path to a Python file or extension module that will be loaded |
|
|
| `expression` | A Python expression that when evaluated in the context of the loaded file returns the version. The default expression is simply `__version__`. |
|
|
| `search-paths` | A list of relative paths to directories that will be prepended to Python's search path |
|
|
|
|
## Missing imports
|
|
|
|
If the chosen path imports another module in your project, then you'll need to use absolute imports coupled with the `search-paths` option. For example, say you need to load the following file:
|
|
|
|
=== ":octicons-file-code-16: src/pkg/\_\_init\_\_.py"
|
|
|
|
```python
|
|
from ._version import get_version
|
|
|
|
__version__ = get_version()
|
|
```
|
|
|
|
You should change it to:
|
|
|
|
=== ":octicons-file-code-16: src/pkg/\_\_init\_\_.py"
|
|
|
|
```python
|
|
from pkg._version import get_version
|
|
|
|
__version__ = get_version()
|
|
```
|
|
|
|
and the configuration would become:
|
|
|
|
=== ":octicons-file-code-16: pyproject.toml"
|
|
|
|
```toml
|
|
[tool.hatch.version]
|
|
source = "code"
|
|
path = "src/pkg/__init__.py"
|
|
search-paths = ["src"]
|
|
```
|
|
|
|
=== ":octicons-file-code-16: hatch.toml"
|
|
|
|
```toml
|
|
[version]
|
|
source = "code"
|
|
path = "src/pkg/__init__.py"
|
|
search-paths = ["src"]
|
|
```
|