<div dir="ltr"><br><br><div class="gmail_quote"><div dir="ltr">пн, 20 авг. 2018 г. в 17:23, Steven D'Aprano <<a href="mailto:steve@pearwood.info">steve@pearwood.info</a>>:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">On Sun, Aug 19, 2018 at 06:18:56PM +0300, Kirill Balunov wrote:<br>
[...]<br>[Kirill]<br>
> Let me disagree with you. While CPython is only one of the implementations<br>
> of the Python language, it is the most common one and defacto is considered<br>
> as a standard.<br>
<br>
Not in this case. If CPython intended this to be the language behaviour, <br>
it should specify that limitation instead of merely giving a doc warning <br>
that changes "may not" affect the local variables.<br>
<br>
In fact, the warning in the docs is too strong. Modifying locals() <br>
inside a class or module scope is allowed, and works fine. It is only <br>
functions which is problematic.<br>
<br></blockquote><div><br></div><div>I think I was pretty clear, that I only spoke about `locals` behavior inside functions and all its derivatives. At least I tried :) Talking about class and module, as for me, modifying `locals()` </div>inside a class or module scope is allowed but is far from the right way to do. </div><div class="gmail_quote"><br></div><div class="gmail_quote">The phrase `may not affect` is the worst phrase for deterministic system. Your program may work or may not work correctly depending on the underlying Python implementation, but you would not know about this because there will be no error and no warning. Good luck fixing such bugs.<br><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">
<br>
> Therefore, all the others, to be compliant, try to replicate<br>
> all subtleties and features of the basic implementation - CPython.<br>
<br>
Implementations are expected to obey the documented behaviour (unless <br>
given special dispensation to break the rules, which I think has <br>
happened once or twice with MicroPython). For behaviour which isn't <br>
dpcumented, it is true that implementations *often* try to copy CPython, <br>
but that's not mandatory and there are exceptions.<br>
<br></blockquote><div><br></div><div>I think you are talking about recent discussion of MicroPython's `dict` implementation (that the order is not guaranteed?) It is a necessary trade off for them given their niche (if I understand <span style="color:rgb(36,41,46);font-family:arial,helvetica,sans-serif">correctly the explanation given by </span><span style="color:rgb(36,41,46)"><font face="arial, helvetica, sans-serif">Paul Sokolovsky</font></span>). </div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex">[...]<br>
<br>
Users of CPython frequently rely on CPython implementation details. Why <br>
do you think Jython and IronPython users will be different?<br><br></blockquote><div><br></div><div>Hmm, what do you mean? It seems to me that everything happens the other way round. For example, recent attempts of numpy to make numpy more PyPy friendly. In fact, I do not know anyone who specifically rely on CPython implementation details in their production code.</div><div><br></div><div>with kind regards,</div><div>-gdg</div><div><br></div></div></div>