From 7d964cb2713a0ef7d51ae10ec4365717895ac759 Mon Sep 17 00:00:00 2001 From: "mergify[bot]" <37929162+mergify[bot]@users.noreply.github.com> Date: Fri, 21 Jul 2023 21:21:49 +0000 Subject: [PATCH] Methods are documented on class pages (#10455) (#10473) (cherry picked from commit e55389f3f05e2d871fdea3814917c93b5c280e93) Co-authored-by: Eric Arellano <14852634+Eric-Arellano@users.noreply.github.com> --- docs/_templates/autosummary/class.rst | 44 +++++++------------ .../class_no_inherited_members.rst | 44 +++++++------------ qiskit/algorithms/optimizers/nft.py | 5 ++- qiskit/providers/backend.py | 1 + 4 files changed, 38 insertions(+), 56 deletions(-) diff --git a/docs/_templates/autosummary/class.rst b/docs/_templates/autosummary/class.rst index 5b3ebf3bdf03..daff18c1e280 100644 --- a/docs/_templates/autosummary/class.rst +++ b/docs/_templates/autosummary/class.rst @@ -1,6 +1,5 @@ {# - The general principle of this is that we manually document attributes here in - the same file, but give all methods their own page. By default, we document + We show all the class's methods and attributes on the same page. By default, we document all methods, including those defined by parent classes. -#} @@ -9,33 +8,24 @@ .. currentmodule:: {{ module }} .. autoclass:: {{ objname }} -{#- - Avoid having autodoc populate the class with the members we're about to - summarize to avoid duplication. -#} :no-members: :show-inheritance: -{# - Methods all get their own separate page, with their names and the first lines - of their docstrings tabulated. The documentation from `__init__` is - automatically included in the standard class documentation, so we don't want - to repeat it. --#} -{% block methods_summary %}{% set wanted_methods = (methods | reject('==', '__init__') | list) %}{% if wanted_methods %} - .. rubric:: Methods - .. autosummary:: - :nosignatures: - :toctree: ../stubs/ -{% for item in wanted_methods %} - ~{{ name }}.{{ item }} -{%- endfor %} -{% endif %}{% endblock %} - -{% block attributes_summary %}{% if attributes %} +{% block attributes_summary %} + {% if attributes %} .. rubric:: Attributes -{# Attributes should all be summarized directly on the same page. -#} -{% for item in attributes %} + {% for item in attributes %} .. autoattribute:: {{ item }} -{%- endfor %} -{% endif %}{% endblock -%} + {%- endfor %} + {% endif %} +{% endblock -%} + +{% block methods_summary %} + {% set wanted_methods = (methods | reject('==', '__init__') | list) %} + {% if wanted_methods %} + .. rubric:: Methods + {% for item in wanted_methods %} + .. automethod:: {{ item }} + {%- endfor %} + {% endif %} +{% endblock %} diff --git a/docs/_templates/autosummary/class_no_inherited_members.rst b/docs/_templates/autosummary/class_no_inherited_members.rst index 6cde3cf5328d..269a89b70718 100644 --- a/docs/_templates/autosummary/class_no_inherited_members.rst +++ b/docs/_templates/autosummary/class_no_inherited_members.rst @@ -1,38 +1,28 @@ -{# - This is very similar to the default class template, except this one is used - when we don't want to generate any inherited methods. --#} +{# This is identical to class.rst, except for the filtering in `set wanted_methods`. -#} {{ objname | escape | underline }} .. currentmodule:: {{ module }} .. autoclass:: {{ objname }} -{#- - Avoid having autodoc populate the class with the members we're about to - summarize to avoid duplication. -#} :no-members: :show-inheritance: -{# - Methods all get their own separate page, with their names and the first lines - of their docstrings tabulated. --#} -{% block methods_summary %}{% set wanted_methods = (methods | reject('in', inherited_members) | reject('==', '__init__') | list) %}{% if wanted_methods %} - .. rubric:: Methods Defined Here - .. autosummary:: - :nosignatures: - :toctree: ../stubs/ -{% for item in wanted_methods %} - ~{{ name }}.{{ item }} -{%- endfor %} -{% endif %}{% endblock %} - -{% block attributes_summary %}{% if attributes %} +{% block attributes_summary %} + {% if attributes %} .. rubric:: Attributes -{# Attributes should all be summarized directly on the same page. -#} -{% for item in attributes %} + {% for item in attributes %} .. autoattribute:: {{ item }} -{%- endfor %} -{% endif %}{% endblock -%} + {%- endfor %} + {% endif %} +{% endblock -%} + +{% block methods_summary %} + {% set wanted_methods = (methods | reject('in', inherited_members) | reject('==', '__init__') | list) %} + {% if wanted_methods %} + .. rubric:: Methods + {% for item in wanted_methods %} + .. automethod:: {{ item }} + {%- endfor %} + {% endif %} +{% endblock %} diff --git a/qiskit/algorithms/optimizers/nft.py b/qiskit/algorithms/optimizers/nft.py index 07827007e79e..2a7503137daf 100644 --- a/qiskit/algorithms/optimizers/nft.py +++ b/qiskit/algorithms/optimizers/nft.py @@ -106,9 +106,10 @@ def nakanishi_fujii_todo( `OptimizeResult` for a description of other attributes. Notes: In this optimization method, the optimization function have to satisfy - three conditions written in [1]. + three conditions written in [2]_. + References: - .. [1] K. M. Nakanishi, K. Fujii, and S. Todo. 2019. + .. [2] K. M. Nakanishi, K. Fujii, and S. Todo. 2019. Sequential minimal optimization for quantum-classical hybrid algorithms. arXiv preprint arXiv:1903.12166. """ diff --git a/qiskit/providers/backend.py b/qiskit/providers/backend.py index d61810f765fd..d570bfd4db60 100644 --- a/qiskit/providers/backend.py +++ b/qiskit/providers/backend.py @@ -88,6 +88,7 @@ def __init__(self, configuration, provider=None, **fields): private methods: .. automethod:: _default_options + :noindex: """ self._configuration = configuration self._options = self._default_options()