<div dir="ltr"><div><div>That's a lot to read between the lines. I was unhappy that Chris took the statement that immutability and hashability are equivalent, claimed that most people think of it that way, and did not point out that it was false, thereby making the impression that he wasn't aware of the difference.<br><br></div>The way I think of it generally is that immutability is a property of types, while hashability is a property of values.<br><br></div>I don't want the original debate (about what to do with hash=True for dataclasses) to be spread across multiple threads so I'll reply separately there.<br></div><div class="gmail_extra"><br><div class="gmail_quote">On Sun, Feb 4, 2018 at 5:54 PM, Nick Coghlan <span dir="ltr"><<a href="mailto:ncoghlan@gmail.com" target="_blank">ncoghlan@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 class="">On 5 February 2018 at 08:31, Guido van Rossum <<a href="mailto:guido@python.org">guido@python.org</a>> wrote:<br>
> On Sun, Feb 4, 2018 at 11:59 AM, Chris Barker - NOAA Federal<br>
> <<a href="mailto:chris.barker@noaa.gov">chris.barker@noaa.gov</a>> wrote:<br>
>><br>
>> I think the folks that are concerned about this issue are quite right<br>
>> — most Python users equate immutable and hashable—so the dataclass API<br>
>> should reflect that.<br>
><br>
> Since they are *not* equivalent (consider a tuple containing a list) I'm not<br>
> at all convinced that any API in the core language should "reflect" this<br>
> misconception, depending on how you meant that.<br>
<br>
</span>Lists are themselves mutable, and hence inherently unhashable.<br>
<br>
Tuples are themselves immutable, and hence hashable if their contents are.<br>
<br>
I interpret Chris's comment as saying that data classes should behave<br>
the same way that the builtin container types do:<br>
<br>
* if the data class itself is mutable (frozen=False, comparable to<br>
list, dict, set), then it is *not* hashable (unless you explicitly<br>
implement __hash__)<br>
<br>
* if the data class itself is immutable (frozen=True, comparable to<br>
tuple or frozenset), then whether or not it is hashable depends on<br>
whether or not the field values are hashable.<br>
<br>
It's the ability to ask the interpreter to guess what you mean<br>
"frozen=False, hash=True" that creates the likelihood of confusion.<br>
<br>
Whereas if we leave out the "hash=True" option entirely, then the most<br>
natural way to obtain a partially-mutable record, which has a fixed<br>
comparison key and selectively mutable state, then the recommended way<br>
of handling that would be through containment, where the mutable state<br>
is moved out to a subrecord that gets excluded from hashes and<br>
comparisons.<br>
<br>
Cheers,<br>
Nick.<br>
<span class="HOEnZb"><font color="#888888"><br>
--<br>
Nick Coghlan | <a href="mailto:ncoghlan@gmail.com">ncoghlan@gmail.com</a> | Brisbane, Australia<br>
</font></span></blockquote></div><br><br clear="all"><br>-- <br><div class="gmail_signature" data-smartmail="gmail_signature">--Guido van Rossum (<a href="http://python.org/~guido" target="_blank">python.org/~guido</a>)</div>
</div>