diff options
author | Miss Islington (bot) <31488909+miss-islington@users.noreply.github.com> | 2023-04-08 08:24:27 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-04-08 08:24:27 (GMT) |
commit | 31bec9198b194798e95c0c46bceff1913784d8ff (patch) | |
tree | 9485b4c5d98fde973e52b31a85d5f55e71a7ea72 /Doc/tools | |
parent | b4f331820772c95c2d5eae9e5f416effb70a8db2 (diff) | |
download | cpython-31bec9198b194798e95c0c46bceff1913784d8ff.zip cpython-31bec9198b194798e95c0c46bceff1913784d8ff.tar.gz cpython-31bec9198b194798e95c0c46bceff1913784d8ff.tar.bz2 |
Docs: use Node.findall to avoid a deprecation warning (GH-99403)
(cherry picked from commit 1e9dfdacefa2c8c27762ba6491b0f570147ee355)
Co-authored-by: Adam Turner <9087854+AA-Turner@users.noreply.github.com>
Diffstat (limited to 'Doc/tools')
-rw-r--r-- | Doc/tools/extensions/c_annotations.py | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/Doc/tools/extensions/c_annotations.py b/Doc/tools/extensions/c_annotations.py index a845ef4..7cb6bd8 100644 --- a/Doc/tools/extensions/c_annotations.py +++ b/Doc/tools/extensions/c_annotations.py @@ -20,6 +20,7 @@ """ from os import path +import docutils from docutils import nodes from docutils.parsers.rst import directives from docutils.parsers.rst import Directive @@ -41,6 +42,16 @@ REST_ROLE_MAP = { } +# Monkeypatch nodes.Node.findall for forwards compatability +# This patch can be dropped when the minimum Sphinx version is 4.4.0 +# or the minimum Docutils version is 0.18.1. +if docutils.__version_info__ < (0, 18, 1): + def findall(self, *args, **kwargs): + return iter(self.traverse(*args, **kwargs)) + + nodes.Node.findall = findall + + class RCEntry: def __init__(self, name): self.name = name @@ -87,7 +98,7 @@ class Annotations: self.stable_abi_data[name] = record def add_annotations(self, app, doctree): - for node in doctree.traverse(addnodes.desc_content): + for node in doctree.findall(addnodes.desc_content): par = node.parent if par['domain'] != 'c': continue |