<html><head><meta http-equiv="Content-Type" content="text/html charset=utf-8"></head><body style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;" class=""><br class=""><div><blockquote type="cite" class=""><div class="">On Apr 12, 2016, at 11:23 PM, David Hart via swift-evolution &lt;<a href="mailto:swift-evolution@swift.org" class="">swift-evolution@swift.org</a>&gt; wrote:</div><br class="Apple-interchange-newline"><div class=""><meta http-equiv="content-type" content="text/html; charset=utf-8" class=""><div dir="auto" class=""><div class="">I wouldn't mind driving the discussion and proposal, because I'd really like to see a more complete generics system. Before I start, can David or Doug, or someone else with a high-level view of the generics system tell me if this is where to start or if there is another feature in the Complete Generics manifesto which is more urgent first?</div></div></div></blockquote><div><br class=""></div><div>I think this is a fine feature to focus on. It’s useful, fits well in the system, and it’s scope is small enough that it’s achievable.</div><div><br class=""></div><span class="Apple-tab-span" style="white-space:pre">        </span>- Doug</div><div><br class=""><blockquote type="cite" class=""><div class=""><div dir="auto" class=""><div class=""><br class=""></div><div class="">David</div><div class=""><br class="">On 13 Apr 2016, at 01:46, Jacob Bandes-Storch via swift-evolution &lt;<a href="mailto:swift-evolution@swift.org" class="">swift-evolution@swift.org</a>&gt; wrote:<br class=""><br class=""></div><blockquote type="cite" class=""><div class=""><div dir="ltr" class="">I'm interested, but I'm by no means claiming I'll have enough time to drive any of the discussion/proposal/implementation. :-(<div class="gmail_extra"><br clear="all" class=""><div class=""><div class="gmail_signature"><div dir="ltr" class=""><div class="">Jacob<br class=""></div></div></div></div>
<br class=""><div class="gmail_quote">On Tue, Apr 12, 2016 at 3:07 PM, Dave Abrahams via swift-evolution <span dir="ltr" class="">&lt;<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>&gt;</span> wrote:<br class=""><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="HOEnZb"><div class="h5"><br class="">
on Tue Apr 12 2016, Douglas Gregor &lt;<a href="mailto:swift-evolution@swift.org" class="">swift-evolution@swift.org</a>&gt; wrote:<br class="">
<br class="">
&gt;&nbsp; &nbsp; &nbsp;On Apr 11, 2016, at 1:01 AM, Jacob Bandes-Storch via swift-evolution<br class="">
&gt;&nbsp; &nbsp; &nbsp;&lt;<a href="mailto:swift-evolution@swift.org" class="">swift-evolution@swift.org</a>&gt; wrote:<br class="">
&gt;<br class="">
&gt;&nbsp; &nbsp; &nbsp;Doug wrote this in the Completing Generics manifesto, under "Minor<br class="">
&gt;&nbsp; &nbsp; &nbsp;extensions":<br class="">
&gt;<br class="">
&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;*Arbitrary requirements in protocols<br class="">
&gt;<br class="">
&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;Currently, a new protocol can inherit from other protocols, introduce<br class="">
&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;new associated types, and add new conformance constraints to associated<br class="">
&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;types (by redeclaring an associated type from an inherited protocol).<br class="">
&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;However, one cannot express more general constraints. Building on the<br class="">
&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;example from “Recursive protocol constraints”, we really want the<br class="">
&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;element type of a Sequence’s SubSequence to be the same as the element<br class="">
&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;type of the Sequence, e.g.,<br class="">
&gt;<br class="">
&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;protocol Sequence {<br class="">
&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;associatedtype Iterator : IteratorProtocol<br class="">
&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;…<br class="">
&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;associatedtype SubSequence : Sequence where SubSequence.Iterator.Element<br class="">
&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;== Iterator.Element<br class="">
&gt;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;}<br class="">
&gt;<br class="">
&gt;&nbsp; &nbsp; &nbsp;+1.<br class="">
&gt;<br class="">
&gt;&nbsp; &nbsp; &nbsp;To make it into Swift 3, would this feature require a proposal of its own?<br class="">
&gt;<br class="">
&gt; Yes. Also, be wary that the syntax above potentially conflicts with the syntax<br class="">
&gt; discussed as "moving the where clauses”:<br class="">
&gt;<br class="">
&gt; <a href="http://thread.gmane.org/gmane.comp.lang.swift.evolution/13886/focus=14058" rel="noreferrer" target="_blank" class="">http://thread.gmane.org/gmane.comp.lang.swift.evolution/13886/focus=14058</a><br class="">
&gt;<br class="">
&gt;&nbsp; &nbsp; &nbsp;How feasible would it be to implement on top of the current system?<br class="">
&gt;<br class="">
&gt; Definitely! The archetype builder would need to learn to check these extra where<br class="">
&gt; clauses, and one would need to be sure that the constraint solver is picking<br class="">
&gt; them up as well.<br class="">
<br class="">
</div></div>By the way, having this would enable us to massively simplify the<br class="">
standard library, and potentially lots of user-written generic code,<br class="">
too.&nbsp; So I'm very excited that someone's interested!<br class="">
<span class="HOEnZb"><font color="#888888" class=""><br class="">
--<br class="">
Dave<br class="">
</font></span><div class="HOEnZb"><div class="h5"><br class="">
_______________________________________________<br class="">
swift-evolution mailing list<br class="">
<a href="mailto:swift-evolution@swift.org" class="">swift-evolution@swift.org</a><br class="">
<a href="https://lists.swift.org/mailman/listinfo/swift-evolution" rel="noreferrer" target="_blank" class="">https://lists.swift.org/mailman/listinfo/swift-evolution</a><br class="">
</div></div></blockquote></div><br class=""></div></div>
</div></blockquote><blockquote type="cite" class=""><div class=""><span class="">_______________________________________________</span><br class=""><span class="">swift-evolution mailing list</span><br class=""><span class=""><a href="mailto:swift-evolution@swift.org" class="">swift-evolution@swift.org</a></span><br class=""><span class=""><a href="https://lists.swift.org/mailman/listinfo/swift-evolution" class="">https://lists.swift.org/mailman/listinfo/swift-evolution</a></span><br class=""></div></blockquote></div>_______________________________________________<br class="">swift-evolution mailing list<br class=""><a href="mailto:swift-evolution@swift.org" class="">swift-evolution@swift.org</a><br class="">https://lists.swift.org/mailman/listinfo/swift-evolution<br class=""></div></blockquote></div><br class=""></body></html>