Type hints (PEP 484) support for the Sphinx autodoc extension
Project description
sphinx-autodoc-napoleon-typehints
This extension allows you to use Python 3 annotations for documenting acceptable argument types and return value types of functions. 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 '{} {}'.format(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 '{} {}'.format(value, unit)
There is also support for google docstrings or numpy docstrings with help of the napoleon napoleon sphinx extention. This means that even docstrings like this:
def format_unit_google(self, value: Union[float, int], unit: str, test: Optional[Union[Iterable, str]]) -> str:
"""
Formats the given value as a human readable string using the given units.
Args:
value: a numeric value
unit: the unit for the value (kg, m, etc.)
test: bla bla blathe unit for the value (kg, m, etc.)
Returns:
This function returns something of
value: and does not overwrite this part.
"""
return '{} {}'.format(value, unit)
def format_unit_numpy(self, value: Union[float, int], unit: str, test: Optional[Union[Iterable, str]]) -> str:
"""
Formats the given value as a human readable string using the given units.
Parameters
----------
value: a numeric value
unit: the unit for the value (kg, m, etc.)
test: bla bla blathe unit for the value (kg, m, etc.)
Returns
-------
This function returns something of
value: and does not overwrite this part.
"""
return '{} {}'.format(value, unit)
the result for which is the same as above
Installation and setup
First, use pip to download and install the extension:
$ pip install sphinx-autodoc-napoleon-typehints
Then, add the extension to your conf.py:
extensions = [
'sphinx.ext.autodoc',
'sphinx_autodoc_napoleon_typehints'
]
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.
This extension does not currently have any configuration options.
Project links
The project was originally forked from here
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file sphinx-autodoc-napoleon-typehints-2.1.6.tar.gz
.
File metadata
- Download URL: sphinx-autodoc-napoleon-typehints-2.1.6.tar.gz
- Upload date:
- Size: 13.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 67e36dc22d03362ab95c41d33b3a86fd8a7561a73648df112cdb57f989e1dae9 |
|
MD5 | 12182b1c73e9538b003931a9f55a99c7 |
|
BLAKE2b-256 | 050b8ccc320b7fdfbb8e57cafefb5d7fb45db383f651dca2eb1fd74b8f3d6f1a |
File details
Details for the file sphinx_autodoc_napoleon_typehints-2.1.6-py2.py3-none-any.whl
.
File metadata
- Download URL: sphinx_autodoc_napoleon_typehints-2.1.6-py2.py3-none-any.whl
- Upload date:
- Size: 7.5 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ad2f6a89eff950b30b65097f41a9f7065df168998a5fab16bb94df2d6b45e087 |
|
MD5 | 9e2fbfe2fb45d15d131b568f80f79c3d |
|
BLAKE2b-256 | 7f0e2d453296810270564bbafb6603d4cca2598f02fa9fb49c3177ba7ea40da0 |