On 11/6/2012 1:18 AM, Chris Withers wrote:
Hi All,

I bumped into this using Michael Foord's Mock library.
It feels like a bug to me, but thought I'd ask here before logging one
in the tracker in case people know that we won't be able to fix it:

On 05/11/2012 13:43, Michael Foord wrote:

class Foo(object):
...  def __setattr__(s, k, v):
...   print k
...
f = Foo()

f.g = f.x = 3
g
x

Hmm, that's definitely counter-intuitive. Worth raising on python-dev?

Well, I guess "it's always been that way", so changing it would be
backwards incompatible. Feel free to raise it though. :-)

You are expecting a chained assignment a = b = c to be parsed as
a = (b = c), as in C and as it should be if assignment is an expression. But in Python it is not. The right association would be meaningless since (b = c) has no value to be assigned to a.

Python actually parses the chained assignment as (a =) (b =) c.
The relevant grammar production is "assignment_stmt ::=
(target_list "=")+ (expression_list | yield_expression)".
The explanation after the grammar begins with this sentence.

"An assignment statement evaluates the expression list (remember that this can be a single expression or a comma-separated list, the latter yielding a tuple) and assigns the single resulting object to each of the target lists, from left to right."

In other words, in my example, c is assigned to a then b. Please do not report documented behavior on the tracker as a bug (and don't encourage people to). If you think the above is not clear enough, you *can* suggest improvement. Perhaps add an example and explanation such as

a = b, (c,d), *e, f = 1, (2, 3), 4, 5, 6

"The tuple on the right is first assigned to a and then unpacked to b, c, d, e, and f, giving them the values 1, 2, 3, [4, 5], and 6."

--
Terry Jan Reedy

_______________________________________________
Python-Dev mailing list
Python-Dev@python.org
http://mail.python.org/mailman/listinfo/python-dev
Unsubscribe: 
http://mail.python.org/mailman/options/python-dev/archive%40mail-archive.com

Reply via email to