On 7/9/2018 6:00 PM, Guido van Rossum wrote:
This rule is included to simplify the choice for the user between an assignment statements and an assignment expression -- there is no
"statements" should not be plural in the above line.
syntactic position where both are valid.
An exception to this special case applies when the target name is the same as a loop control variable for a comprehension containing it. This is invalid. This exception exists to rule out edge cases of the above scope rules as illustrated by ``[i := i+1 for i in range(5)]`` or ``[[(j := j) for i in range(5)] for j in range(5)]``. Note that this exception also applies to ``[i := 0 for i, j in stuff]``, as well as to cases like ``[i+1 for i in i := stuff]``.
It is unclear whether exactly what is invalid. Is the use of the target name that is the same as (any of the nested) loop control variable invalid? I think, from discussions, that that is what is meant. But this paragraph could be interpreted as meaning the special case doesn't apply, meaning that the target name would be in a "sublocal" scope.
The ``:=`` operator groups more tightly than a comma in all syntactic positions where it is legal, but less tightly than all operators,
If comma is considered an operator, this sentence is inconsistent, would need to be "all other operators". Even if comma is not considered an operator, the sentence would be more clear with "other" added, since ":=" is an operator.
Sorry, I haven't learned pull requests. Glenn
_______________________________________________ Python-Dev mailing list Python-Dev@python.org https://mail.python.org/mailman/listinfo/python-dev Unsubscribe: https://mail.python.org/mailman/options/python-dev/archive%40mail-archive.com