-
-
Notifications
You must be signed in to change notification settings - Fork 163
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support type annotations in Returns
and Yields
sections
#356
Comments
This is already an option in Sphinx itself, but IIRC not very usable yet. I agree this would be nice to have. Can you please look into how Sphinx does this, and if anything is needed from Numpydoc to integrate with that? |
From experimenting with the sphinx/napoleon feature you mentioned, I believe that it is sort of broken, since it does not really adhere to the specification and behaves differently for one and multiple return values. I can follow up with specifics once I find the time to set up a reproducible example if you want. I think it would be a good start to define something like my proposal above in the specification of the This will make a consistent and compatible implementation in tools like sphinx and pylint easier. |
So it should work with If that could be made to work with
then I think we're good, and I'm +1 on accepting that feature. That's the main target I'd think. I'm less sure about the single return format you propose; certainly seems lower prio. |
@rgommers I opened an issue in the Sphinx repo. I'd be happy if you could chime in in case you have any objections to my description there. |
I believe we've reached a deadlock situation, since the sphinx maintainers don't want to add this feature, unless it is added to the numpydoc specification. See sphinx-doc/sphinx#10134 (comment) |
Okay, then let's approve this as part of the Numpydoc spec I'd say (the part in #356 (comment)). Any objections @numpy/numpydoc-devs? |
Just to make sure, since #356 (comment) only mentions the Personally, I'm strongly in favor of adding it to both sections. |
Adding the following pattern to the standard:
seems fine to me. As noted, it's backward-compatible from the perspective of docstring parsing as this will parse fine w/ numpydoc 1.2: >>> def foo():
... """foo's description
...
... Returns
... -------
... my_float :
... a value of 1.0
... """
... my_float = 1.0
... return my_float
>>> from numpydoc.docscrape import NumpyDocString
>>> foo_nds = NumpyDocString(foo.__doc__)
>>> foo_nds["Returns"]
[Parameter(name='my_float', type='', desc=['a value of 1.0'])] It's just not explicitly mentioned in the standard. It will require a change to the validation, as IMO I don't much see the utility of having the Returns section list the name of the object instead of the type, since the name for returned object isn't relevant outside the function scope. I'd propose a different solution to the problem of duplicated type info in the signature and docstring (namely extracting typing info directly from the docstring), but that's a separate discussion. Since it's already technically supported, seems to be desired in multiple places, and shouldn't break anyone I have no strong objections. |
To me there are a couple of reasons. First, it's often useful as a quick shorthand, because you can more quickly get the variable's purpose, e.g. I often can get it immediately from a quick glance at the name if I'm familiar with the function and just can't remember the order for example:
This to me is faster than where I have to read some or most of a sentence:
Second, it helps with code uniformity (at least in some places and projects), as it gives users (and devs for internal use!) some hint about what good names would be to standardize around for the returned variables where it's reasonable to do so. |
What's the status of this? |
Seemed initially blocked by - numpy/numpydoc#356 - sphinx-doc/sphinx#7077 - numpy/numpydoc#251 (comment) However, fixed by finding this comment sphinx-doc/sphinx#7077 (comment) which pointed to tox-dev/sphinx-autodoc-typehints#311
Currently, when using
numpydoc
-style docstrings alongside Python type annotation, the types of returns or yields must be specified twice, which is tedious and also error prone. I would like to propose a backward-compatible addition to the docstring specification, which allows returns/yields to be specified without return types:Note the addition of the colons to distinguish return names and return types in a backward-compatible way.
Additionally, for a single return value with a Python return type annotation, it would be great if the following would be possible:
or
The same suggestions should also work for the
Yields
sectionThe text was updated successfully, but these errors were encountered: