git: 6b168f112781 - main - textproc/py-mkdocstrings: Update to 0.22.0
- Go to: [ bottom of page ] [ top of archives ] [ this month ]
Date: Thu, 31 Aug 2023 05:47:51 UTC
The branch main has been updated by kai: URL: https://cgit.FreeBSD.org/ports/commit/?id=6b168f112781310a794a3ba68d99a38c819d9aba commit 6b168f112781310a794a3ba68d99a38c819d9aba Author: Kai Knoblich <kai@FreeBSD.org> AuthorDate: 2023-08-31 05:27:25 +0000 Commit: Kai Knoblich <kai@FreeBSD.org> CommitDate: 2023-08-31 05:44:18 +0000 textproc/py-mkdocstrings: Update to 0.22.0 * Introduce CRYSTAL, PYTHON and PYTHONLEGACY options to reflect the optional dependencies as noted in "pyproject.toml". Leave the last two as non-default for now, because both are mutually exclusive due conflicting dependencies. * Switch to PEP517 build framework and get rid of the no longer required workarounds for distutils. * Remove the backported patch for Jinja2 3.1+ compatibility which is also no longer needed. * Convert the test suite to USE_PYTHON=pytest as well. Changelogs since 0.17.0: https://github.com/mkdocstrings/mkdocstrings/blob/0.22.0/CHANGELOG.md --- textproc/py-mkdocstrings/Makefile | 43 ++++++++++++++------- textproc/py-mkdocstrings/distinfo | 6 +-- textproc/py-mkdocstrings/files/patch-setup.py | 44 ---------------------- .../files/patch-src_mkdocstrings_loggers.py | 34 ----------------- 4 files changed, 33 insertions(+), 94 deletions(-) diff --git a/textproc/py-mkdocstrings/Makefile b/textproc/py-mkdocstrings/Makefile index 3b26f3a5d4a3..5d1896b78f99 100644 --- a/textproc/py-mkdocstrings/Makefile +++ b/textproc/py-mkdocstrings/Makefile @@ -1,6 +1,5 @@ PORTNAME= mkdocstrings -DISTVERSION= 0.17.0 -PORTREVISION= 1 +DISTVERSION= 0.22.0 CATEGORIES= textproc python PKGNAMEPREFIX= ${PYTHON_PKGNAMEPREFIX} @@ -11,32 +10,50 @@ WWW= https://github.com/mkdocstrings/mkdocstrings LICENSE= ISCL LICENSE_FILE= ${WRKSRC}/LICENSE +BUILD_DEPENDS= ${PYTHON_PKGNAMEPREFIX}pdm-backend>0:devel/py-pdm-backend@${PY_FLAVOR} RUN_DEPENDS= ${PYTHON_PKGNAMEPREFIX}Jinja2>=2.11.1:devel/py-Jinja2@${PY_FLAVOR} \ ${PYTHON_PKGNAMEPREFIX}markdown>=3.3:textproc/py-markdown@${PY_FLAVOR} \ ${PYTHON_PKGNAMEPREFIX}markupsafe>=1.1:textproc/py-markupsafe@${PY_FLAVOR} \ ${PYTHON_PKGNAMEPREFIX}mkdocs>=1.2:textproc/py-mkdocs@${PY_FLAVOR} \ ${PYTHON_PKGNAMEPREFIX}pymdown-extensions>=6.3:textproc/py-pymdown-extensions@${PY_FLAVOR} \ - ${PYTHON_PKGNAMEPREFIX}mkdocs-autorefs>=0.1:textproc/py-mkdocs-autorefs@${PY_FLAVOR} \ - ${PYTHON_PKGNAMEPREFIX}pytkdocs>=0.14.0:textproc/py-pytkdocs@${PY_FLAVOR} + ${PYTHON_PKGNAMEPREFIX}mkdocs-autorefs>=0.3.1:textproc/py-mkdocs-autorefs@${PY_FLAVOR} TEST_DEPENDS= ${PYTHON_PKGNAMEPREFIX}pytest>0:devel/py-pytest@${PY_FLAVOR} \ ${PYTHON_PKGNAMEPREFIX}mkdocs-material>0:textproc/py-mkdocs-material@${PY_FLAVOR} \ ${PYTHON_PKGNAMEPREFIX}sphinx>0:textproc/py-sphinx@${PY_FLAVOR} USES= python USE_GITHUB= yes -USE_PYTHON= autoplist distutils +USE_PYTHON= autoplist pep517 pytest +# Skip "test_sphinx_load_mkdocstrings_inventory_file" as it requires +# mkdocs-gen-files (not in Ports tree, yet). +# The same applies to "test_plugin" which requires markdown-exec (not in Ports +# tree yet). +PYTEST_IGNORED_TESTS= test_sphinx_load_mkdocstrings_inventory_file test_plugin +# Required otherwise the build process tries to get the current version via git +MAKE_ENV= PDM_BUILD_SCM_VERSION=${DISTVERSION} TEST_ENV= PYTHONPATH=${STAGEDIR}${PYTHONPREFIX_SITELIBDIR} NO_ARCH= yes -post-patch: - @${REINPLACE_CMD} -e 's|%%DISTVERSION%%|${DISTVERSION}|' ${WRKSRC}/setup.py +OPTIONS_DEFINE= CRYSTAL +OPTIONS_DEFAULT= CRYSTAL +OPTIONS_RADIO= PYHANDLER +OPTIONS_RADIO_PYHANDLER= PYTHON PYTHONLEGACY -# Skip "test_sphinx_load_mkdocstrings_inventory_file" as it requires -# mkdocs-gen-files (not in Ports tree, yet). -do-test: - @cd ${WRKSRC} && ${SETENV} ${TEST_ENV} ${PYTHON_CMD} -m pytest -v -rs \ - -k 'not test_sphinx_load_mkdocstrings_inventory_file' +CRYSTAL_DESC= Crystal language handler +PYTHONLEGACY_DESC= Legacy Python language handler +PYTHON_DESC= Python language handler + +CRYSTAL_RUN_DEPENDS= ${PYTHON_PKGNAMEPREFIX}mkdocstrings-crystal>=0.3.4:textproc/py-mkdocstrings-crystal@${PY_FLAVOR} +PYTHONLEGACY_RUN_DEPENDS= ${PYTHON_PKGNAMEPREFIX}mkdocstrings-python-legacy>=0.2.1:textproc/py-mkdocstrings-python-legacy@${PY_FLAVOR} +PYTHON_RUN_DEPENDS= ${PYTHON_PKGNAMEPREFIX}mkdocstrings-python>=0.5.2:textproc/py-mkdocstrings-python@${PY_FLAVOR} + +.include <bsd.port.pre.mk> + +.if ${PYTHON_REL} < 31000 +RUN_DEPENDS+= ${PYTHON_PKGNAMEPREFIX}importlib-metadata>=4.6:devel/py-importlib-metadata@${PY_FLAVOR} \ + ${PYTHON_PKGNAMEPREFIX}typing-extensions>=4.1:devel/py-typing-extensions@${PY_FLAVOR} +.endif -.include <bsd.port.mk> +.include <bsd.port.post.mk> diff --git a/textproc/py-mkdocstrings/distinfo b/textproc/py-mkdocstrings/distinfo index 7ffaec2dfc77..b6fe9927b69d 100644 --- a/textproc/py-mkdocstrings/distinfo +++ b/textproc/py-mkdocstrings/distinfo @@ -1,3 +1,3 @@ -TIMESTAMP = 1645976995 -SHA256 (mkdocstrings-mkdocstrings-0.17.0_GH0.tar.gz) = dcd8f03387c423bb1ddf6fbbec8dfa0432dfc3d01001adb4a0c07985f333971c -SIZE (mkdocstrings-mkdocstrings-0.17.0_GH0.tar.gz) = 73551 +TIMESTAMP = 1688217280 +SHA256 (mkdocstrings-mkdocstrings-0.22.0_GH0.tar.gz) = fcabb0e22b5630de43ade2e26c3ace2d2d70f132a472da3fda0421571e24883d +SIZE (mkdocstrings-mkdocstrings-0.22.0_GH0.tar.gz) = 81345 diff --git a/textproc/py-mkdocstrings/files/patch-setup.py b/textproc/py-mkdocstrings/files/patch-setup.py deleted file mode 100644 index 99fdbaca862e..000000000000 --- a/textproc/py-mkdocstrings/files/patch-setup.py +++ /dev/null @@ -1,44 +0,0 @@ ---- setup.py.orig 2022-02-28 05:29:01 UTC -+++ setup.py -@@ -0,0 +1,41 @@ -+# Generated via pdm export -f setuppy" (run "pdm lock" beforehand) -+# -*- coding: utf-8 -*- -+from setuptools import setup -+ -+INSTALL_REQUIRES = [ -+ 'Jinja2>=2.11.1', -+ 'Markdown>=3.3', -+ 'MarkupSafe>=1.1', -+ 'mkdocs>=1.2', -+ 'mkdocs-autorefs>=0.1', -+ 'pymdown-extensions>=6.3', -+ 'pytkdocs>=0.14.0', -+] -+ENTRY_POINTS = { -+ 'mkdocs.plugins': [ -+ 'mkdocstrings = mkdocstrings.plugin:MkdocstringsPlugin', -+ ], -+} -+ -+setup_kwargs = { -+ 'name': 'mkdocstrings', -+ 'version': '%%DISTVERSION%%', -+ 'description': 'Automatic documentation from sources, for MkDocs.', -+ 'author': '', -+ 'author_email': 'Timothée Mazzucotelli <pawamoy@pm.me>', -+ 'package_dir': {'': 'src/'}, -+ 'packages': [ -+ 'mkdocstrings', -+ 'mkdocstrings.handlers', -+ 'mkdocstrings.templates.python', -+ 'mkdocstrings.templates.python.material', -+ 'mkdocstrings.templates.python.mkdocs', -+ 'mkdocstrings.templates.python.readthedocs' -+ ], -+ 'package_data': {'': ['*']}, -+ 'install_requires': INSTALL_REQUIRES, -+ 'python_requires': '>=3.6.2', -+ 'entry_points': ENTRY_POINTS, -+} -+ -+setup(**setup_kwargs) diff --git a/textproc/py-mkdocstrings/files/patch-src_mkdocstrings_loggers.py b/textproc/py-mkdocstrings/files/patch-src_mkdocstrings_loggers.py deleted file mode 100644 index defa90fffce3..000000000000 --- a/textproc/py-mkdocstrings/files/patch-src_mkdocstrings_loggers.py +++ /dev/null @@ -1,34 +0,0 @@ -From: =?UTF-8?q?Timoth=C3=A9e=20Mazzucotelli?= <pawamoy@pm.me> -Date: Wed, 2 Feb 2022 12:27:27 +0100 -Subject: [PATCH] refactor: Support Jinja2 3.1 - -Issue #360: https://github.com/mkdocstrings/mkdocstrings/issues/360 -PR #361: https://github.com/mkdocstrings/mkdocstrings/issues/361 - ---- src/mkdocstrings/loggers.py.orig 2021-12-27 17:59:33 UTC -+++ src/mkdocstrings/loggers.py -@@ -4,10 +4,14 @@ from typing import Any, Callable, Optional, Tuple - from pathlib import Path - from typing import Any, Callable, Optional, Tuple - --from jinja2 import contextfunction - from jinja2.runtime import Context - from mkdocs.utils import warning_filter - -+try: -+ from jinja2 import pass_context -+except ImportError: # TODO: remove once Jinja2 < 3.1 is dropped -+ from jinja2 import contextfunction as pass_context # noqa: WPS440 -+ - TEMPLATES_DIR = Path(__file__).parent / "templates" - - -@@ -71,7 +75,7 @@ def get_template_logger_function(logger_func: Callable - A function. - """ - -- @contextfunction -+ @pass_context - def wrapper(context: Context, msg: Optional[str] = None) -> str: - """Log a message. -