community
community copied to clipboard
Update dependency sphinx to v7
This PR contains the following updates:
| Package | Change | Age | Adoption | Passing | Confidence |
|---|---|---|---|---|---|
| sphinx (changelog) | ~=6.2.1 -> ~=7.3.7 |
Release Notes
sphinx-doc/sphinx (sphinx)
v7.3.7
=====================================
Bugs fixed
- #12299: Defer loading themes defined via entry points until their explicit use by the user or a child theme. Patch by Adam Turner.
- #12305: Return the default value for
theme.get_config()with an unsupported theme configuration section. Patch by Adam Turner.
v7.3.6
=====================================
Bugs fixed
- #12295: Re-export all AST types in the C and C++ domains. Patch by Adam Turner.
- #12295: Re-export various objects from
sphinx.domains.python._annotationsinsphinx.domains.python. Patch by Jacob Chesslo and Adam Turner.
v7.3.5
=====================================
Bugs fixed
- #12295: Re-export various objects from
sphinx.domains.python._objectinsphinx.domains.python. Patch by Jacob Chesslo and Adam Turner.
v7.3.4
=====================================
Bugs fixed
- Handle cases when
Anyis not an instance oftype. Patch by Adam Turner.
v7.3.3
=====================================
Bugs fixed
- #12290: Fix a false-positive warning when setting a configuration value
with
Anyas the valid type to a type other than the value's default. Patch by Adam Turner.
v7.3.2
=====================================
Bugs fixed
- Preload all themes defined via entry points. Patch by Adam Turner.
- Fix a bad interaction between the
'Furo'theme and the new-style for configuration values. Patch by Adam Turner.
v7.3.1
=====================================
Dependencies
- Require
tomlion Python 3.10 and earlier. Patch by Adam Turner.
v7.3.0
=====================================
Dependencies
-
#11858: Increase the minimum supported version of Alabaster to 0.7.14. Patch by Adam Turner.
-
#11411: Support
Docutils 0.21_. Patch by Adam Turner... _Docutils 0.21: https://docutils.sourceforge.io/RELEASE-NOTES.html#release-0-21-2024-04-09
-
#12012: Use
types-docutilsinstead ofdocutils-stubs.
Deprecated
- #11693: Support for old-style :file:
Makefileand :file:make.batoutput in :program:sphinx-quickstart, and the associated options :option:!-M, :option:!-m, :option:!--no-use-make-mode, and :option:!--use-make-mode. - #11285: Direct access to :attr:
!sphinx.testing.util.SphinxTestApp._statusor :attr:!sphinx.testing.util.SphinxTestApp._warningis deprecated. Use the public properties :attr:!sphinx.testing.util.SphinxTestApp.statusand :attr:!sphinx.testing.util.SphinxTestApp.warninginstead. Patch by Bénédikt Tran. - tests: :func:
!sphinx.testing.util.strip_escseqis deprecated in favour of :func:!sphinx.util.console.strip_colors. Patch by Bénédikt Tran.
Features added
-
#12265: Support theme configuration via
theme.toml. -
#11701: HTML Search: Adopt the new
\<search\>_ element. Patch by Bénédikt Tran... _
\<search\>: https://developer.mozilla.org/en-US/docs/Web/HTML/Element/search -
#11776: Add long option names to
sphinx-build. Patch by Hugo van Kemenade, Adam Turner, Bénédikt Tran, and Ezio Melotti. -
Organise the
sphinx-buildoptions into groups. Patch by Adam Turner. -
#11855: Defer computation of configuration values. Patch by Adam Turner.
-
Add
:no-search:as an alias of the:nosearch:metadata field. Patch by Adam Turner. -
#11803: autodoc: Use an overriden
__repr__()function in an enum, if defined. Patch by Shengyu Zhang. -
#11825: Allow custom targets in the manpage role. Patch by Nicolas Peugnet.
-
#11892: Improved performance when resolving cross references in the C++ domain. Patch by Rouslan Korneychuk.
-
#11905: Add a :rst:dir:
versionremoveddirective. Patch by Hugo van Kemenade, Adam Turner, and C.A.M. Gerlach. -
#11981: Improve rendering of signatures using
slicesyntax, e.g.,def foo(arg: np.float64[:,:]) -> None: .... -
The manpage builder now adds
OSC 8_ anchors to hyperlinks, using thegroff_ device control command... _OSC 8: https://gist.github.com/egmontkob/eb114294efbcd5adb1944c9f3cb5feda .. _groff: https://lists.gnu.org/archive/html/groff/2021-10/msg00000.html
-
#11015: Change the text of the :rst:dir:
versionaddeddirective fromNew in [...]toAdded in [...]. Patch by Bénédikt Tran. -
#12131: Added :confval:
show_warning_typesconfiguration option. Patch by Chris Sewell. -
#12193: Improve
externalwarnings for unknown roles. In particular, suggest related role names if an object type is mistakenly used. Patch by Chris Sewell. -
Add public type alias :class:
sphinx.util.typing.ExtensionMetadata. This can be used by extension developers to annotate the return type of theirsetupfunction. Patch by Chris Sewell.
Bugs fixed
-
#11668: Raise a useful error when
theme.confis missing. Patch by Vinay Sajip. -
#11622: Ensure that the order of keys in
searchindex.jsis deterministic. Patch by Pietro Albini. -
#11617: ANSI control sequences are stripped from the output when writing to a warnings file with :option:
-w <sphinx-build -w>. Patch by Bénédikt Tran. -
#11666: Skip all hidden directories in
CatalogRepository.pofiles. Patch by Aryaz Eghbali. -
#9686: html builder: Fix MathJax lazy loading when equations appear in titles. Patch by Bénédikt Tran.
-
#11483: singlehtml builder: Fix MathJax lazy loading when the index does not contain any math equations. Patch by Bénédikt Tran.
-
#11697: HTML Search: add 'noindex' meta robots tag. Patch by James Addison.
-
#11678: Fix a possible
ZeroDivisionErrorinsphinx.ext.coverage. Patch by Stephen Finucane. -
#11756: LaTeX: build error with recent TeXLive due to missing
substitutefontpackage (triggered if usingfontencwithT2Aoption and document language is not a Cyrillic one). Patch by Jean-François B. -
#11675: Fix rendering of progression bars in environments that do not support ANSI control sequences. Patch by Bénédikt Tran.
-
#11861: Whitelist more types with an incorrect
__module__attribute. Patch by Adam Turner. -
#11715: Apply
tls_verifyandtls_cacertsconfig toImageDownloader. Patch by Nick Touran. -
Allow hyphens in group names for :rst:dir:
productionlistcross-references. Patch by Adam Turner. -
#11433: Added the :confval:
linkcheck_allow_unauthorizedconfiguration option. Set this option toFalseto report HTTP 401 (unauthorized) server responses as broken. Patch by James Addison. -
#11868: linkcheck: added a distinct
timeoutreporting status code. This can be enabled by setting :confval:linkcheck_report_timeouts_as_brokentoFalse. Patch by James Addison. -
#11869: Refresh the documentation for the
linkcheck_timeoutsetting. Patch by James Addison. -
#11874: Configure a default 30-second value for
linkcheck_timeout. Patch by James Addison. -
#11886: Print the Jinja2 template path chain in
TemplateNotFoundexceptions. Patch by Colin Marquardt. -
#11598: Do not use query components in URLs for assets in EPUB rendering. Patch by David Runge.
-
#11904: Support unary subtraction when parsing annotations. Patch by James Addison.
-
#11925: Blacklist the
sphinxprettysearchresultsextension; the functionality it provides was merged into Sphinx v2.0.0. Patch by James Addison. -
#11917: Fix rendering of annotated inherited members for Python 3.9. Patch by Janet Carson.
-
#11935: C Domain: Fix namespace-pop context. Patch by Frank Dana.
-
#11923: Avoid zombie processes when parallel builds fail. Patch by Felix von Drigalski.
-
#11353: Support enumeration classes inheriting from mixin or data types. Patch by Bénédikt Tran.
-
#11962: Fix target resolution when using
:paramtype:fields. Patch by Bénédikt Tran. -
#11944: Use anchor in search preview. Patch by Will Lachance.
-
#12008: Fix case-sensitive lookup of
std:labelnames in intersphinx inventory. Patch by Michael Goerz. -
#11958: HTML Search: Fix partial matches overwriting full matches. Patch by William Lachance.
-
#11959: Fix multiple term matching when word appears in both title and document. Patch by Will Lachance.
-
#11474: Fix doctrees caching causing files not be rebuilt in some cases, e.g., when :confval:
numfigisTrue. Patch by Bénédikt Tran. -
#11278: autodoc: Fix rendering of :class:
functools.singledispatchmethodcombined with :func:@classmethod <classmethod>. Patch by Bénédikt Tran. -
#11894: Do not add checksums to css files if building using the htmlhelp builder. Patch by reduerK akiM.
-
#12052: Remove
<script>and<style>tags from the content of search result summary snippets. Patch by James Addison. -
#11578: HTML Search: Order non-main index entries after other results. Patch by Brad King.
-
#12147: autosummary: Fix a bug whereby the wrong file extension may be used, when multiple suffixes are specified in :confval:
source_suffix. Patch by Sutou Kouhei. -
#10786: improve the error message when a file to be copied (e.g., an asset) is removed during Sphinx execution. Patch by Bénédikt Tran.
-
#12040: HTML Search: Ensure that document titles that are partially-matched by the user search query are included in search results. Patch by James Addison.
-
#11970: singlehtml builder: make target URIs to be same-document references in the sense of :rfc:
RFC 3986, §4.4 <3986#section-4.4>, e.g.,index.html#foobecomes#foo. Patch by Eric Norige. -
#12271: Partially revert Docutils' r9562__ to fix EPUB files. Patch by Adam Turner.
__ https://sourceforge.net/p/docutils/code/9562/
-
#12253: Escape reserved path characters in the remote images post-transform download cache. Patch by James Addison and Adam Turner.
Testing
- Reorganise tests into directories. Patch by Adam Turner.
- Clean up global state in
SphinxTestApp. Patch by Adam Turner. - #11285: :func:
!pytest.mark.sphinxand :class:!sphinx.testing.util.SphinxTestAppaccept warningiserror, keep_going and verbosity as keyword arguments. Patch by Bénédikt Tran. - #11285: :class:
!sphinx.testing.util.SphinxTestAppstatus and warning arguments are checked to be :class:io.StringIOobjects (the public API incorrectly assumed this without checking it). Patch by Bénédikt Tran. - Report the result of
test_run_epubcheckasskippedinstead ofsuccesswhen either Java orepubcheckare not available. - Use dynamic allocation of unused port numbers for the test HTTP(S) servers.
As a side-effect, this removes the need for test server lockfiles,
meaning that any remaining
tests/test-server.lockfiles can safely be deleted.
v7.2.6
=====================================
Bugs fixed
- #11679: Add the :envvar:
!SPHINX_AUTODOC_RELOAD_MODULESenvironment variable, which if set reloads modules when using autodoc withTYPE_CHECKING = True. Patch by Matt Wozniski and Adam Turner. - #11679: Use :py:func:
importlib.reloadto reload modules in autodoc. Patch by Matt Wozniski and Adam Turner.
v7.2.5
=====================================
Bugs fixed
- #11645: Fix a regression preventing autodoc from importing modules within
packages that make use of
if typing.TYPE_CHECKING:to guard circular imports needed by type checkers. Patch by Matt Wozniski. - #11634: Fixed inheritance diagram relative link resolution for sibling files in a subdirectory. Patch by Albert Shih.
- #11659: Allow
?config=...in :confval:mathjax_path. - #11654: autodoc: Fail with a more descriptive error message
when an object claims to be an instance of
type, but is not a class. Patch by James Braza. - 11620: Cease emitting :event:
source-readevents for files read via the :dudir:includedirective. - 11620: Add a new :event:
include-readfor observing and transforming the content of included files via the :dudir:includedirective. - #11627: Restore support for copyright lines of the form
YYYYwhenSOURCE_DATE_EPOCHis set.
v7.2.4
=====================================
Bugs fixed
- #11618: Fix a regression in the MoveModuleTargets transform, introduced in #10478 (#9662).
- #11649: linkcheck: Resolve hanging tests for timezones west of London and incorrect conversion from UTC to offsets from the UNIX epoch. Patch by Dmitry Shachnev and Adam Turner.
v7.2.3
=====================================
Dependencies
- #11576: Require sphinxcontrib-serializinghtml 1.1.9.
Bugs fixed
- Fix regression in
autodoc.Documenter.parse_name(). - Fix regression in JSON serialisation.
- #11543: autodoc: Support positional-only parameters in
classmethodmethods whenautodoc_preserve_defaultsisTrue. - Restore support string methods on path objects.
This is deprecated and will be removed in Sphinx 8.
Use :py:func:
os.fspathto convert :py:class:~pathlib.Pathobjects to strings, or :py:class:~pathlib.Path's methods to work with path objects.
v7.2.2
=====================================
Bugs fixed
- Fix the signature of the
StateMachine.insert_input()patch, for when calling with keyword arguments. - Fixed membership testing (
in) for the :py:class:strinterface of the asset classes (_CascadingStyleSheetand_JavaScript), which several extensions relied upon. - Fixed a type error in
SingleFileHTMLBuilder._get_local_toctree,includehiddenmay be passed as a string or a boolean. - Fix
:noindex:forPyModuleandJSModule.
v7.2.1
=====================================
Bugs fixed
- Restored the the :py:class:
strinterface of the asset classes (_CascadingStyleSheetand_JavaScript), which several extensions relied upon. This will be removed in Sphinx 9. - Restored calls to
Builder.add_{css,js}_file(), which several extensions relied upon. - Restored the private API
TocTree.get_toctree_ancestors(), which several extensions relied upon.
v7.2.0
=====================================
Dependencies
Deprecated
- #11512: Deprecate
sphinx.util.md5andsphinx.util.sha1. Usehashlibinstead. - #11526: Deprecate
sphinx.testing.path. Useos.pathorpathlibinstead. - #11528: Deprecate
sphinx.util.split_index_msgandsphinx.util.split_into. Usesphinx.util.index_entries.split_index_msginstead. - Deprecate
sphinx.builders.html.Stylesheetandsphinx.builders.html.Javascript. Usesphinx.application.Sphinx.add_css_file()andsphinx.application.Sphinx.add_js_file()instead. - #11582: Deprecate
sphinx.builders.html.StandaloneHTMLBuilder.css_filesandsphinx.builders.html.StandaloneHTMLBuilder.script_files. Usesphinx.application.Sphinx.add_css_file()andsphinx.application.Sphinx.add_js_file()instead. - #11459: Deprecate
sphinx.ext.autodoc.preserve_defaults.get_function_def(). Patch by Bénédikt Tran.
Features added
- #11526: Support
os.PathLiketypes andpathlib.Pathobjects in many more places. - #5474: coverage: Print summary statistics tables. Patch by Jorge Leitao.
- #6319: viewcode: Add :confval:
viewcode_line_numbersto control whether line numbers are added to rendered source code. Patch by Ben Krikler. - #9662: Add the
:no-typesetting:option to suppress textual output and only create a linkable anchor. Patch by Latosha Maltba. - #11221: C++: Support domain objects in the table of contents. Patch by Rouslan Korneychuk.
- #10938: doctest: Add :confval:
doctest_show_successesoption. Patch by Trey Hunner. - #11533: Add
:no-index:,:no-index-entry:, and:no-contents-entry:. - #11572: Improve
debuglogging of reasons why files are detected as out of date. Patch by Eric Larson. - #10678: Emit :event:
source-readevents for files read via the :dudir:includedirective. Patch by Halldor Fannar. - #11570: Use short names when using :pep:
585built-in generics. Patch by Riccardo Mori. - #11300: Improve
SigElementFallbackTransformfallback logic and signature text elements nodes. See :doc:the documentation </extdev/nodes>for more details. Patch by Bénédikt Tran. - Allow running Sphinx with
python -m sphinx build ....
Bugs fixed
- #11077: graphviz: Fix relative links from within the graph. Patch by Ralf Grubenmann.
- #11529: Line Block in LaTeX builder outputs spurious empty token. Patch by Adrian Vollmer.
- #11196: autosummary: Summary line extraction failed with "e.g."
- #10614: Fixed a number of bugs in inheritance diagrams that resulted in missing or broken links. Patch by Albert Shih.
- #9428: Exclude substitution definitions when running the
gettextbuilder. Patch by Alvin Wong. - #10795: Raise a descriptive error if
graphviz_dotis falsy. - #11546: Translated nodes identical to their original text are now marked
with the
translated=Trueattribute. - #10049: html: Change "Permalink" to "Link" for title text in link anchors.
- #4225: Relax Pygments parsing on lexing failures.
- #11246: Allow inline links in the first line of a docstring and one-line
type comments
#: :meta ...:when using :mod:sphinx.ext.napoleon. Patch by Bénédikt Tran. - #10930: Highlight all search terms on the search results page. Patch by Dmitry Shachnev.
- #11473: Type annotations containing :py:data:
~typing.Literalenumeration values now render correctly. Patch by Bénédikt Tran. - #11591: Fix support for C coverage in
sphinx.ext.coverageextension. Patch by Stephen Finucane. - #11594: HTML Theme: Enhancements to horizontal scrolling on smaller
devices in the
agogotheme. Patch by Lukas Engelter. - #11459: Fix support for async and lambda functions in
sphinx.ext.autodoc.preserve_defaults. Patch by Bénédikt Tran.
Testing
- #11577: pytest: Fail tests on "XPASS".
- #11577: pytest: Use "importlib" import mode.
- #11577: pytest: Set PYTHONWARNINGS=error.
- #11577: pytest: Set strict config and strict markers.
v7.1.2
=====================================
Bugs fixed
- #11542: linkcheck: Properly respect :confval:
linkcheck_anchorsand do not spuriously report failures to validate anchors. Patch by James Addison.
v7.1.1
=====================================
Bugs fixed
- #11514: Fix
SOURCE_DATE_EPOCHin multi-line copyright footer. Patch by Bénédikt Tran.
v7.1.0
=====================================
Incompatible changes
-
Releases are no longer signed, given the
change in PyPI policy_... _change in PyPI policy: https://blog.pypi.org/posts/2023-05-23-removing-pgp/
Deprecated
- #11412: Emit warnings on using a deprecated Python-specific index entry type
(namely,
module,keyword,operator,object,exception,statement, andbuiltin) in the :rst:dir:indexdirective, and set the removal version to Sphinx 9. Patch by Adam Turner.
Features added
- #11415: Add a checksum to JavaScript and CSS asset URIs included within generated HTML, using the CRC32 algorithm.
- :meth:
~sphinx.application.Sphinx.require_sphinxnow allows the version requirement to be specified as(major, minor). - #11011: Allow configuring a line-length limit for object signatures, via
:confval:
maximum_signature_line_lengthand the domain-specific variants. If the length of the signature (in characters) is greater than the configured limit, each parameter in the signature will be split to its own logical line. This behaviour may also be controlled by options on object description directives, for example :rst:dir:py:function:single-line-parameter-list. Patch by Thomas Louf, Adam Turner, and Jean-François B. - #10983: Support for multiline copyright statements in the footer block. Patch by Stefanie Molin
sphinx.util.display.status_iteratornow clears the current line with ANSI control codes, rather than overprinting with space characters.- #11431: linkcheck: Treat SSL failures as broken links. Patch by James Addison.
- #11157: Keep the
translatedattribute on translated nodes. - #11451: Improve the traceback displayed when using :option:
sphinx-build -Tin parallel builds. Patch by Bénédikt Tran - #11324: linkcheck: Use session-basd HTTP requests.
- #11438: Add support for the :rst:dir:
py:classand :rst:dir:py:functiondirectives for PEP 695 (generic classes and functions declarations) and PEP 696 (default type parameters). Multi-line support (#11011) is enabled for type parameters list and can be locally controlled on object description directives, e.g., :rst:dir:py:function:single-line-type-parameter-list. Patch by Bénédikt Tran. - #11484: linkcheck: Allow HTML anchors to be ignored on a per-URL basis
via :confval:
linkcheck_anchors_ignore_for_urlwhile still checking the validity of the page itself. Patch by Bénédikt Tran - #1246: Add translation progress statistics and inspection support,
via a new substitution (
|translation progress|) and a new configuration variable (:confval:translation_progress_classes). These enable determining the percentage of translated elements within a document, and the remaining translated and untranslated elements.
Bugs fixed
-
Restored the
footnote-referenceclass that has been removed in the latest (unreleased) version of Docutils. -
#11486: Use :rfc:
8081font file MIME types in the EPUB builder. Using the correct MIME type will prevent warnings fromepubcheckand will generate a valid EPUB. -
#11435: Use microsecond-resolution timestamps for outdated file detection in
BuildEnvironment.get_outdated_files. -
#11437: Top-level headings starting with a reStructuredText role now render properly when :confval:
rst_prologis set. Previously, a file starting with the below would have improperly rendered due to where the prologue text was inserted into the document... code:: rst
:mod:
lobster-- The lobster module...
Patch by Bénédikt Tran.
-
#11337: Fix a
MemoryErrorinsphinx.ext.intersphinxwhen usingNoneortyping.*as inline type references. Patch by Bénédikt Tran (picnixz)
Testing
- #11345: Always delete
docutils.confin test directories when runningSphinxTestApp.cleanup().
v7.0.1
=====================================
Dependencies
- #11411: Support
Docutils 0.20_. Patch by Adam Turner.
.. _Docutils 0.20: https://docutils.sourceforge.io/RELEASE-NOTES.html#release-0-20-2023-05-04
Bugs fixed
- #11418: Clean up remaining references to
sphinx.setup_commandfollowing the removal of support for setuptools. Patch by Willem Mulder.
v7.0.0
=====================================
Incompatible changes
- #11359: Remove long-deprecated aliases for
MecabSplitterandDefaultSplitterinsphinx.search.ja. - #11360: Remove deprecated
make_old_idfunctions in domain object description classes. - #11363: Remove the Setuptools integration (
build_sphinxhook insetup.py). - #11364: Remove deprecated
sphinx.ext.napoleon.iteratorsmodule. - #11365: Remove support for the
jsdumpformat insphinx.search. - #11366: Make
localea required argument tosphinx.util.i18n.format_date(). - #11370: Remove deprecated
sphinx.util.stemmermodule. - #11371: Remove deprecated
sphinx.pycode.ast.parse()function. - #11372: Remove deprecated
sphinx.io.read_doc()function. - #11373: Removed deprecated
sphinx.util.get_matching_files()function. - #11378: Remove deprecated
sphinx.util.docutils.is_html5_writer_available()function. - #11379: Make the
envargument toBuildersubclasses required. - #11380: autosummary: Always emit grouped import exceptions.
- #11381: Remove deprecated
stylekey for HTML templates. - #11382: Remove deprecated
sphinx.writers.latex.LaTeXTranslator.docclassesattribute. - #11383: Remove deprecated
sphinx.builders.html.html5_readyandsphinx.builders.html.HTMLTranslatorattributes. - #11385: Remove support for HTML 4 output.
Configuration
📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this PR and you won't be reminded about this update again.
- [ ] If you want to rebase/retry this PR, check this box
This PR has been generated by Mend Renovate. View repository job log here.
CI is failing as sphinx>7.1.2 is incompatible with python 3.8, which is our minimum supported version.
Keep the PR on hold until we decide to drop 3.8 support, or a compatible sphinx version gets released.