Skip to main content

Type hints (PEP 484) support for the Sphinx autodoc extension

Project description

sphinx-autodoc-typehints

PyPI Supported Python versions Downloads check

This extension allows you to use Python 3 annotations for documenting acceptable argument types and return value types of functions. See an example of the Sphinx render at the pyproject-api docs.

This allows you to use type hints in a very natural fashion, allowing you to migrate from this:

def format_unit(value, unit):
    """
    Formats the given value as a human readable string using the given units.

    :param float|int value: a numeric value
    :param str unit: the unit for the value (kg, m, etc.)
    :rtype: str
    """
    return f"{value} {unit}"

to this:

from typing import Union


def format_unit(value: Union[float, int], unit: str) -> str:
    """
    Formats the given value as a human readable string using the given units.

    :param value: a numeric value
    :param unit: the unit for the value (kg, m, etc.)
    """
    return f"{value} {unit}"

Installation and setup

First, use pip to download and install the extension:

pip install sphinx-autodoc-typehints

Then, add the extension to your conf.py:

extensions = ["sphinx.ext.autodoc", "sphinx_autodoc_typehints"]

Options

The following configuration options are accepted:

  • typehints_fully_qualified (default: False): if True, class names are always fully qualified (e.g. module.for.Class). If False, just the class name displays (e.g. Class)

  • always_document_param_types (default: False): If False, do not add type info for undocumented parameters. If True, add stub documentation for undocumented parameters to be able to add type info.

  • always_use_bars_union (default: False): If True, display Union's using the | operator described in PEP 604. (e.g X | Y or int | None). If False, Unions will display with the typing in brackets. (e.g. Union[X, Y] or Optional[int]). Note that on 3.14 and later this will always be True and not configurable due the interpreter no longer differentiating between the two types, and we have no way to determine what the user used.

  • typehints_document_rtype (default: True): If False, never add an :rtype: directive. If True, add the :rtype: directive if no existing :rtype: is found.

  • typehints_document_rtype_none (default: True): If False, never add an :rtype: None directive. If True, add the :rtype: None.

  • typehints_use_rtype (default: True): Controls behavior when typehints_document_rtype is set to True. If True, document return type in the :rtype: directive. If False, document return type as part of the :return: directive, if present, otherwise fall back to using :rtype:. Use in conjunction with napoleon_use_rtype to avoid generation of duplicate or redundant return type information.

  • typehints_defaults (default: None): If None, defaults are not added. Otherwise, adds a default annotation:

    • 'comma' adds it after the type, changing Sphinx’ default look to “param (int, default: 1) -- text”.
    • 'braces' adds (default: ...) after the type (useful for numpydoc like styles).
    • 'braces-after' adds (default: ...) at the end of the parameter documentation text instead.
  • simplify_optional_unions (default: True): If True, optional parameters of type "Union[...]" are simplified as being of type Union[..., None] in the resulting documentation (e.g. Optional[Union[A, B]] -> Union[A, B, None]). If False, the "Optional"-type is kept. Note: If False, any Union containing None will be displayed as Optional! Note: If an optional parameter has only a single type (e.g Optional[A] or Union[A, None]), it will always be displayed as Optional!

  • typehints_formatter (default: None): If set to a function, this function will be called with annotation as first argument and sphinx.config.Config argument second. The function is expected to return a string with reStructuredText code or None to fall back to the default formatter.

  • typehints_use_signature (default: False): If True, typehints for parameters in the signature are shown.

  • typehints_use_signature_return (default: False): If True, return annotations in the signature are shown.

  • suppress_warnings: sphinx-autodoc-typehints supports to suppress warning messages via Sphinx's suppress_warnings. It allows following additional warning types:

    • sphinx_autodoc_typehints
    • sphinx_autodoc_typehints.comment
    • sphinx_autodoc_typehints.forward_reference
    • sphinx_autodoc_typehints.guarded_import
    • sphinx_autodoc_typehints.local_function
    • sphinx_autodoc_typehints.multiple_ast_nodes

How it works

The extension listens to the autodoc-process-signature and autodoc-process-docstring Sphinx events. In the former, it strips the annotations from the function signature. In the latter, it injects the appropriate :type argname: and :rtype: directives into the docstring.

Only arguments that have an existing :param: directive in the docstring get their respective :type: directives added. The :rtype: directive is added if and only if no existing :rtype: is found.

Compatibility with sphinx.ext.napoleon

To use sphinx.ext.napoleon with sphinx-autodoc-typehints, make sure you load sphinx.ext.napoleon first, before sphinx-autodoc-typehints. See Issue 15 on the issue tracker for more information.

Dealing with circular imports

Sometimes functions or classes from two different modules need to reference each other in their type annotations. This creates a circular import problem. The solution to this is the following:

  1. Import only the module, not the classes/functions from it
  2. Use forward references in the type annotations (e.g. def methodname(self, param1: 'othermodule.OtherClass'):)

On Python 3.7, you can even use from __future__ import annotations and remove the quotes.

Project details


Release history Release notifications | RSS feed

This version

3.5.0

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sphinx_autodoc_typehints-3.5.0.tar.gz (37.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sphinx_autodoc_typehints-3.5.0-py3-none-any.whl (21.1 kB view details)

Uploaded Python 3

File details

Details for the file sphinx_autodoc_typehints-3.5.0.tar.gz.

File metadata

  • Download URL: sphinx_autodoc_typehints-3.5.0.tar.gz
  • Upload date:
  • Size: 37.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for sphinx_autodoc_typehints-3.5.0.tar.gz
Algorithm Hash digest
SHA256 435b4cafdf8f7329fb86be1fa93f8f7a59773f2f235ae8cd253a1b172a9c498f
MD5 4c5af126a8db5300a04bc8932e5aa123
BLAKE2b-256 e7a4865e4eebbc771199a706282aadeac24aebe5859275997cfe6a34a5b33c5d

See more details on using hashes here.

Provenance

The following attestation bundles were made for sphinx_autodoc_typehints-3.5.0.tar.gz:

Publisher: release.yaml on tox-dev/sphinx-autodoc-typehints

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file sphinx_autodoc_typehints-3.5.0-py3-none-any.whl.

File metadata

File hashes

Hashes for sphinx_autodoc_typehints-3.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 599efe1f02b20d32c07790df85211015fb51a6e10f2012a2e1a3803c1966856e
MD5 c77a85d583986378fcbbd5b4a66e5309
BLAKE2b-256 2cea5f31a00a53e9d594b9254c7bc4ed7e550f22ce9bf1e89337f821bdf403a0

See more details on using hashes here.

Provenance

The following attestation bundles were made for sphinx_autodoc_typehints-3.5.0-py3-none-any.whl:

Publisher: release.yaml on tox-dev/sphinx-autodoc-typehints

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page