Commit 561bc884 authored by R David Murray's avatar R David Murray

#19953: Clarify the wording of the augmented assignment discussion.

Patch by Priya Pappachan, based on suggestions from Terry Reedy
and myself.
parent 69b1197f
...@@ -1103,6 +1103,7 @@ Use a list comprehension:: ...@@ -1103,6 +1103,7 @@ Use a list comprehension::
result = [obj.method() for obj in mylist] result = [obj.method() for obj in mylist]
.. _faq-augmented-assignment-tuple-error:
Why does a_tuple[i] += ['item'] raise an exception when the addition works? Why does a_tuple[i] += ['item'] raise an exception when the addition works?
--------------------------------------------------------------------------- ---------------------------------------------------------------------------
......
...@@ -2023,11 +2023,13 @@ left undefined. ...@@ -2023,11 +2023,13 @@ left undefined.
``&=``, ``^=``, ``|=``). These methods should attempt to do the operation ``&=``, ``^=``, ``|=``). These methods should attempt to do the operation
in-place (modifying *self*) and return the result (which could be, but does in-place (modifying *self*) and return the result (which could be, but does
not have to be, *self*). If a specific method is not defined, the augmented not have to be, *self*). If a specific method is not defined, the augmented
assignment falls back to the normal methods. For instance, to execute the assignment falls back to the normal methods. For instance, if *x* is an
statement ``x += y``, where *x* is an instance of a class that has an instance of a class with an :meth:`__iadd__` method, ``x += y`` is equivalent
:meth:`__iadd__` method, ``x.__iadd__(y)`` is called. If *x* is an instance to ``x = x.__iadd__(y)`` . Otherwise, ``x.__add__(y)`` and ``y.__radd__(x)``
of a class that does not define a :meth:`__iadd__` method, ``x.__add__(y)`` are considered, as with the evaluation of ``x + y``. In certain situations,
and ``y.__radd__(x)`` are considered, as with the evaluation of ``x + y``. augmented assignment can result in unexpected errors (see
:ref:`faq-augmented-assignment-tuple-error`), but this behavior is in
fact part of the data model.
.. method:: object.__neg__(self) .. method:: object.__neg__(self)
......
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