<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 Jan 19, 2016, at 1:21 PM, Douglas Gregor <<a href="mailto:dgregor@apple.com" class="">dgregor@apple.com</a>> wrote:</div><div class=""><div style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;" class=""><div class=""><br class=""></div><div class="">Right. There’s also SubSequence, which you almost certainly don’t want to have to specify. For reference, once we get generic typealiases, one would be free to add</div></div></div></blockquote><div><br class=""></div>Yes, although in the version of SequenceType which declared earlier in the thread, there was no longer a need for SubSequence, as I could just return protocol<SequenceType where .Element == Element> where needed.</div><div><br class=""><blockquote type="cite" class=""><div class=""><div style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;" class=""><div class=""><span class="Apple-tab-span" style="white-space: pre;">        </span>typealias AnyCollection<Element> = protocol<CollectionType where .Element == Element></div></div></div></blockquote><div><br class=""></div>Eventually if you had typealiases in protocols (since the keyword will be freed up eventually due to the new associatedtype keyword) you could declare</div><div><br class=""></div><blockquote style="margin: 0 0 0 40px; border: none; padding: 0px;" class=""><div><div class=""><div class=""><div class="" style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><div class=""><div class=""><div class="" style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><div class=""><div class=""><div class=""><div class=""><div class="" style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><div class=""><div class=""><div class="" style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><div class=""><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; color: rgb(187, 44, 162);">protocol<span class=""> SequenceType {</span></div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; color: rgb(187, 44, 162);"><span class="">  associatedtype Element</span></div></div></div></div></div></div></div></div></div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;"><span class="" style="color: rgb(187, 44, 162);">  typealias</span> SubSequence = protocol<SequenceType where .Element = Self.Element></div></div></div></div></div></div></div></div></div></div></blockquote><div class=""><br class=""></div><div class="">But thats a whole bucket of deprecation issues which aren’t worth it ATM - it would be a proposal for Swift 4.</div><div class=""><br class=""></div><div class="">-DW</div><div class=""><br class=""></div><div><blockquote type="cite" class=""><div class=""><div style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;" class=""><div class=""><br class=""></div><div class="">to cover the common case.</div><div class=""><br class=""></div><span class="Apple-tab-span" style="white-space: pre;">        </span>- Doug</div><div style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;" class=""><br class=""><blockquote type="cite" class=""><div class=""><div class="" style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><div class=""><blockquote type="cite" class=""><div class=""><div class="" style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><div class=""><div class=""><br class=""></div><div class="">Example of a simple protocol which models a node of a tree:</div><div class=""><br class=""></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; color: rgb(0, 132, 0);">// Before</div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; min-height: 13px;"><br class=""></div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; color: rgb(0, 132, 0);">// NodeType can be anything</div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; color: rgb(0, 132, 0);">// currently Swift doesn't allow</div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; color: rgb(0, 132, 0);">// `typealias NodeType: Node`</div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; color: rgb(0, 132, 0);">//</div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; color: rgb(0, 132, 0);">// or even where clauses </div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; color: rgb(0, 132, 0);">// `typealias NodeType: Node where NodeType.T == T`</div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; color: rgb(187, 44, 162);">protocol<span class=""> Node {</span></div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; color: rgb(187, 44, 162);"><span class=""><span class="Apple-tab-span" style="white-space: pre;">        </span></span>typealias<span class=""> T</span></div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;"><span class="Apple-tab-span" style="white-space: pre;">        </span><span class="" style="color: rgb(187, 44, 162);">typealias</span> NodeType</div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; min-height: 13px;"><span class="Apple-tab-span" style="white-space: pre;">        </span><br class="webkit-block-placeholder"></div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;"><span class="Apple-tab-span" style="white-space: pre;">        </span><span class="" style="color: rgb(187, 44, 162);">var</span> value: <span class="" style="color: rgb(112, 61, 170);">T</span> { <span class="" style="color: rgb(187, 44, 162);">get</span> }</div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;"><span class="Apple-tab-span" style="white-space: pre;">        </span><span class="" style="color: rgb(187, 44, 162);">var</span> nodes: [<span class="" style="color: rgb(112, 61, 170);">NodeType</span>] { <span class="" style="color: rgb(187, 44, 162);">get</span> }</div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">}</div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; min-height: 13px;"><br class=""></div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; color: rgb(0, 132, 0);">// After</div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;"><span class="" style="color: rgb(187, 44, 162);">protocol</span> Node<T> {</div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; color: rgb(187, 44, 162);"><span class=""><span class="Apple-tab-span" style="white-space: pre;">        </span></span>typealias<span class=""> T </span><span class="" style="color: rgb(0, 132, 0);">// probably remove this declaration (see reason below)</span></div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;"><span class="Apple-tab-span" style="white-space: pre;">        </span><span class="" style="color: rgb(187, 44, 162);">var</span> value: <span class="" style="color: rgb(112, 61, 170);">T</span> { <span class="" style="color: rgb(187, 44, 162);">get</span> }</div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;"><span class="Apple-tab-span" style="white-space: pre;">        </span><span class="" style="color: rgb(187, 44, 162);">var</span> nodes: [<span class="" style="color: rgb(112, 61, 170);">Node</span><T>] { <span class="" style="color: rgb(187, 44, 162);">get</span> }</div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">}</div></div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;"><br class=""></div><div class=""><div class="" style="margin: 0px; line-height: normal;"><div class="" style="margin: 0px; line-height: normal;"><div class="" style="margin: 0px; line-height: normal;"><div class="" style="margin: 0px; line-height: normal;"><div class="">So a generic parameter is placed after the protocol name. Therefore a corresponding associated type could be synthesized making its declaration in the body of the protocol unnecessary.</div><div class=""><br class=""></div><div class="">In order to let this still compile:</div><div class=""><br class=""></div><div class=""><span class="Apple-tab-span" style="white-space: pre;">        </span><span class="" style="color: rgb(187, 44, 162); font-family: Menlo; font-size: 11px;">func</span><span class="" style="font-family: Menlo; font-size: 11px;"> afunction<S: </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">SequenceType</span><span class="" style="font-family: Menlo; font-size: 11px;"> </span><span class="" style="font-family: Menlo; font-size: 11px; color: rgb(187, 44, 162);">where</span><span class="" style="font-family: Menlo; font-size: 11px;"> </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">S</span><span class="" style="font-family: Menlo; font-size: 11px;">.</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">Generator</span><span class="" style="font-family: Menlo; font-size: 11px;">.</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">Element</span><span class="" style="font-family: Menlo; font-size: 11px;"> == </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">Int</span><span class="" style="font-family: Menlo; font-size: 11px;">>(s: </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">S</span><span class="" style="font-family: Menlo; font-size: 11px;">){}</span></div><div class=""><span class="" style="font-family: Menlo; font-size: 11px;"><br class=""></span></div><div class="">there could be a general Swift feature to get the generic type by dot syntax (e.g. synthesized typealiases for every generic parameter).</div><div class=""><br class=""></div><div class=""><br class=""></div><div class="">Implementation:</div><div class="">The function declaration above could be rewritten to using a function like generic parameter parameter syntax for protocols:</div><div class=""><br class=""></div><div class="">        <span class="" style="color: rgb(0, 132, 0); font-family: Menlo; font-size: 11px;">// Declaration of SequenceType</span></div><div class="">        <span class="" style="color: rgb(187, 44, 162); font-family: Menlo; font-size: 11px;">protocol </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">SequenceType</span><span class="" style="font-family: Menlo; font-size: 11px;"><<font color="#703daa" class="">Element</font>:<font color="#703daa" class=""><span class="Apple-converted-space"> </span>Generator.Element</font>,</span> <span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">Generator</span><span class="" style="font-family: Menlo; font-size: 11px;">:</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;"><span class="Apple-converted-space"> </span>GeneratorType</span><span class="" style="font-family: Menlo; font-size: 11px;">,</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;"> </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">SubSequence</span><font face="Menlo" class=""><span class="" style="font-size: 11px;">> { … }</span></font></div><div class=""><font face="Menlo" class=""><span class="" style="font-size: 11px;">    </span></font><span class="" style="color: rgb(0, 132, 0); font-family: Menlo; font-size: 11px;">//                           ^~~~ using : in oder to allow default types with =</span></div><div class=""><br class=""></div><div class="">        <span class="" style="color: rgb(0, 132, 0); font-family: Menlo; font-size: 11px;">// Using "_" to leave it unspecified eg. Any</span></div><div class=""><span class="" style="color: rgb(187, 44, 162); font-family: Menlo; font-size: 11px;">    func</span><span class="" style="font-family: Menlo; font-size: 11px;"> afunction(s: </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">SequenceType<Element: Int</span><span class="" style="font-family: Menlo; font-size: 11px;">,</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;"><span class="Apple-converted-space"> </span>Generator: GeneratorType</span><span class="" style="font-family: Menlo; font-size: 11px;"><</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">Element</span><span class="" style="font-family: Menlo; font-size: 11px;">:</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;"><span class="Apple-converted-space"> </span>Int</span><span class="" style="font-family: Menlo; font-size: 11px;">></span><span class="" style="font-family: Menlo; font-size: 11px;">,</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;"><span class="Apple-converted-space"> </span>SubSequence: _></span><span class="" style="font-family: Menlo; font-size: 11px;">){}</span></div><div class=""><span class="" style="font-family: Menlo; font-size: 11px;">    </span><span class="" style="color: rgb(0, 132, 0); font-family: Menlo; font-size: 11px;">// omitting `SubSequence: _` since the type is already unambiguous</span></div><div class=""><span class="" style="color: rgb(187, 44, 162); font-family: Menlo; font-size: 11px;">    </span><span class="" style="color: rgb(187, 44, 162); font-family: Menlo; font-size: 11px;">func</span><span class="" style="font-family: Menlo; font-size: 11px;"> afunction(s: </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">SequenceType</span><span class="" style="font-family: Menlo; font-size: 11px;"><</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">Element</span><span class="" style="font-family: Menlo; font-size: 11px;">:</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;"> Int</span><span class="" style="font-family: Menlo; font-size: 11px;">,</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;"><span class="Apple-converted-space"> </span>Generator: </span><span class="" style="font-family: Menlo; font-size: 11px;"><span class="" style="color: rgb(112, 61, 170);">GeneratorType</span><span class=""><</span><span class="" style="color: rgb(112, 61, 170);">Element</span><span class="">:</span><span class="" style="color: rgb(112, 61, 170);"> Int</span><span class="">></span>></span><span class="" style="font-family: Menlo; font-size: 11px;">){}</span></div><div class=""><span class="" style="font-family: Menlo; font-size: 11px;"><div class="" style="font-family: Helvetica; font-size: 12px;"><span class="" style="font-family: Menlo; font-size: 11px;">    </span><span class="" style="color: rgb(0, 132, 0); font-family: Menlo; font-size: 11px;">// omitting `Generator: GeneratorType<Int>` since the type of `Generator` can be inferred from Element</span></div><div class="" style="font-family: Helvetica; font-size: 12px;"><span class="" style="color: rgb(187, 44, 162); font-family: Menlo; font-size: 11px;">    </span><span class="" style="color: rgb(187, 44, 162); font-family: Menlo; font-size: 11px;">func</span><span class="" style="font-family: Menlo; font-size: 11px;"> afunction(s: </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">SequenceType</span><span class="" style="font-family: Menlo; font-size: 11px;"><</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">Element</span><span class="" style="font-family: Menlo; font-size: 11px;">:</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;"> Int</span><span class="" style="font-family: Menlo; font-size: 11px;">></span><span class="" style="font-family: Menlo; font-size: 11px;">){}</span></div></span></div><div class=""><span class="" style="font-family: Menlo; font-size: 11px;"><br class=""></span></div><div class="">The order of arguments is in this case irrelevant, but should probably be in a strict ordering to make it more consistent with the point below.</div><div class=""><br class=""></div><div class="">In order to have a more general generic parameter behavior (to work with structs, classes and enums) we could also allow to use these without external names and only their order. So the example above would look like this:</div><div class=""><br class=""></div><div class=""><div class=""><span class="" style="color: rgb(187, 44, 162); font-family: Menlo; font-size: 11px;">    func</span><span class="" style="font-family: Menlo; font-size: 11px;"> afunction(s: </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">SequenceType<Int</span><span class="" style="font-family: Menlo; font-size: 11px;">,</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;"> GeneratorType<Int></span><span class="" style="font-family: Menlo; font-size: 11px;">, </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">_></span><span class="" style="font-family: Menlo; font-size: 11px;">){}</span></div><div class=""><span class="" style="color: rgb(187, 44, 162); font-family: Menlo; font-size: 11px;">    </span><span class="" style="color: rgb(187, 44, 162); font-family: Menlo; font-size: 11px;">func</span><span class="" style="font-family: Menlo; font-size: 11px;"> afunction(s: </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">SequenceType</span><span class="" style="font-family: Menlo; font-size: 11px;"><</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">Int</span><span class="" style="font-family: Menlo; font-size: 11px;">, </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">GeneratorType<Int></span><span class="" style="font-family: Menlo; font-size: 11px;">></span><span class="" style="font-family: Menlo; font-size: 11px;">){}</span></div><div class=""><span class="" style="font-family: Menlo; font-size: 11px;"><div class="" style="font-family: Helvetica; font-size: 12px;"><span class="" style="color: rgb(187, 44, 162); font-family: Menlo; font-size: 11px;">    </span><span class="" style="color: rgb(187, 44, 162); font-family: Menlo; font-size: 11px;">func</span><span class="" style="font-family: Menlo; font-size: 11px;"> afunction(s: </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">SequenceType</span><span class="" style="font-family: Menlo; font-size: 11px;"><</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">Int</span><span class="" style="font-family: Menlo; font-size: 11px;">></span><span class="" style="font-family: Menlo; font-size: 11px;">){}</span></div><div class="" style="font-family: Helvetica; font-size: 12px;"><span class="" style="font-family: Menlo; font-size: 11px;">    </span></div><div class="" style="font-family: Helvetica; font-size: 12px;"><span class="" style="font-family: Menlo; font-size: 11px;">    </span><span class="" style="color: rgb(0, 132, 0); font-family: Menlo; font-size: 11px;">// These two functions don't produce an error since `Element` can be inferred</span></div><div class="" style="font-family: Helvetica; font-size: 12px;"><span class="" style="color: rgb(0, 132, 0); font-family: Menlo; font-size: 11px;">    </span><span class="" style="color: rgb(187, 44, 162); font-family: Menlo; font-size: 11px;">func</span><span class="" style="font-family: Menlo; font-size: 11px;"> afunction(s: </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">SequenceType<</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">GeneratorType<Int></span><span class="" style="font-family: Menlo; font-size: 11px;">, </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">_></span><span class="" style="font-family: Menlo; font-size: 11px;">){}</span></div></span><div class=""><span class="" style="color: rgb(187, 44, 162); font-family: Menlo; font-size: 11px;">    </span><span class="" style="color: rgb(187, 44, 162); font-family: Menlo; font-size: 11px;">func</span><span class="" style="font-family: Menlo; font-size: 11px;"> afunction(s: </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">SequenceType</span><span class="" style="font-family: Menlo; font-size: 11px;"><</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">GeneratorType<Int></span><span class="" style="font-family: Menlo; font-size: 11px;">></span><span class="" style="font-family: Menlo; font-size: 11px;">){}</span></div><div class=""><span class="" style="font-family: Menlo; font-size: 11px;"><br class=""></span></div><div class=""><span class="" style="font-family: Menlo; font-size: 11px;"><span class="" style="color: rgb(0, 132, 0);">    // for an unconstrained Sequence "_" can be used in order to make it clear: "there could be generic parameters"</span></span></div><div class=""><span class="" style="font-family: Menlo; font-size: 11px;"><span class="" style="color: rgb(187, 44, 162);">    </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class=""> afunction(s: </span><span class="" style="color: rgb(112, 61, 170);">SequenceType</span><span class=""><_</span><span class="">></span><span class="">){}</span></span></div></div></div><div class=""><br class=""></div><div class="">For instance `Array` and `Dictionary` also can apply to this model.</div><div class=""><br class=""></div><div class="">Also where clauses could be used in generic parameter declarations which are disallowed for associated types (currently).</div><div class=""><br class=""></div><div class=""><br class=""></div><div class="">What do you think about this approach?</div><div class=""><br class=""></div><div class="">Should <span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">SequenceType</span><span class="" style="font-family: Menlo; font-size: 11px;"><_</span><span class="" style="font-family: Menlo; font-size: 11px;">> </span>be<span class="Apple-converted-space"> </span><b class="">equal</b><span class="Apple-converted-space"> </span>to <span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">SequenceType</span><span class="" style="font-family: Menlo; font-size: 11px;"><</span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">Any</span><span class="" style="font-family: Menlo; font-size: 11px;">> / </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">SequenceType</span><span class="" style="font-family: Menlo; font-size: 11px;"><<span class="" style="color: rgb(112, 61, 170);">Element</span>: </span><span class="" style="color: rgb(112, 61, 170); font-family: Menlo; font-size: 11px;">Any</span><span class="" style="font-family: Menlo; font-size: 11px;">></span><span class="" style="font-family: Menlo; font-size: 11px;"> </span>?</div><div class=""><br class=""></div><div class=""><br class=""></div><div class="">- Maximilian</div></div></div></div></div></div></div><br class=""><div class=""><blockquote type="cite" class=""><div class="">Am 19.01.2016 um 00:32 schrieb David Waite via swift-evolution <<a href="mailto:swift-evolution@swift.org" class="">swift-evolution@swift.org</a>>:</div><br class="Apple-interchange-newline"><div class=""><div class="" style="word-wrap: break-word; -webkit-nbsp-mode: space; -webkit-line-break: after-white-space;"><br class=""><div class=""><blockquote type="cite" class=""><div class="">On Jan 18, 2016, at 1:18 PM, Douglas Gregor <<a href="mailto:dgregor@apple.com" class="">dgregor@apple.com</a>> wrote:</div><div class=""><div class="" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;"><div class=""><blockquote type="cite" class=""><div class=""><div class=""><br class=""></div><blockquote class="" style="margin: 0px 0px 0px 40px; border: none; padding: 0px;"><div class="">let x:SequenceType = [1,2,3] // no constraints specified whatsoever</div><div class="">let y:protocol<SequenceType where Generator.Element == String> = [“foo”, “bar”] // partially constrained</div></blockquote></div></blockquote><div class=""><br class=""></div>Not wanting to start throwing paint, but "Generator.Element" could be ambiguous with a Generator in the lexical scope. You'll probably want some way to differentiate it (eg, a leading dot). Otherwise, this is the syntactic direction that I think makes the most sense.</div></div></div></blockquote><div class=""><br class=""></div>Yes, I’ll use that below. There is a right balance in extending protocol<>. For instance, I did not like the following at all:</div><div class=""><br class=""></div><div class=""><span class="Apple-tab-span" style="white-space: pre;">        </span>protocol<S:SequenceType where S.Generator.Element == String></div><div class=""><br class=""></div><div class=""><blockquote type="cite" class=""><div class=""><div class="" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;"><div class=""><br class=""><blockquote type="cite" class=""><div class=""><div class="">One interesting side-effect to note is that SequenceType could be redefined to only have “Element” as an associated type. Instead of Generator or SubSequence being associated types, methods could return partially constrained GenericType or SequenceType from the appropriate methods. This would be one way of eliminating issues today with recursive use of associated types (as well as SubSequence over-constraining the output of various algorithms to a single concrete type)</div></div></blockquote><div class=""><br class=""></div><div class="">Assuming nobody cares about the identity of the Generator type, which is probably a safe assumption. Note that one could implement this design today by using a function taking no arguments and returning an Element? in lieu of "Generator”.</div></div></div></div></blockquote><div class=""><br class=""></div>Yes, as an aside I was actually curious GeneratorType existed when I was first diving into the standard library, considering it could just be a closure.</div><div class=""><br class=""><blockquote type="cite" class=""><div class=""><div class="" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;"><div class=""><br class=""><blockquote type="cite" class=""><div class=""><div class=""><br class=""></div><div class="">For the “opening” of an existential type to find the concrete type it stores dynamically, I’m currently using a different syntax just because the “open x as T” originally given makes ‘open’ a keyword’ and makes it unclear where ’T’ came from</div></div></blockquote><div class=""><br class=""></div><div class="">Yes, the issue of "which name did I introduce?" is tricky here. </div><br class=""><blockquote type="cite" class=""><div class=""><div class="">- I’m instead overloading the typealias keyword when used within an expression context:</div><div class=""><br class=""></div><blockquote class="" style="margin: 0px 0px 0px 40px; border: none; padding: 0px;"><div class="">typealias T = x.dynamicType</div><div class="">let xT = x as! T</div></blockquote></div></blockquote><div class=""><br class=""></div>x will have to be immutable for this to make sense. That's why my ugly "open" expression extracts a new value and gives it a fresh type in one lexically-scoped block. Both the type and the value end up being scoped. Otherwise, one might reassign "x" with a different dynamic type... Then what does T mean?</div></div></div></blockquote><div class=""><br class=""></div><div class="">This is an area that I need to understand compiler behavior more here (I’ve been researching)</div><div class=""><br class=""></div><div class="">If ’T’ internally behaves like an immutable variable with lexical scope, then ’typealias’ in a code block is just another statement, and the type would be based on the value of ‘x’ at the point of execution:</div><div class=""><br class=""></div></div><div class="">var x:Any = “Initial”</div><div class="">typealias T = x.dynamicType // String</div><div class="">x = 1</div><div class="">let xT = x as! T // fails precondition as if I had said x as! String</div><div class=""><br class=""></div><div class="">I’m guessing from your comment however that T would not a variable. In which case, it makes sense to be more restrictive in use (such as requiring immutability). This is also more consistent with the use of typealias in other contexts, if that was the syntax one was going with.</div><div class=""><br class=""></div><div class=""><blockquote type="cite" class=""><div class=""><div class="" style="font-family: Helvetica; font-size: 12px; font-style: normal; font-variant: normal; font-weight: normal; letter-spacing: normal; orphans: auto; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; widows: auto; word-spacing: 0px; -webkit-text-stroke-width: 0px;">I suggest you also look at what can be done with an existential value that hasn't been opened explicitly. Can I call "generate" on a SequenceType value, and what do I get back?</div></div></blockquote><div class=""><br class=""></div>Depends on how far we are willing to go. If you are only willing to expose the invariants in the face of the constraints given (in this case none), all you would get exposed is “underestimateCount”.</div><div class=""><br class=""></div><div class="">If you are willing to expose anything which can be expressed by certain type safety rules (needing formal definition later), then you can do quite a bit.</div><div class=""><br class=""></div><div class="">To start, let me express SequenceType relying on the partially constrained protocols, taking a few liberties: </div><div class="">- pruning some alternate forms</div><div class="">- removing SubSequence and Generator associated types and just having Element</div><div class="">- using the protocol<> syntax described before (with . prefix)</div><div class="">- returning partially constrained SequenceTypes rather than stdlib concrete types like JoinSequence in a few cases. </div><div class="">- eliminate usage of AnySequence in definitions (not needed)</div><div class="">- assuming a change in protocol LazySequenceType to be expressed in terms of Element rather than a base SequenceType</div><div class=""><br class=""></div><blockquote class="" style="margin: 0px 0px 0px 40px; border: none; padding: 0px;"><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;"><span class="" style="color: rgb(187, 44, 162);">protocol</span><span class="Apple-converted-space"> </span>SequenceType {</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">    associatedtype Element</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; min-height: 13px;"><br class=""></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">var</span><span class="Apple-converted-space"> </span>lazy:<span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(112, 61, 170);">LazySequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element == Element> {<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">get</span><span class="Apple-converted-space"> </span>}</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>contains(<span class="" style="color: rgb(187, 44, 162);">@noescape</span><span class="Apple-converted-space"> </span>predicate:(Element)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">throws</span><span class="Apple-converted-space"> </span>-> Bool)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">rethrows</span><span class="Apple-converted-space"> </span>-><span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">Bool</span></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>dropFirst(n:<span class="" style="color: rgb(112, 61, 170);">Int</span>) -><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(79, 129, 135);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element == Element></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>dropLast(n:<span class="" style="color: rgb(112, 61, 170);">Int</span>) -><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(79, 129, 135);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element == Element></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">    <span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>elementsEqual(other:<span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(79, 129, 135);">SequenceType</span> <span class="" style="color: rgb(187, 44, 162);">where</span> .Element == Element>,<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">@noescape</span><span class="Apple-converted-space"> </span>isEquivalent: (Element, Element)) -> Bool</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>enumerate() -><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(79, 129, 135);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element == (Int, Element)></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>filter(<span class="" style="color: rgb(187, 44, 162);">@noescape</span><span class="Apple-converted-space"> </span>includeElement: (Element)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">throws</span>-> Bool)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">rethrows</span><span class="Apple-converted-space"> </span>-> [<span class="" style="color: rgb(112, 61, 170);">Element</span>]</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>flatMap<E>(transform: (Element)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">throws</span><span class="Apple-converted-space"> </span>-><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">protocol</span><SequenceType<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element:E>)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">rethrows</span><span class="Apple-converted-space"> </span>-> [<span class="" style="color: rgb(79, 129, 135);">E</span>]</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>flatMap<T>(<span class="" style="color: rgb(187, 44, 162);">@noescape</span><span class="Apple-converted-space"> </span>transform: (Element)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">throws</span><span class="Apple-converted-space"> </span>-><span class="Apple-converted-space"> </span><span class="" style="color: rgb(79, 129, 135);">T</span>?)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">rethrows</span><span class="Apple-converted-space"> </span>-> [<span class="" style="color: rgb(79, 129, 135);">T</span>]</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>forEach(<span class="" style="color: rgb(187, 44, 162);">@noescape</span><span class="Apple-converted-space"> </span>body: (Element)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">throws</span><span class="Apple-converted-space"> </span>-> ())<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">rethrows</span></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>generate() -><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(112, 61, 170);">GeneratorType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element == Element></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>lexicographicalCompare(other:<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(79, 129, 135);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element == Element>,<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">@noescape</span><span class="Apple-converted-space"> </span>isOrderedBefore:(Element,Element)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">throws</span>-> Bool)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">rethrows</span><span class="Apple-converted-space"> </span>-><span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">Bool</span></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>map<T>(<span class="" style="color: rgb(187, 44, 162);">@noescape</span><span class="Apple-converted-space"> </span>transform: (Element)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">throws</span><span class="Apple-converted-space"> </span>-><span class="Apple-converted-space"> </span><span class="" style="color: rgb(79, 129, 135);">T</span>)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">rethrows</span><span class="Apple-converted-space"> </span>-> [<span class="" style="color: rgb(79, 129, 135);">T</span>]</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>maxElement(<span class="" style="color: rgb(187, 44, 162);">@noescape</span><span class="Apple-converted-space"> </span>isOrderedBefore: (Element,Element)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">throws</span><span class="Apple-converted-space"> </span>-> Bool)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">rethrows</span><span class="Apple-converted-space"> </span>-><span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">Element</span>?</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>minElement(<span class="" style="color: rgb(187, 44, 162);">@noescape</span><span class="Apple-converted-space"> </span>isOrderedBefore: (Element,Element)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">throws</span><span class="Apple-converted-space"> </span>-> Bool)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">rethrows</span><span class="Apple-converted-space"> </span>-><span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">Element</span>?</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>prefix(n:<span class="" style="color: rgb(112, 61, 170);">Int</span>) -><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(79, 129, 135);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element == Element></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>reduce<T>(initial:<span class="Apple-converted-space"> </span><span class="" style="color: rgb(79, 129, 135);">T</span>,<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">@noescape</span><span class="Apple-converted-space"> </span>combine: (<span class="" style="color: rgb(79, 129, 135);">T</span>, Element)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">throws</span><span class="Apple-converted-space"> </span>-><span class="Apple-converted-space"> </span><span class="" style="color: rgb(79, 129, 135);">T</span>)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">rethrows</span><span class="Apple-converted-space"> </span>-><span class="Apple-converted-space"> </span><span class="" style="color: rgb(79, 129, 135);">T</span></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>reverse() -> [<span class="" style="color: rgb(112, 61, 170);">Element</span>]</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>sort(<span class="" style="color: rgb(187, 44, 162);">@noescape</span><span class="Apple-converted-space"> </span>isOrderedBefore: (Element,Element)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">throws</span><span class="Apple-converted-space"> </span>-> Bool)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">rethrows</span><span class="Apple-converted-space"> </span>-> [<span class="" style="color: rgb(112, 61, 170);">Element</span>]</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>split(maxSplit:<span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">Int</span>, allowEmptySubsequences:<span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">Bool</span>,<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">@noescape</span><span class="Apple-converted-space"> </span>isSeparator: (Element)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">throws</span><span class="Apple-converted-space"> </span>-> Bool)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">rethrows</span><span class="Apple-converted-space"> </span>-> [<span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(79, 129, 135);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element == Element>]</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>startsWith(other:<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(79, 129, 135);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element == Element>,<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">@noescape</span><span class="Apple-converted-space"> </span>isEquivalent: (Element, Element)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">throws</span><span class="Apple-converted-space"> </span>-> Bool)<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">rethrows</span><span class="Apple-converted-space"> </span>-><span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">Bool</span></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>suffix(n:<span class="" style="color: rgb(112, 61, 170);">Int</span>) -><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(79, 129, 135);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element == Element></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>underestimateCount() -><span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">Int</span></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">}</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; min-height: 13px;"><br class=""></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;"><span class="" style="color: rgb(187, 44, 162);">extension</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(79, 129, 135);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>Element:Equatable {</div></div><div class=""><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">    <span class="" style="color: rgb(187, 44, 162);">func</span> elementsEqual<OtherSequence : <span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(79, 129, 135);">SequenceType</span> <span class="" style="color: rgb(187, 44, 162);">where</span> .Element == Element>(other: OtherSequence) -> Bool</div></div><div class=""></div><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">    <span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>split(separator:<span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">Element</span>, maxSplit:<span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">Int</span>, allowEmptySlices:<span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">Bool</span>) -> [<span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(112, 61, 170);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element == Element>]</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>startsWith(other:<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(112, 61, 170);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element == Element) -><span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">Bool</span></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">}</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; min-height: 13px;"><br class=""></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;"><span class="" style="color: rgb(187, 44, 162);">extension</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(79, 129, 135);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>Element == String {</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>joinWithSeparator(separator:<span class="" style="color: rgb(112, 61, 170);">String</span>) -><span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">String</span></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">}</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; min-height: 13px;"><br class=""></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;"><span class="" style="color: rgb(187, 44, 162);">extension</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(79, 129, 135);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>Element:<span class="" style="color: rgb(187, 44, 162);">protocol</span><SequenceType></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;"><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>flatten() -><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(79, 129, 135);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element == Element.Element></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;"><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>joinWithSeparator(separator:<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(79, 129, 135);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element = Element.Element>) -><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(79, 129, 135);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element == Element.Element>)</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">}</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo; min-height: 13px;"><br class=""></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;"><span class="" style="color: rgb(187, 44, 162);">extension</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(79, 129, 135);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>Element:Comparable {</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>lexicographicalCompare(other:<span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">protocol</span><<span class="" style="color: rgb(112, 61, 170);">SequenceType</span><span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">where</span><span class="Apple-converted-space"> </span>.Element == Element>) -><span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">Bool</span></div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>maxElement() -><span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">Element</span>?</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>minElement() -><span class="Apple-converted-space"> </span><span class="" style="color: rgb(112, 61, 170);">Element</span>?</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">   <span class="Apple-converted-space"> </span><span class="" style="color: rgb(187, 44, 162);">func</span><span class="Apple-converted-space"> </span>sort() -> [<span class="" style="color: rgb(112, 61, 170);">Element</span>]</div></div><div class=""><div class="" style="margin: 0px; font-size: 11px; line-height: normal; font-family: Menlo;">}</div></div></blockquote>Now, mapping this in terms of just an unconstrained SequenceType, which is shorthand for protocol<SequenceType where .Element:Any>:<div class="">- None of the extensions match the constraint on Element, so they are not exposed</div><div class="">- property Lazy is exposed as an unconstrained LazySequenceType, aka protocol<LazySequenceType where .Element:Any></div><div class="">- the predicate function in contains is not constrained by a particular kind of element, so it becomes (Any)->Bool, e.g.:</div><blockquote class="" style="margin: 0px 0px 0px 40px; border: none; padding: 0px;"><div class=""><span class="" style="font-family: Menlo; font-size: 11px; color: rgb(187, 44, 162);">func</span><span class="" style="font-family: Menlo; font-size: 11px;"> contains(</span><span class="" style="font-family: Menlo; font-size: 11px; color: rgb(187, 44, 162);">@noescape</span><span class="" style="font-family: Menlo; font-size: 11px;"> predicate:(Any) </span><span class="" style="font-family: Menlo; font-size: 11px; color: rgb(187, 44, 162);">throws</span><span class="" style="font-family: Menlo; font-size: 11px;"> -> Bool) </span><span class="" style="font-family: Menlo; font-size: 11px; color: rgb(187, 44, 162);">rethrows</span><span class="" style="font-family: Menlo; font-size: 11px;"> -> </span><span class="" style="font-family: Menlo; font-size: 11px; color: rgb(112, 61, 170);">Bool</span></div></blockquote><div class=""><div class="">- dropFirst/dropLast would return an unconstrained SequenceType. This would need to leverage rules around constrained protocol variance/equivalence.</div><div class="">- elementsEqual was changed to no longer be generic - one can pass in any SequenceType constrained to have the same Element type. The function parameter, similar to contains above, now has the signature (Any, Any)->Bool</div><div class="">- enumerate() will return a sequence with elements of type (Int, Any)</div><div class="">- filter takes a (Any) throws -> Bool method and returns [Any]</div><div class="">- flatMap and forEach are exposed similar to contains above</div><div class="">- generate returns an unconstrained GeneratorType (so it will have a single method func next() -> Any?)</div><div class="">- lexicographicalCompare fails, more below</div><div class="">- reduce has effective syntax:</div></div><blockquote class="" style="margin: 0px 0px 0px 40px; border: none; padding: 0px;"><div class=""><div class=""> <span class="" style="font-family: Menlo; font-size: 11px; color: rgb(187, 44, 162);">func</span><span class="" style="font-family: Menlo; font-size: 11px;"> reduce<T>(initial: </span><span class="" style="font-family: Menlo; font-size: 11px; color: rgb(79, 129, 135);">T</span><span class="" style="font-family: Menlo; font-size: 11px;">, </span><span class="" style="font-family: Menlo; font-size: 11px; color: rgb(187, 44, 162);">@noescape</span><span class="" style="font-family: Menlo; font-size: 11px;"> combine: (</span><span class="" style="font-family: Menlo; font-size: 11px; color: rgb(79, 129, 135);">T</span><span class="" style="font-family: Menlo; font-size: 11px;">, Any) </span><span class="" style="font-family: Menlo; font-size: 11px; color: rgb(187, 44, 162);">throws</span><span class="" style="font-family: Menlo; font-size: 11px;"> -> </span><span class="" style="font-family: Menlo; font-size: 11px; color: rgb(79, 129, 135);">T</span><span class="" style="font-family: Menlo; font-size: 11px;">) </span><span class="" style="font-family: Menlo; font-size: 11px; color: rgb(187, 44, 162);">rethrows</span><span class="" style="font-family: Menlo; font-size: 11px;"> -> </span><span class="" style="font-family: Menlo; font-size: 11px; color: rgb(79, 129, 135);">T</span></div></div></blockquote><div class="">- the rest are exposed as above except for startsWith</div><div class=""><br class=""></div><div class="">So all functionality except<span class="" style="font-family: Menlo; font-size: 11px;"> lexicographicalCompare and </span><span class="" style="font-family: Menlo; font-size: 11px;">startsWith </span>could at least in theory be exposed safely. These cannot be exposed cleanly because method expected an input sequence with the same element type, but the element type is not invariantly constrained. Self properties and method arguments are an equivalent problem, except that for a Self argument can only be invariantly constrained when you know the implementing concrete type - hence wanting a system to dynamically reason about said types.</div><div class=""><br class=""></div><div class="">This seems like a good amount of exposed functionality. Granted, it is not free to work at the level of protocols vs concrete types, and this does not attempt to simplify that. However, this proposal seems to bridge the gap between protocols without associated types and protocols with them. I also am happy with the amount of functionality that can be exposed safely as well as the consistency (A lexicographicalCompare function working on heterogenous sequences would have to be declared differently)</div><div class=""><br class=""></div><div class="">-DW</div><div class=""><br class=""></div><blockquote class="" style="margin: 0px 0px 0px 40px; border: none; padding: 0px;"><div class=""></div></blockquote><div class=""><blockquote class="" style="margin: 0px 0px 0px 40px; border: none; padding: 0px;"></blockquote></div></div>_______________________________________________<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" class="">https://lists.swift.org/mailman/listinfo/swift-evolution</a></div></blockquote></div></div></div></blockquote></div></div></div></blockquote></div></div></blockquote></div><br class=""></body></html>