<div dir="ltr"><div>Steven, in your example you would get `2 99`. Also, you can always tell what the name of the local is. I think the bytecode example that scott showed was a pretty clear implementation example.<br><br></div>Also, the idea of this is not that the variable has the name name as the key, but that you can pull the values out of a mapping and name them. This means that the idea of updating the locals with the dict is not really the same idea. That also forces you to use all or none of the keye instead of allowing you to take a subset.<br></div><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Aug 12, 2015 at 12:52 PM, Joseph Jevnik <span dir="ltr"><<a href="mailto:joejev@gmail.com" target="_blank">joejev@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">If you look carefully at the way the stack is setup, we are not iterating over the map, instead we are executing a sequence of PyObject_GetItem calls in the execution of the opcode and then pushing the results back onto the stack. The order of the results is based on the order of keys that were on the stack.<br></div><div class="HOEnZb"><div class="h5"><div class="gmail_extra"><br><div class="gmail_quote">On Wed, Aug 12, 2015 at 12:10 PM, Chris Angelico <span dir="ltr"><<a href="mailto:rosuav@gmail.com" target="_blank">rosuav@gmail.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span>On Wed, Aug 12, 2015 at 11:57 PM, Scott Sanderson<br>
<<a href="mailto:scott.b.sanderson90@gmail.com" target="_blank">scott.b.sanderson90@gmail.com</a>> wrote:<br>
> LOAD_NAME 'values' # Push rvalue onto the stack.<br>
> LOAD_CONST 'dict' # Push top-level keys onto the stack.<br>
> LOAD_CONST 'tuple'<br>
> LOAD_CONST 'name'<br>
> UNPACK_MAP 3 # Unpack keys. Pops values and all keys from the stack.<br>
> # TOS = values['name']<br>
> # TOS1 = values['tuple']<br>
> # TOS2 = values['dict']<br>
><br>
> STORE_FAST name # Terminal names are simply stored.<br>
><br>
> UNPACK_SEQUENCE 2 # Push the two entries in values['tuple'] onto the<br>
> stack.<br>
> # TOS = values['tuple'][0]<br>
> # TOS1 = values['tuple'][1]<br>
> # TOS2 = values['dict']<br>
> STORE_FAST x<br>
> STORE_FAST y<br>
<br>
</span>This sounds reasonable in theory; is it going to have problems with<br>
the non-orderedness of dictionaries? With sequence unpacking, it's<br>
straight-forward - you evaluate things in a known order, you iterate<br>
over the thing, you assign. In this case, you might end up with some<br>
bizarre stack manipulation needed to make this work. Inside that<br>
UNPACK_MAP opcode, arbitrary code could be executed (imagine if the<br>
RHS is not a dict per se, but an object with a __getitem__ method), so<br>
it'll need to be popping some things off and pushing others on, and<br>
presumably would need to know what goes where.<br>
<br>
Unless, of course, this doesn't "pop" and "push", but does some sort<br>
of replacement. Suppose you load the keys first, and only once those<br>
are loaded, you load the rvalue - so the rvalue is on the top of the<br>
stack. "UNPACK_MAP 3" means this:<br>
<br>
1) Pop the top item off the stack - it is the map we're working with.<br>
2) Reach 3 items down in the stack. Take that item, subscript our map<br>
with it, and replace that stack entry with the result.<br>
3) Reach 2 items down, subscript, replace. Repeat till we subscript<br>
with the top of the stack.<br>
<br>
I've no idea how plausible that is, but it'd kinda work. It would also<br>
mean you could evaluate the keys in the order that they're shown in<br>
the dict display *and* assign to them in that order, which the current<br>
proposal doesn't do (it assigns in order, but evaluates in reverse<br>
order).<br>
<br>
Stupid, unworkable idea?<br>
<br>
ChrisA<br>
<div><div>_______________________________________________<br>
Python-ideas mailing list<br>
<a href="mailto:Python-ideas@python.org" target="_blank">Python-ideas@python.org</a><br>
<a href="https://mail.python.org/mailman/listinfo/python-ideas" rel="noreferrer" target="_blank">https://mail.python.org/mailman/listinfo/python-ideas</a><br>
Code of Conduct: <a href="http://python.org/psf/codeofconduct/" rel="noreferrer" target="_blank">http://python.org/psf/codeofconduct/</a><br>
</div></div></blockquote></div><br></div>
</div></div></blockquote></div><br></div>