Skip to content

Commit

Permalink
Add typehints_use_rtype option (#218)
Browse files Browse the repository at this point in the history
Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
Co-authored-by: Bernát Gábor <bgabor8@bloomberg.net>
  • Loading branch information
3 people authored Feb 11, 2022
1 parent a022d1a commit aa345ca
Show file tree
Hide file tree
Showing 6 changed files with 124 additions and 2 deletions.
5 changes: 5 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -59,6 +59,11 @@ The following configuration options are accepted:
`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](https://www.sphinx-doc.org/en/master/usage/extensions/napoleon.html#confval-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”.
Expand Down
10 changes: 9 additions & 1 deletion src/sphinx_autodoc_typehints/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -556,13 +556,20 @@ def _inject_types_to_docstring(
insert_index = None
break
elif line.startswith(":return:") or line.startswith(":returns:"):
if " -- " in line and not app.config.typehints_use_rtype:
insert_index = None
break
insert_index = at

if insert_index is not None and app.config.typehints_document_rtype:
if insert_index == len(lines): # ensure that :rtype: doesn't get joined with a paragraph of text
lines.append("")
insert_index += 1
lines.insert(insert_index, f":rtype: {formatted_annotation}")
if app.config.typehints_use_rtype or insert_index == len(lines):
lines.insert(insert_index, f":rtype: {formatted_annotation}")
else:
line = lines[insert_index]
lines[insert_index] = f":return: {formatted_annotation} --{line[line.find(' '):]}"


def validate_config(app: Sphinx, env: BuildEnvironment, docnames: list[str]) -> None: # noqa: U100
Expand All @@ -579,6 +586,7 @@ def setup(app: Sphinx) -> dict[str, bool]:
app.add_config_value("always_document_param_types", False, "html")
app.add_config_value("typehints_fully_qualified", False, "env")
app.add_config_value("typehints_document_rtype", True, "env")
app.add_config_value("typehints_use_rtype", True, "env")
app.add_config_value("typehints_defaults", None, "env")
app.add_config_value("simplify_optional_unions", True, "env")
app.add_config_value("typehints_formatter", None, "env")
Expand Down
37 changes: 37 additions & 0 deletions tests/roots/test-dummy/dummy_module_simple_no_use_rtype.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
def function_no_returns(x: bool, y: int = 1) -> str: # noqa: U100
"""
Function docstring.
:param x: foo
:param y: bar
"""


def function_returns_with_type(x: bool, y: int = 1) -> str: # noqa: U100
"""
Function docstring.
:param x: foo
:param y: bar
:returns: *CustomType* -- A string
"""


def function_returns_with_compound_type(x: bool, y: int = 1) -> str: # noqa: U100
"""
Function docstring.
:param x: foo
:param y: bar
:returns: Union[str, int] -- A string or int
"""


def function_returns_without_type(x: bool, y: int = 1) -> str: # noqa: U100
"""
Function docstring.
:param x: foo
:param y: bar
:returns: A string
"""
7 changes: 7 additions & 0 deletions tests/roots/test-dummy/simple_no_use_rtype.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
Simple Module
=============

.. autofunction:: dummy_module_simple_no_use_rtype.function_no_returns
.. autofunction:: dummy_module_simple_no_use_rtype.function_returns_with_type
.. autofunction:: dummy_module_simple_no_use_rtype.function_returns_with_compound_type
.. autofunction:: dummy_module_simple_no_use_rtype.function_returns_without_type
65 changes: 65 additions & 0 deletions tests/test_sphinx_autodoc_typehints.py
Original file line number Diff line number Diff line change
Expand Up @@ -916,3 +916,68 @@ def test_no_source_code_type_guard() -> None:
from csv import Error

_resolve_type_guarded_imports(Error)


@pytest.mark.sphinx("text", testroot="dummy")
@patch("sphinx.writers.text.MAXWIDTH", 2000)
def test_sphinx_output_formatter_no_use_rtype(app: SphinxTestApp, status: StringIO) -> None:
set_python_path()
app.config.master_doc = "simple_no_use_rtype" # type: ignore # create flag
app.config.typehints_use_rtype = False # type: ignore
app.build()
assert "build succeeded" in status.getvalue()
text_path = pathlib.Path(app.srcdir) / "_build" / "text" / "simple_no_use_rtype.txt"
text_contents = text_path.read_text().replace("–", "--")
expected_contents = """\
Simple Module
*************
dummy_module_simple_no_use_rtype.function_no_returns(x, y=1)
Function docstring.
Parameters:
* **x** ("bool") -- foo
* **y** ("int") -- bar
Return type:
"str"
dummy_module_simple_no_use_rtype.function_returns_with_type(x, y=1)
Function docstring.
Parameters:
* **x** ("bool") -- foo
* **y** ("int") -- bar
Returns:
*CustomType* -- A string
dummy_module_simple_no_use_rtype.function_returns_with_compound_type(x, y=1)
Function docstring.
Parameters:
* **x** ("bool") -- foo
* **y** ("int") -- bar
Returns:
Union[str, int] -- A string or int
dummy_module_simple_no_use_rtype.function_returns_without_type(x, y=1)
Function docstring.
Parameters:
* **x** ("bool") -- foo
* **y** ("int") -- bar
Returns:
"str" -- A string
"""
assert text_contents == dedent(expected_contents)
2 changes: 1 addition & 1 deletion tox.ini
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ description = run type check on code base
setenv =
{tty:MYPY_FORCE_COLOR = 1}
deps =
mypy==0.930
mypy==0.931
types-docutils
commands =
mypy --python-version 3.10 src
Expand Down

0 comments on commit aa345ca

Please sign in to comment.