-
Notifications
You must be signed in to change notification settings - Fork 187
[Bug] D417 not raised for missing parameter when docstring contains further sections #459
Comments
Yeah - the issue is related to how we treat conventions as a bundle of error codes, instead of a first class entity. If we indeed take advantage of the fact that the user is specifying the convention type - we can avoid such ambigious cases. @Nurdok what are your thoughts on this? Also currently any google style docstring that has a returns section yields no errors for other sections since its detected as a numpy section. |
@samj1912 if I understand correctly, any docstring containing a section that is present in both Google-style and Numpy-style, such as:
will be interpreted as Numpy-style instead of Google-style, is that correct? These are obviously very common sections for docstrings, so this effectively means that auto-detection of Google-style docstrings doesn't currently work. There are many possible fixes for this:
Do you have a particular preference for any of these? I think 1 is the quickest/easiest and most flexible since it would work most of the time, even if a single project mixes both Numpy and Google style in different methods. I'm also perfectly okay with 2 or 3 since my projects don't mix styles and I can easily specify which convention I use. I'm happy to submit a PR to try to implement any of these options, although I may need pointers on which files contain the style autodetection code. |
@adamjstewart The file @check_for(Definition)
def check_docstring_sections(self, definition, docstring):
"""Check for docstring sections."""
if not docstring:
return
lines = docstring.split("\n")
if len(lines) < 2:
return
found_numpy = yield from self._check_numpy_sections(
lines, definition, docstring
)
if not found_numpy:
yield from self._check_google_sections(
lines, definition, docstring
) The Google checks are skipped if anything is found in I think treating a docstring as a numpy docstring although I have explicitly configured pydocstyle to use the Google convention is a bug. Option 2 proposed by @adamjstewart sounds like the best way forward to me because it is less fragile then the first option and does not introduce the complexity of Option 3. My proposal:
The first three steps would be a refactoring and the fourth step would fix the actual bug. Let me know if that sounds reasonable and I would volunteer to implement this. |
Hi all, |
The following example does not raise a D417:
There is also no error raised when replacing
Raises
withReturns
, i.e. D417 is broken for both.Without the
Raises
section, everything works correctly, i.e.:prints
D417: Missing argument descriptions in the docstring (argument(s) b are missing descriptions in 'foo' docstring)
.The text was updated successfully, but these errors were encountered: