[swift-users] is this a defect in equatable for swift tuples?

David Sweeris davesweeris at mac.com
Sun Jul 9 13:44:01 CDT 2017


> On Jul 9, 2017, at 10:06, David Baraff via swift-users <swift-users at swift.org> wrote:
> 
> 
>> On Jul 9, 2017, at 8:27 AM, Jens Persson <jens at bitcycle.com> wrote:
>> 
>> (Also, note that your implementation of == uses lhs === rhs thus will only return true when lhs and rhs are the same instance of SomeClass.)
> Of course — i threw that in just to make a simple example.
> 
> Followup question: what I really wanted to write was an == operator for a tree:
> 
> // silly tree, useful for nothing
> class Tree : Equatable {
>    let rootData:Int
>    let children:[(String, Tree)]
> 
>    static public func ==(_ lhs:Tree, _ rhs:Tree) {
> 	return lhs.rootData == rhs.rootData && 
>             lhs.children == rhs.children		// sadly, this doesn’t compile
>    }
> }

Right, the `==` func is *defined* for 2-element tuples where both elements conform to `Equatable`, but that tuple type doesn't itself *conform* to `Equatable`. So the`==` func that's defined on "Array where Element: Equatable" can't see it.

We'd need both "conditional conformance" and "tuple conformance" in order for that to Just Work.

- Dave Sweeris 
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.swift.org/pipermail/swift-users/attachments/20170709/720c08e9/attachment.html>


More information about the swift-users mailing list