From e3441fbcf3aad2138a58a569c6142406a40542c1 Mon Sep 17 00:00:00 2001 From: dolf Date: Thu, 19 Sep 2024 22:45:50 +0200 Subject: [PATCH 1/2] Update mkdocstrings and griffe to the latest versions. Remove some unnecessary code from the Handler. --- mkdocstrings_handlers/vba/_handler.py | 115 ++++++++++---------------- mkdocstrings_handlers/vba/_sort.py | 2 +- mkdocstrings_handlers/vba/_types.py | 2 +- mkdocstrings_handlers/vba/_util.py | 3 +- mypy-requirements.txt | 6 +- setup.py | 4 +- 6 files changed, 51 insertions(+), 81 deletions(-) diff --git a/mkdocstrings_handlers/vba/_handler.py b/mkdocstrings_handlers/vba/_handler.py index 051d1bd..afc716e 100644 --- a/mkdocstrings_handlers/vba/_handler.py +++ b/mkdocstrings_handlers/vba/_handler.py @@ -5,26 +5,21 @@ from __future__ import annotations import copy -import posixpath from collections import ChainMap from pathlib import Path from typing import ( Any, - BinaryIO, - Iterator, - Optional, - Tuple, MutableMapping, Dict, Mapping, Set, + Tuple, ) -from griffe.logger import patch_loggers +from griffe import patch_loggers from markdown import Markdown from mkdocs.exceptions import PluginError -from mkdocstrings.handlers.base import BaseHandler -from mkdocstrings.inventory import Inventory +from mkdocstrings.handlers.base import BaseHandler, CollectionError from mkdocstrings.loggers import get_logger from ._crossref import do_crossref, do_multi_crossref @@ -49,14 +44,14 @@ def __init__(self, *, base_dir: Path, **kwargs: Any) -> None: super().__init__(**kwargs) self.base_dir = base_dir - domain: str = "vba" + name: str = "vba" """ - The cross-documentation domain/language for this handler. + The handler's name. """ - enable_inventory: bool = True + domain: str = "vba" """ - Whether this handler is interested in enabling the creation of the `objects.inv` Sphinx inventory file. + The cross-documentation domain/language for this handler. """ fallback_theme = "material" @@ -83,9 +78,7 @@ def __init__(self, *, base_dir: Path, **kwargs: Any) -> None: "docstring_section_style": "table", } """ - The default rendering options. - - See [`default_config`][mkdocstrings_handlers.vba.renderer.VbaRenderer.default_config]. + The default handler configuration. Option | Type | Description | Default ------ | ---- | ----------- | ------- @@ -107,32 +100,38 @@ def __init__(self, *, base_dir: Path, **kwargs: Any) -> None: **`docstring_section_style`** | `str` | The style used to render docstring sections. Options: `table`, `list`, `spacy`. | `table` """ - @classmethod - def load_inventory( - cls, - in_file: BinaryIO, - url: str, - base_url: Optional[str] = None, - **kwargs: Any, - ) -> Iterator[Tuple[str, str]]: - """Yield items and their URLs from an inventory file streamed from `in_file`. - - This implements mkdocstrings' `load_inventory` "protocol" (see plugin.py). + def collect( + self, + identifier: str, + config: MutableMapping[str, Any], + ) -> VbaModuleInfo: + """Collect the documentation tree given an identifier and selection options. Arguments: - in_file: The binary file-like object to read the inventory from. - url: The URL that this file is being streamed from (used to guess `base_url`). - base_url: The URL that this inventory's sub-paths are relative to. - **kwargs: Ignore additional arguments passed from the config. + identifier: Which VBA file (.bas or .cls) to collect from. + config: Selection options, used to alter the data collection. - Yields: - Tuples of (item identifier, item URL). + Raises: + CollectionError: When there was a problem collecting the documentation. + + Returns: + The collected object tree. """ - if base_url is None: - base_url = posixpath.dirname(url) + p = Path(self.base_dir, identifier) + if not p.exists(): + raise CollectionError("File not found.") + + with p.open("r") as f: + code = f.read() - for item in Inventory.parse_sphinx(in_file, domain_filter=("py",)).values(): - yield item.name, posixpath.join(base_url, item.uri) + code = collapse_long_lines(code) + + return VbaModuleInfo( + docstring=find_file_docstring(code), + source=code.splitlines(), + path=p, + procedures=list(find_procedures(code)), + ) def render( self, @@ -163,9 +162,6 @@ def render( }, ) - def get_anchors(self, data: VbaModuleInfo) -> Set[str]: - return {data.path.as_posix(), *(p.signature.name for p in data.procedures)} - def update_env(self, md: Markdown, config: Dict[Any, Any]) -> None: super().update_env(md, config) self.env.trim_blocks = True @@ -175,38 +171,12 @@ def update_env(self, md: Markdown, config: Dict[Any, Any]) -> None: self.env.filters["multi_crossref"] = do_multi_crossref self.env.filters["order_members"] = do_order_members - def collect( - self, - identifier: str, - config: MutableMapping[str, Any], - ) -> VbaModuleInfo: - """Collect the documentation tree given an identifier and selection options. - - Arguments: - identifier: Which VBA file (.bas or .cls) to collect from. - config: Selection options, used to alter the data collection. - - Raises: - CollectionError: When there was a problem collecting the documentation. - - Returns: - The collected object tree. - """ - p = Path(self.base_dir, identifier) - with p.open("r") as f: - code = f.read() - - code = collapse_long_lines(code) - - return VbaModuleInfo( - docstring=find_file_docstring(code), - source=code.splitlines(), - path=p, - procedures=list(find_procedures(code)), - ) + def get_anchors(self, data: VbaModuleInfo) -> Tuple[str, ...]: + return data.path.as_posix(), *(p.signature.name for p in data.procedures) def get_handler( + *, theme: str, custom_templates: str | None = None, config_file_path: str | None = None, @@ -229,11 +199,12 @@ def get_handler( An instance of `VbaHandler`. """ return VbaHandler( - base_dir=Path(config_file_path or ".").parent, + base_dir=( + Path(config_file_path).resolve().parent + if config_file_path + else Path(".").resolve() + ), handler="vba", theme=theme, custom_templates=custom_templates, - config_file_path=config_file_path, - paths=paths, - locale=locale, ) diff --git a/mkdocstrings_handlers/vba/_sort.py b/mkdocstrings_handlers/vba/_sort.py index e7c52ad..151cb65 100644 --- a/mkdocstrings_handlers/vba/_sort.py +++ b/mkdocstrings_handlers/vba/_sort.py @@ -4,7 +4,7 @@ import sys from typing import Any, Sequence -from griffe.dataclasses import Alias, Object +from griffe import Alias, Object from mkdocstrings.handlers.base import CollectorItem diff --git a/mkdocstrings_handlers/vba/_types.py b/mkdocstrings_handlers/vba/_types.py index f3deea8..074766e 100644 --- a/mkdocstrings_handlers/vba/_types.py +++ b/mkdocstrings_handlers/vba/_types.py @@ -2,7 +2,7 @@ from pathlib import Path from typing import List, Optional -from griffe.dataclasses import Docstring +from griffe import Docstring @dataclass diff --git a/mkdocstrings_handlers/vba/_util.py b/mkdocstrings_handlers/vba/_util.py index 6e8f8fc..640bcf9 100644 --- a/mkdocstrings_handlers/vba/_util.py +++ b/mkdocstrings_handlers/vba/_util.py @@ -1,8 +1,7 @@ import re from typing import List, Generator -from griffe.dataclasses import Docstring, Function, Parameters, Parameter -from griffe.docstrings import Parser +from griffe import Docstring, Function, Parameters, Parameter, Parser from ._regex import re_signature, re_arg from ._types import ( diff --git a/mypy-requirements.txt b/mypy-requirements.txt index 464660a..fab278d 100644 --- a/mypy-requirements.txt +++ b/mypy-requirements.txt @@ -1,3 +1,3 @@ -mypy==1.5.1 -types-setuptools -types-Markdown +mypy==1.11.2 +types-setuptools==75.* +types-Markdown==3.* diff --git a/setup.py b/setup.py index 46c3aa8..acfa5ff 100644 --- a/setup.py +++ b/setup.py @@ -28,8 +28,8 @@ "setuptools_scm", ], install_requires=[ - "mkdocstrings>=0.22,<0.23", - "griffe>=0.34,<0.35", + "mkdocstrings>=0.26.1,<1", + "griffe>=1.3.1,<2", "mkdocs-material>=9.2,<10", ], include_package_data=True, From b063c0b11c51f477434f41bd6231c5ad7b64adda Mon Sep 17 00:00:00 2001 From: dolf Date: Thu, 19 Sep 2024 22:57:12 +0200 Subject: [PATCH 2/2] Update ci-constraints.txt --- ci-constraints.txt | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/ci-constraints.txt b/ci-constraints.txt index e85d330..8dd68c6 100644 --- a/ci-constraints.txt +++ b/ci-constraints.txt @@ -1,3 +1,3 @@ -mkdocstrings==0.22.0 -griffe==0.34.0 +mkdocstrings==0.26.1 +griffe==1.3.1 mkdocs-material==9.2.1