元数据钩子插件(Metadata hook plugins)¶
元数据钩子允许在加载项目元数据后进行修改。
知名第三方插件(Known third-party)¶
- hatch-docstring-description - 使用 docstring 设置项目描述
- hatch-fancy-pypi-readme - 动态构建 README
- hatch-nodejs-version - 使用 NodeJS package.json文件中的字段
- hatch-odoo - 基于 Odoo 插件的清单来确定依赖项
- hatch-requirements-txt - 从 requirements.txt文件读取项目依赖
- UniDep - 使用单个 requirements.yaml文件实现统一的pip和conda依赖管理
 MetadataHookInterface ¶
 Example usage:
from hatchling.metadata.plugin.interface import MetadataHookInterface
class SpecialMetadataHook(MetadataHookInterface):
    PLUGIN_NAME = 'special'
    ...
from hatchling.plugin import hookimpl
from .plugin import SpecialMetadataHook
@hookimpl
def hatch_register_metadata_hook():
    return SpecialMetadataHook
Source code in backend/src/hatchling/metadata/plugin/interface.py
 class MetadataHookInterface(ABC):  # no cov
    """
    Example usage:
    ```python tab="plugin.py"
    from hatchling.metadata.plugin.interface import MetadataHookInterface
    class SpecialMetadataHook(MetadataHookInterface):
        PLUGIN_NAME = 'special'
        ...
    ```
    ```python tab="hooks.py"
    from hatchling.plugin import hookimpl
    from .plugin import SpecialMetadataHook
    @hookimpl
    def hatch_register_metadata_hook():
        return SpecialMetadataHook
    ```
    """
    PLUGIN_NAME = ''
    """The name used for selection."""
    def __init__(self, root: str, config: dict) -> None:
        self.__root = root
        self.__config = config
    @property
    def root(self) -> str:
        """
        The root of the project tree.
        """
        return self.__root
    @property
    def config(self) -> dict:
        """
        The hook configuration.
        ```toml config-example
        [tool.hatch.metadata.hooks.<PLUGIN_NAME>]
        ```
        """
        return self.__config
    @abstractmethod
    def update(self, metadata: dict) -> None:
        """
        This updates the metadata mapping of the `project` table in-place.
        """
    def get_known_classifiers(self) -> list[str]:  # noqa: PLR6301
        """
        This returns extra classifiers that should be considered valid in addition to the ones known to PyPI.
        """
        return []
 PLUGIN_NAME = ''  class-attribute instance-attribute  ¶
 The name used for selection.
 root: str  property  ¶
 The root of the project tree.
 config: dict  property  ¶
 The hook configuration.
[tool.hatch.metadata.hooks.<PLUGIN_NAME>]
[metadata.hooks.<PLUGIN_NAME>]
 update(metadata: dict) -> None  abstractmethod  ¶
 This updates the metadata mapping of the project table in-place.
Source code in backend/src/hatchling/metadata/plugin/interface.py
 @abstractmethod
def update(self, metadata: dict) -> None:
    """
    This updates the metadata mapping of the `project` table in-place.
    """
 get_known_classifiers() -> list[str] ¶
 This returns extra classifiers that should be considered valid in addition to the ones known to PyPI.
Source code in backend/src/hatchling/metadata/plugin/interface.py
 def get_known_classifiers(self) -> list[str]:  # noqa: PLR6301
    """
    This returns extra classifiers that should be considered valid in addition to the ones known to PyPI.
    """
    return []