• Stars
    star
    545
  • Rank 81,316 (Top 2 %)
  • Language
    Python
  • License
    MIT License
  • Created about 9 years ago
  • Updated about 2 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Type hints support for the Sphinx autodoc extension

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.

  • 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_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.

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.

More Repositories

1

tox

Command line driven CI frontend and development task automation tool.
Python
3,615
star
2

pipdeptree

A command line utility to display dependency tree of the installed Python packages
Python
2,787
star
3

filelock

A platform-independent file lock for Python.
Python
757
star
4

tox-travis

Seamless integration of tox into Travis CI
Python
202
star
5

tox-docker

A tox plugin to run one or more Docker containers during tests
Python
175
star
6

pyproject-fmt

Python
166
star
7

tox-conda

Make tox cooperate with conda envs
Python
152
star
8

tox-pyenv

plugin that tells tox to use `pyenv which` to find python executables
Python
127
star
9

tox-pipenv

A pipenv plugin for Tox
Python
124
star
10

tox-uv

Use https://github.com/astral-sh/uv with tox
Python
55
star
11

detox

distributed tox (tox plugin to run testenvs in parallel)
Python
48
star
12

tox-gh

Github Action support for tox 4 and later
Python
45
star
13

tox-ini-fmt

Formats your tox.ini files
Python
41
star
14

pre-commit-uv

Python
33
star
15

azure-pipelines-template

template for your azure pipelines
24
star
16

pyproject-api

API to interact with the python pyproject.toml based projects
Python
23
star
17

tox-venv

Use Python 3 venvs for Python 3 test environments
Python
21
star
18

sphinx-argparse-cli

Render CLI arguments (sub-commands friendly) defined by the argparse module.
Python
21
star
19

pyproject-fmt-rust

Rust
11
star
20

gh-action-tox

Run tox as a Github Action
Dockerfile
7
star
21

devpi-process

Python
7
star
22

tox-report

Records tox console output and produces a colored HTML report with it.
Python
6
star
23

tox-extra

Tox plugin which adds few extra checks like assuring that git does not report dirty
Python
6
star
24

cookiecutter-tox-plugin

Cookiecutter template for tox plugins
Python
5
star
25

tox-bindep

Deprecated as its functionality is now covered by tox-extra
Python
4
star
26

workflow

4
star
27

PyVenvManage

Kotlin
4
star
28

tox-external-wheels

A plugin for tox to allow external wheels for testing
Python
3
star
29

toml-fmt

1
star
30

py-discovery

Python
1
star