- Tests - gh-127906: Test the limited C API in test_cppext. Patch by Victor Stinner. - gh-127906: Backport test_cext from the main branch. Patch by Victor Stinner. - gh-127637: Add tests for the dis command-line interface. Patch by Bénédikt Tran. - Security - gh-105704: When using urllib.parse.urlsplit() and urllib.parse.urlparse() host parsing would not reject domain names containing square brackets ([ and ]). Square brackets are only valid for IPv6 and IPvFuture hosts according to RFC 3986 Section 3.2.2. (CVE-2025-0938, bsc#1236705) - gh-127655: Fixed the asyncio.selector_events._SelectorSocketTransport transport not pausing writes for the protocol when the buffer reaches the high water mark when using asyncio.WriteTransport.writelines() (CVE-2024-12254, bsc#1234290). - gh-126108: Fix a possible NULL pointer dereference in PySys_AddWarnOptionUnicode(). - gh-80222: Fix bug in the folding of quoted strings when flattening an email message using a modern email policy. Previously when a quoted string was folded so that it spanned more than one line, the surrounding quotes and internal escapes would be omitted. This could theoretically be used to spoof header lines using a carefully constructed quoted string if the resulting OBS-URL: https://build.opensuse.org/package/show/devel:languages:python:Factory/python312?expand=0&rev=94
57 lines
2.1 KiB
Diff
57 lines
2.1 KiB
Diff
---
|
|
Doc/tools/extensions/c_annotations.py | 6 +++++-
|
|
Doc/tools/extensions/glossary_search.py | 12 ++++++++++--
|
|
Doc/tools/extensions/pyspecific.py | 5 ++++-
|
|
3 files changed, 19 insertions(+), 4 deletions(-)
|
|
|
|
--- a/Doc/tools/extensions/c_annotations.py
|
|
+++ b/Doc/tools/extensions/c_annotations.py
|
|
@@ -117,7 +117,11 @@ def add_annotations(app: Sphinx, doctree
|
|
state = app.env.domaindata["c_annotations"]
|
|
refcount_data = state["refcount_data"]
|
|
stable_abi_data = state["stable_abi_data"]
|
|
- for node in doctree.findall(addnodes.desc_content):
|
|
+ try:
|
|
+ findall = doctree.findall
|
|
+ except AttributeError:
|
|
+ findall = doctree.traverse
|
|
+ for node in findall(addnodes.desc_content):
|
|
par = node.parent
|
|
if par["domain"] != "c":
|
|
continue
|
|
--- a/Doc/tools/extensions/glossary_search.py
|
|
+++ b/Doc/tools/extensions/glossary_search.py
|
|
@@ -30,8 +30,16 @@ def process_glossary_nodes(
|
|
else:
|
|
terms = app.env.glossary_terms = {}
|
|
|
|
- for node in doctree.findall(glossary):
|
|
- for glossary_item in node.findall(nodes.definition_list_item):
|
|
+ try:
|
|
+ findall = doctree.findall
|
|
+ except AttributeError:
|
|
+ findall = doctree.traverse
|
|
+ for node in findall(glossary):
|
|
+ try:
|
|
+ node_findall = node.findall
|
|
+ except AttributeError:
|
|
+ node_findall = node.traverse
|
|
+ for glossary_item in node_findall(nodes.definition_list_item):
|
|
term = glossary_item[0].astext()
|
|
definition = glossary_item[-1]
|
|
|
|
--- a/Doc/tools/extensions/pyspecific.py
|
|
+++ b/Doc/tools/extensions/pyspecific.py
|
|
@@ -25,7 +25,10 @@ from sphinx.domains.python import PyFunc
|
|
from sphinx.locale import _ as sphinx_gettext
|
|
from sphinx.util.docutils import SphinxDirective
|
|
from sphinx.writers.text import TextWriter, TextTranslator
|
|
-from sphinx.util.display import status_iterator
|
|
+try:
|
|
+ from sphinx.util.display import status_iterator
|
|
+except ModuleNotFoundError:
|
|
+ from sphinx.util import status_iterator
|
|
|
|
|
|
ISSUE_URI = 'https://bugs.python.org/issue?@action=redirect&bpo=%s'
|