Skip to content

Commit

Permalink
Fix sphinx-doc#4182: autodoc: Support :confval:suppress_warnings
Browse files Browse the repository at this point in the history
  • Loading branch information
tk0miya committed Aug 26, 2018
1 parent 6e8113d commit 8c4de32
Show file tree
Hide file tree
Showing 3 changed files with 39 additions and 12 deletions.
2 changes: 2 additions & 0 deletions CHANGES
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,8 @@ Deprecated
Features added
--------------

* #4182: autodoc: Support :confval:`suppress_warnings`

Bugs fixed
----------

Expand Down
17 changes: 17 additions & 0 deletions doc/usage/extensions/autodoc.rst
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,10 @@ docstrings to correct reStructuredText before :mod:`autodoc` processes them.
.. _NumPy:
https://github.com/numpy/numpy/blob/master/doc/HOWTO_DOCUMENT.rst.txt


Directives
----------

:mod:`autodoc` provides several directives that are versions of the usual
:rst:dir:`py:module`, :rst:dir:`py:class` and so forth. On parsing time, they
import the corresponding module and extract the docstring of the given objects,
Expand Down Expand Up @@ -306,6 +310,9 @@ inserting them into the page source under a suitable :rst:dir:`py:module`,
well-behaved decorating functions.


Configuration
-------------

There are also new config values that you can set:

.. confval:: autoclass_content
Expand Down Expand Up @@ -432,6 +439,16 @@ There are also new config values that you can set:

.. versionadded:: 1.7

.. confval:: suppress_warnings
:noindex:

:mod:`autodoc` supports to suppress warning messages via
:confval:`suppress_warnings`. It allows following warnings types in
addition:

* autodoc
* autodoc.import_object


Docstring preprocessing
-----------------------
Expand Down
32 changes: 20 additions & 12 deletions sphinx/ext/autodoc/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -342,7 +342,8 @@ def parse_name(self):
explicit_modname, path, base, args, retann = \
py_ext_sig_re.match(self.name).groups() # type: ignore
except AttributeError:
logger.warning(__('invalid signature for auto%s (%r)') % (self.objtype, self.name))
logger.warning(__('invalid signature for auto%s (%r)') % (self.objtype, self.name),
type='autodoc')
return False

# support explicit module and class name separation via ::
Expand Down Expand Up @@ -379,7 +380,7 @@ def import_object(self):
self.module, self.parent, self.object_name, self.object = ret
return True
except ImportError as exc:
logger.warning(exc.args[0])
logger.warning(exc.args[0], type='autodoc', subtype='import_object')
self.env.note_reread()
return False

Expand Down Expand Up @@ -442,7 +443,7 @@ def format_signature(self):
args = self.format_args()
except Exception as err:
logger.warning(__('error while formatting arguments for %s: %s') %
(self.fullname, err))
(self.fullname, err), type='autodoc')
args = None

retann = self.retann
Expand Down Expand Up @@ -564,7 +565,7 @@ def get_object_members(self, want_all):
selected.append((name, members[name].value))
else:
logger.warning(__('missing attribute %s in object %s') %
(name, self.fullname))
(name, self.fullname), type='autodoc')
return False, sorted(selected)
elif self.options.inherited_members:
return False, sorted((m.name, m.value) for m in itervalues(members))
Expand Down Expand Up @@ -653,7 +654,7 @@ def filter_members(self, members, want_all):
except Exception as exc:
logger.warning(__('autodoc: failed to determine %r to be documented.'
'the following exception was raised:\n%s'),
member, exc)
member, exc, type='autodoc')
keep = False

if keep:
Expand Down Expand Up @@ -746,7 +747,7 @@ def generate(self, more_content=None, real_modname=None,
__('don\'t know which module to import for autodocumenting '
'%r (try placing a "module" or "currentmodule" directive '
'in the document, or giving an explicit module name)') %
self.name)
self.name, type='autodoc')
return

# now, import the module and get object to document
Expand Down Expand Up @@ -832,15 +833,17 @@ def can_document_member(cls, member, membername, isattr, parent):
def resolve_name(self, modname, parents, path, base):
# type: (str, Any, str, Any) -> Tuple[str, List[unicode]]
if modname is not None:
logger.warning(__('"::" in automodule name doesn\'t make sense'))
logger.warning(__('"::" in automodule name doesn\'t make sense'),
type='autodoc')
return (path or '') + base, []

def parse_name(self):
# type: () -> bool
ret = Documenter.parse_name(self)
if self.args or self.retann:
logger.warning(__('signature arguments or return annotation '
'given for automodule %s') % self.fullname)
'given for automodule %s') % self.fullname,
type='autodoc')
return ret

def add_directive_header(self, sig):
Expand Down Expand Up @@ -875,7 +878,9 @@ def get_object_members(self, want_all):
logger.warning(
__('__all__ should be a list of strings, not %r '
'(in module %s) -- ignoring __all__') %
(memberlist, self.fullname))
(memberlist, self.fullname),
type='autodoc'
)
# fall back to all members
return True, safe_getmembers(self.object)
else:
Expand All @@ -888,7 +893,9 @@ def get_object_members(self, want_all):
logger.warning(
__('missing attribute mentioned in :members: or __all__: '
'module %s, attribute %s') %
(safe_getattr(self.object, '__name__', '???'), mname))
(safe_getattr(self.object, '__name__', '???'), mname),
type='autodoc'
)
return False, ret


Expand Down Expand Up @@ -1539,15 +1546,16 @@ def merge_autodoc_default_flags(app, config):
return

logger.warning(__('autodoc_default_flags is now deprecated. '
'Please use autodoc_default_options instead.'))
'Please use autodoc_default_options instead.'),
type='autodoc')

for option in config.autodoc_default_flags:
if isinstance(option, string_types):
config.autodoc_default_options[option] = None
else:
logger.warning(
__("Ignoring invalid option in autodoc_default_flags: %r"),
option
option, type='autodoc'
)


Expand Down

0 comments on commit 8c4de32

Please sign in to comment.