Skip to content

Commit

Permalink
Add option to set :noindex: (#150)
Browse files Browse the repository at this point in the history
* Add option to set :noindex:

Fix #130

* Remove py2 compat code

* Add test

* Fix package discovery

* Cleanup

* Include test files

* Typos

* Comment out language = None

Co-authored-by: P. L. Lim <[email protected]>
  • Loading branch information
saimn and pllim authored Dec 9, 2022
1 parent c4aa837 commit 6e476f2
Show file tree
Hide file tree
Showing 14 changed files with 118 additions and 11 deletions.
2 changes: 1 addition & 1 deletion setup.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,7 @@ test =

[options.package_data]
sphinx_automodapi = templates/*/*.rst
sphinx_automodapi.tests = cases/*/*.*, cases/*/*/*.*, cases/*/*/*/*.*, cases/*/*/*/*/*.*
sphinx_automodapi.tests = cases/*/*.*, cases/*/*/*.*, cases/*/*/*/*.*, cases/*/*/*/*/*.*, duplicated_warning/docs/*

[tool:pytest]
minversion = 4.6
Expand Down
9 changes: 9 additions & 0 deletions sphinx_automodapi/automodapi.py
Original file line number Diff line number Diff line change
Expand Up @@ -63,6 +63,10 @@
documentation. The option ``:inherited-members:`` or ``:no-inherited-members:``
allows the user to overrride the global setting.
* ``:noindex:``
Propagates the ``noindex`` flag to autodoc. Use it to avoid duplicate
objects warnings.
This extension also adds four sphinx configuration options:
Expand Down Expand Up @@ -239,6 +243,7 @@ def automodapi_replace(sourcestr, app, dotoctree=True, docname=None,
hds = '-^'
allowedpkgnms = []
allowothers = False
noindex = False

# look for actual options
unknownops = []
Expand Down Expand Up @@ -266,6 +271,8 @@ def automodapi_replace(sourcestr, app, dotoctree=True, docname=None,
inherited_members = False
elif opname == 'include-all-objects':
allowothers = True
elif opname == 'noindex':
noindex = True
else:
unknownops.append(opname)

Expand Down Expand Up @@ -321,6 +328,8 @@ def automodapi_replace(sourcestr, app, dotoctree=True, docname=None,
clsfuncoptions = []
if toctreestr:
clsfuncoptions.append(toctreestr)
if noindex:
clsfuncoptions.append(':noindex:')
if toskip:
clsfuncoptions.append(':skip: ' + ','.join(toskip))
if allowedpkgnms:
Expand Down
4 changes: 3 additions & 1 deletion sphinx_automodapi/automodsumm.py
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,7 @@ class Automodsumm(Autosummary):
option_spec['allowed-package-names'] = _str_list_converter
option_spec['inherited-members'] = flag
option_spec['no-inherited-members'] = flag
option_spec['noindex'] = flag

def run(self):
env = self.state.document.settings.env
Expand Down Expand Up @@ -457,7 +458,7 @@ def generate_automodsumm_docs(lines, srcfn, app=None, suffix='.rst',
new_files = []

# write
for name, path, template_name, inherited_mem in sorted(items):
for name, path, template_name, inherited_mem, noindex in sorted(items):

if path is None:
# The corresponding autosummary:: directive did not have
Expand Down Expand Up @@ -601,6 +602,7 @@ def get_members_class(obj, typ, include_public=[],
else:
mod_name, obj_name = '.'.join(parts[:-1]), parts[-1]

ns['noindex'] = noindex
ns['fullname'] = name
ns['module'] = mod_name
ns['objname'] = obj_name
Expand Down
3 changes: 3 additions & 0 deletions sphinx_automodapi/templates/autosummary_core/class.rst
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,9 @@

.. autoclass:: {{ objname }}
:show-inheritance:
{% if noindex -%}
:noindex:
{%- endif %}

{% if '__init__' in methods %}
{% set caught_result = methods.remove('__init__') %}
Expand Down
Empty file.
11 changes: 11 additions & 0 deletions sphinx_automodapi/tests/duplicated_warning/docs/conf.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,11 @@
project = 'duplicated'
copyright = '2022, Maximilian Linhoff'
author = 'Maximilian Linhoff'
release = '0.1'


extensions = [
"sphinx_automodapi.automodapi",
]

html_theme = 'alabaster'
9 changes: 9 additions & 0 deletions sphinx_automodapi/tests/duplicated_warning/docs/foo.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
Foo Submodule
=============


API Reference
-------------

.. automodapi:: sphinx_automodapi.tests.duplicated_warning.duplicated.foo
:noindex:
19 changes: 19 additions & 0 deletions sphinx_automodapi/tests/duplicated_warning/docs/index.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
.. duplicated documentation master file, created by
sphinx-quickstart on Tue Mar 29 17:11:23 2022.
You can adapt this file completely to your liking, but it should at least
contain the root `toctree` directive.
Welcome to duplicated's documentation!
======================================

.. toctree::
:maxdepth: 2
:caption: Contents:

foo


API Reference
-------------

.. automodapi:: sphinx_automodapi.tests.duplicated_warning.duplicated
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
from .foo import Foo


__all__ = [
'Foo',
]
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
from .foo import Foo

__all__ = [
"Foo",
]
17 changes: 17 additions & 0 deletions sphinx_automodapi/tests/duplicated_warning/duplicated/foo/foo.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
__all__ = [
'Foo',
'Bar',
'baz',
]


class Foo:
'''Awesome Foo class'''


class Bar:
'''Awesome Bar class'''


def baz():
'''Awesome baz function'''
8 changes: 1 addition & 7 deletions sphinx_automodapi/tests/example_module/abstract_classes.py
Original file line number Diff line number Diff line change
@@ -1,10 +1,4 @@
try:
# Python 3
from collections.abc import Sequence
except ImportError:
# Python 2 (this import also works in Python <= 3.7, but will be removed in
# Python 3.8)
from collections import Sequence
from collections.abc import Sequence

__all__ = ['SequenceSubclass']

Expand Down
25 changes: 25 additions & 0 deletions sphinx_automodapi/tests/test_cases.py
Original file line number Diff line number Diff line change
Expand Up @@ -115,3 +115,28 @@ def test_run_full_case(tmpdir, case_dir, parallel):
with open(path_reference, encoding='utf8') as f:
reference = f.read()
assert actual.strip() == reference.strip()


def test_duplicated_warning(tmpdir):
input_dir = os.path.join(os.path.dirname(__file__), 'duplicated_warning', 'docs')
docs_dir = tmpdir.mkdir('docs').strpath

start_dir = os.path.abspath('.')
src_dir = '.'

for root, dirnames, filenames in os.walk(input_dir):
for filename in filenames:
root_dir = os.path.join(docs_dir, os.path.relpath(root, input_dir))
ensuredir(root_dir)
input_file = os.path.join(root, filename)
shutil.copy(input_file, root_dir)

argv = ['-W', '-b', 'html', src_dir, '_build/html']

try:
os.chdir(docs_dir)
status = build_main(argv=argv)
finally:
os.chdir(start_dir)

assert status == 0
11 changes: 9 additions & 2 deletions sphinx_automodapi/utils.py
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ def find_mod_objs(modname, onlylocals=False):
def find_autosummary_in_lines_for_automodsumm(lines, module=None, filename=None):
"""Find out what items appear in autosummary:: directives in the
given lines.
Returns a list of (name, toctree, template, inherited_members)
Returns a list of (name, toctree, template, inherited_members, noindex)
where *name* is a name
of an object and *toctree* the :toctree: path of the corresponding
autosummary directive (relative to the root of the file name),
Expand All @@ -133,12 +133,14 @@ def find_autosummary_in_lines_for_automodsumm(lines, module=None, filename=None)
template_arg_re = re.compile(r'^\s+:template:\s*(.*?)\s*$')
inherited_members_arg_re = re.compile(r'^\s+:inherited-members:\s*$')
no_inherited_members_arg_re = re.compile(r'^\s+:no-inherited-members:\s*$')
noindex_arg_re = re.compile(r'^\s+:noindex:\s*$')

documented = []

toctree = None
template = None
inherited_members = None
noindex = None
current_module = module
in_autosummary = False
base_indent = ""
Expand Down Expand Up @@ -168,6 +170,11 @@ def find_autosummary_in_lines_for_automodsumm(lines, module=None, filename=None)
inherited_members = False
continue

m = noindex_arg_re.match(line)
if m:
noindex = True
continue

if line.strip().startswith(':'):
warn(line)
continue # skip options
Expand All @@ -181,7 +188,7 @@ def find_autosummary_in_lines_for_automodsumm(lines, module=None, filename=None)
not name.startswith(current_module + '.'):
name = "%s.%s" % (current_module, name)
documented.append((name, toctree, template,
inherited_members))
inherited_members, noindex))
continue

if not line.strip() or line.startswith(base_indent + " "):
Expand Down

0 comments on commit 6e476f2

Please sign in to comment.