From bbc97e035720d96f617921dbd25022e121495b98 Mon Sep 17 00:00:00 2001 From: Adam Turner <9087854+AA-Turner@users.noreply.github.com> Date: Sat, 20 Jul 2024 15:19:55 +0100 Subject: [PATCH] autosummary: Filter invalid import prefixes in ``autolink`` (#12626) --- CHANGES.rst | 4 +++- sphinx/ext/autosummary/__init__.py | 9 ++++++++- 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/CHANGES.rst b/CHANGES.rst index 1686f2cbc8a..ed2d18d5916 100644 --- a/CHANGES.rst +++ b/CHANGES.rst @@ -15,6 +15,8 @@ Bugs fixed ``sphinx.ext.autodoc``, especially when using :mod:`dataclasses` as type metadata. Patch by Adam Turner. +* #12589, #12626: autosummary: Fix warnings with :rst:role:`!autolink`. + Patch by Adam Turner. Release 7.4.6 (released Jul 18, 2024) ===================================== @@ -22,7 +24,7 @@ Release 7.4.6 (released Jul 18, 2024) Bugs fixed ---------- -* #12859, #9743, #12609: autosummary: Do not add the package prefix when +* #12589, #9743, #12609: autosummary: Do not add the package prefix when generating autosummary directives for modules within a package. Patch by Adam Turner. * #12613: Reduce log severity for ambiguity detection during inventory loading. diff --git a/sphinx/ext/autosummary/__init__.py b/sphinx/ext/autosummary/__init__.py index 7fa419483f9..225651ae819 100644 --- a/sphinx/ext/autosummary/__init__.py +++ b/sphinx/ext/autosummary/__init__.py @@ -765,7 +765,14 @@ def run(self) -> tuple[list[Node], list[system_message]]: try: # try to import object by name prefixes = get_import_prefixes_from_env(self.env) - import_by_name(pending_xref['reftarget'], prefixes) + name = pending_xref['reftarget'] + prefixes = [ + prefix + for prefix in prefixes + if prefix is None + or not (name.startswith(f'{prefix}.') or name == prefix) + ] + import_by_name(name, prefixes) except ImportExceptionGroup: literal = cast(nodes.literal, pending_xref[0]) objects[0] = nodes.emphasis(self.rawtext, literal.astext(),