<div dir="ltr"><div><span style="line-height:1.5">class PrototypeNamedTuple:</span><br></div><div> cache = {}</div><div> def __new__(cls, *args):</div><div> P = <span style="line-height:1.5">PrototypeNamedTuple</span></div><div> if cls not in P.cache:</div><div> P.cache[cls] = typing.NamedTuple(cls.__name__, <span style="line-height:1.5">cls.__annotations__.items())</span></div><div> return P.cache[cls](*args)</div><div><br></div><div>Works modulo ordering, though I'm not sure that's the right way to do it.</div><div><br></div><div>The ordering part of namedtuple is orthogonal to the value-type/immutability part. So I would imagine making "Value" for the latter, "tuple" for the former, and namedtuple is mixing both (possibly given a convenient name, such as <span style="line-height:1.5">PrototypeNamedTuple). "Value" can also seen as mixing "Struct" and "Immutable", but that's overdoing it I guess.</span><span style="line-height:1.5"></span></div><div><br></div>~Elazar<div><br><div class="gmail_quote"><div dir="ltr">On Mon, Aug 8, 2016 at 11:25 PM Guido van Rossum <<a href="mailto:guido@python.org">guido@python.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div><div><div><div><div><div><div>That's a very interesting idea and one that deserves pursuing (though I agree it's not a blocker for the PEP I'm hoping to write). I think the next step is to prototype this -- which can only happen once we have an implementation of the PEP. Though perhaps you could start by writing a prototype that works by having the user write the following:<br><br></div>class Starship(PrototypeNamedTuple):<br></div> damage = 0<br></div> captain = "Kirk"<br></div> __annotations__ = dict(damage=int, captain=str)<br><br></div>It could also benefit from PEP 520 (Preserving Class Attribute Definition Order).<br><br></div>Who's game?<br><br></div>--Guido<br></div><div class="gmail_extra"><br><div class="gmail_quote"></div></div><div class="gmail_extra"><div class="gmail_quote">On Mon, Aug 8, 2016 at 1:13 PM, אלעזר <span dir="ltr"><<a href="mailto:elazarg@gmail.com" target="_blank">elazarg@gmail.com</a>></span> wrote:<br></div></div><div class="gmail_extra"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr"><div class="gmail_quote"><span><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">class Starship:<br>
stats: class Dict[str, int] = {} # Pure class variable<br>
damage: class int = 0 # Hybrid class/instance variable<br>
captain: str # Pure instance variable<br></blockquote><div><span style="line-height:1.5"><br></span></div></span><div><span style="line-height:1.5">I can't avoid noting that there is an opportunity here to insert NamedTuple into the core language. The above example is almost there, except it's mutable and without convenient methods. But</span><br></div><div><span style="line-height:1.5"><br></span></div><div>class Starship(tuple):<br> damage: int = 0 <br> captain: str = "Kirk"<span style="line-height:1.5"><br></span></div><div><br></div><div>Is an obvious syntax for </div><div><br></div><div> <span style="line-height:1.5">Starship = </span><span style="line-height:1.5">NamedTuple('</span><span style="line-height:1.5">Starship', [('damage', int), ('captain', str)])</span></div><div><span style="line-height:1.5"><br></span></div><div><span style="line-height:1.5">Only much more available and intuitive to read, use, and of course - type check.</span></div><div><span style="line-height:1.5">(Of course, it does mean adding semantics to the declaration syntax in general)</span></div><div><span style="line-height:1.5"><br></span></div><div><span style="line-height:1.5">I'm not really suggesting to make this change now, but I believe it will be done, sooner or later. My brief experience with mypy convinced me that it must be the case. The new declaration syntax only makes it easier.</span></div><div><span style="line-height:1.5"><br></span></div><div><span style="line-height:1.5">~Elazar</span></div></div></div>
<br></blockquote></div></div><div class="gmail_extra"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">_______________________________________________<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></blockquote></div></div><div class="gmail_extra"><br><br clear="all"><br>-- <br><div data-smartmail="gmail_signature">--Guido van Rossum (<a href="http://python.org/~guido" target="_blank">python.org/~guido</a>)</div>
</div></blockquote></div></div></div>