Commit cd81f050 authored by Raymond Hettinger's avatar Raymond Hettinger Committed by GitHub

bpo-23674: Clarify ambiguities in super() docs (#15564)

parent 122376df
...@@ -1589,10 +1589,17 @@ are always available. They are listed here in alphabetical order. ...@@ -1589,10 +1589,17 @@ are always available. They are listed here in alphabetical order.
Return a proxy object that delegates method calls to a parent or sibling Return a proxy object that delegates method calls to a parent or sibling
class of *type*. This is useful for accessing inherited methods that have class of *type*. This is useful for accessing inherited methods that have
been overridden in a class. The search order is same as that used by been overridden in a class.
:func:`getattr` except that the *type* itself is skipped.
The :attr:`~class.__mro__` attribute of the *type* lists the method The *object-or-type* determines the :term:`method resolution order`
to be searched. The search starts from the class right after the
*type*.
For example, if :attr:`~class.__mro__` of *object-or-type* is
``D -> B -> C -> A -> object`` and the value of *type* is ``B``,
then :func:`super` searches ``C -> A -> object``.
The :attr:`~class.__mro__` attribute of the *object-or-type* lists the method
resolution search order used by both :func:`getattr` and :func:`super`. The resolution search order used by both :func:`getattr` and :func:`super`. The
attribute is dynamic and can change whenever the inheritance hierarchy is attribute is dynamic and can change whenever the inheritance hierarchy is
updated. updated.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment