<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="">I strongly disagree.<div class=""><br class=""></div><div class="">Exchanging</div><div class=""><br class=""></div><div class=""><div class="" style="margin: 0px; font-size: 9px; line-height: normal; font-family: Menlo;"><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(187, 44, 162);">for</span><span class="" style="font-variant-ligatures: no-common-ligatures;"> result </span><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(187, 44, 162);">in</span><span class="" style="font-variant-ligatures: no-common-ligatures;"> results </span><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(187, 44, 162);">where</span><span class="" style="font-variant-ligatures: no-common-ligatures;"> result.value != .Warning </span><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(187, 44, 162);">while</span><span class="" style="font-variant-ligatures: no-common-ligatures;"> result.value != .Error {</span></div><div class="" style="margin: 0px; font-size: 9px; line-height: normal; font-family: Menlo; color: rgb(0, 132, 0);"><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(0, 0, 0);"><span class="Apple-tab-span" style="white-space: pre;"> </span></span><span class="" style="font-variant-ligatures: no-common-ligatures;">/// ...</span></div><div class="" style="margin: 0px; font-size: 9px; line-height: normal; font-family: Menlo;"><span class="" style="font-variant-ligatures: no-common-ligatures;">}</span></div></div><div class=""><br class=""></div><div class="">for either </div><div class=""><br class=""></div><div class=""><div class="" style="margin: 0px; font-size: 9px; line-height: normal; font-family: Menlo;"><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(187, 44, 162);">for</span><span class="" style="font-variant-ligatures: no-common-ligatures;"> result </span><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(187, 44, 162);">in</span><span class="" style="font-variant-ligatures: no-common-ligatures;"> results.filter({ $0.value != .Warning }).prefix(</span><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(187, 44, 162);">while</span><span class="" style="font-variant-ligatures: no-common-ligatures;">: { $0.value != .Error })) {</span></div><div class="" style="margin: 0px; font-size: 9px; line-height: normal; font-family: Menlo; color: rgb(0, 132, 0);"><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(0, 0, 0);"><span class="Apple-tab-span" style="white-space: pre;"> </span></span><span class="" style="font-variant-ligatures: no-common-ligatures;">/// ...</span></div><div class="" style="margin: 0px; font-size: 9px; line-height: normal; font-family: Menlo;"><span class="" style="font-variant-ligatures: no-common-ligatures;">}</span></div></div><div class="" style="margin: 0px; font-size: 9px; line-height: normal; font-family: Menlo;"><span class="" style="font-variant-ligatures: no-common-ligatures;"><br class=""></span></div><div class="">or</div><div class=""><br class=""></div><div class=""><div class="" style="margin: 0px; font-size: 9px; line-height: normal; font-family: Menlo;"><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(187, 44, 162);">for</span><span class="" style="font-variant-ligatures: no-common-ligatures;"> result </span><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(187, 44, 162);">in</span><span class="" style="font-variant-ligatures: no-common-ligatures;"> results {</span></div><div class="" style="margin: 0px; font-size: 9px; line-height: normal; font-family: Menlo;"><span class="" style="font-variant-ligatures: no-common-ligatures;"><span class="Apple-tab-span" style="white-space: pre;"> </span></span><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(187, 44, 162);">if</span><span class="" style="font-variant-ligatures: no-common-ligatures;"> result.value == .Warning { </span><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(187, 44, 162);">continue</span><span class="" style="font-variant-ligatures: no-common-ligatures;"> }</span></div><div class="" style="margin: 0px; font-size: 9px; line-height: normal; font-family: Menlo;"><span class="" style="font-variant-ligatures: no-common-ligatures;"><span class="Apple-tab-span" style="white-space: pre;"> </span></span><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(187, 44, 162);">if</span><span class="" style="font-variant-ligatures: no-common-ligatures;"> result.value == .Error { </span><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(187, 44, 162);">break</span><span class="" style="font-variant-ligatures: no-common-ligatures;"> }</span></div><div style="margin: 0px; font-size: 9px; line-height: normal; font-family: Menlo; min-height: 10px;" class=""><span class="" style="font-variant-ligatures: no-common-ligatures;"><span class="Apple-tab-span" style="white-space: pre;"> </span></span><br class="webkit-block-placeholder"></div><div class="" style="margin: 0px; font-size: 9px; line-height: normal; font-family: Menlo; color: rgb(0, 132, 0);"><span class="" style="font-variant-ligatures: no-common-ligatures; color: rgb(0, 0, 0);"><span class="Apple-tab-span" style="white-space: pre;"> </span></span><span class="" style="font-variant-ligatures: no-common-ligatures;">/// ...</span></div><div class="" style="margin: 0px; font-size: 9px; line-height: normal; font-family: Menlo;"><span class="" style="font-variant-ligatures: no-common-ligatures;">}</span></div></div><div class="" style="margin: 0px; font-size: 9px; line-height: normal; font-family: Menlo;"><span class="" style="font-variant-ligatures: no-common-ligatures;"><br class=""></span></div><div class="">Seems like an absolute step back. Not to mention filter(_:) doesn't return a lazy collection, but will recreate it, while the `where` will do on-the-fly check.</div><div class=""><br class=""></div><div style=""><blockquote type="cite" class=""><div class="">On Jun 7, 2016, at 1:34 AM, Xiaodi Wu via swift-evolution <<a href="mailto:swift-evolution@swift.org" class="">swift-evolution@swift.org</a>> wrote:</div><br class="Apple-interchange-newline"><div class=""><div style="white-space:pre-wrap" class="">Personally, given this discussion and the one about `where` in if and while statements, I would not be opposed to elimination of `where` in control statements altogether.<br class=""><br class="">My reasoning would be that words like filter and prefix unambiguously indicate what happens to elements of a sequence for which the predicate returns false, whereas words like where and while are ambiguous.<br class=""></div><br class=""><div class="gmail_quote"><div dir="ltr" class="">On Mon, Jun 6, 2016 at 17:52 Tim Vermeulen <<a href="mailto:tvermeulen@me.com" class="">tvermeulen@me.com</a>> wrote:<br class=""></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">I didn’t mean we should really get rid of the `where` clause, it’s great. I guess the point I was trying to make is that we can use a `where` clause with a `for` loop in Swift, despite the existence of the `filter` method. So despite `prefix(while:)` in Swift 3, there might be room for a `while` clause. I think it makes the code a lot more readable, much like how `where` can make a `for` loop a lot more readable than using `filter`.<br class="">
<br class="">
> The burden of proof for adding new features is different from that for taking away existing features.<br class="">
><br class="">
> If a feature doesn't yet exist, a successful proposal will show how it provides additional and non-trivial utility. If a feature already exists, a successful proposal to remove it will show how it is harmful to the language or contrary to the direction in which it is evolving.<br class="">
><br class="">
> On Mon, Jun 6, 2016 at 15:38 Tim Vermeulen<<a href="mailto:tvermeulen@me.com" target="_blank" class="">tvermeulen@me.com</a>(mailto:<a href="mailto:tvermeulen@me.com" target="_blank" class="">tvermeulen@me.com</a>)>wrote:<br class="">
> > The functionality of the `where` clause in `for` loops also already can be mimicked using `filter`. Wouldn’t we have to get ride of the `where` clause by that logic?<br class="">
> ><br class="">
> > >The functionality being asked for here is already accepted for inclusion to Swift as a method on Sequence named `prefix(while:)` (SE-0045):<br class="">
> > ><br class="">
> > >`for element in array.prefix(while: { someCondition($0) }) { ... }`<br class="">
> > >On Mon, Jun 6, 2016 at 14:31 T.J. Usiyan via swift-evolution<<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>(mailto:<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>)(mailto:<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>)>wrote:<br class="">
> > >>(As I said, I can live with `while`. I am simply presenting a potential point of confusion.)<br class="">
> > >>You aren't evaluating the statements in the loop 'while' the condition isn't met. The first time that the condition isn't met, evaluation of the loop stops. I get that this is technically true for the `while` construct but I suggest that the only reason that it works there is that 'stopping the first time that the condition isn't met' *is* the construct. Here, we have a loop that we execute for each thing and we're tacking on/intermingling the `while` construct.<br class="">
> > >><br class="">
> > >><br class="">
> > >><br class="">
> > >>On Mon, Jun 6, 2016 at 2:19 PM, Thorsten Seitz<<a href="mailto:tseitz42@icloud.com" target="_blank" class="">tseitz42@icloud.com</a>(mailto:<a href="mailto:tseitz42@icloud.com" target="_blank" class="">tseitz42@icloud.com</a>)(mailto:<a href="mailto:tseitz42@icloud.com" target="_blank" class="">tseitz42@icloud.com</a>)>wrote:<br class="">
> > >>><br class="">
> > >>>>Am 06.06.2016 um 19:43 schrieb Tim Vermeulen via swift-evolution<<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>(mailto:<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>)(mailto:<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>)>:<br class="">
> > >>>><br class="">
> > >>>>I also considered `until`, but it would be a bit confusing that `where` makes sure a condition is met, while `until` makes sure the condition isn’t met. I think `while` makes more sense because it corresponds to `break` in the same way that `where` corresponds to `continue`.<br class="">
> > >>><br class="">
> > >>>That's a good argument! The only drawback is that `while` and `where` look quite similar at a glance.<br class="">
> > >>><br class="">
> > >>>-Thorsten<br class="">
> > >>><br class="">
> > >>>><br class="">
> > >>>>>`while`, to me, actually reads like it should do what `where` does.<br class="">
> > >>>><br class="">
> > >>>>To me, `while` reads like it should stop the loop once the condition isn’t met, just like in a while loop.<br class="">
> > >>>><br class="">
> > >>>>>I hadn't thought about `while` in this regard but wouldn't `until` make more sense? `while`, to me, actually reads like it should do what `where` does. In any case, whether it is `while` or `where`, this seems like a reasonable feature in my opinion.<br class="">
> > >>>>><br class="">
> > >>>>>TJ<br class="">
> > >>>>><br class="">
> > >>>>>On Mon, Jun 6, 2016 at 5:15 AM, Tim Vermeulen via swift-evolution<<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>(mailto:<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>)(mailto:<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>)(mailto:<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>)>wrote:<br class="">
> > >>>>>>We can already use a where clause in a for loop like this:<br class="">
> > >>>>>><br class="">
> > >>>>>>for element in array where someCondition(element) {<br class="">
> > >>>>>>// …<br class="">
> > >>>>>>}<br class="">
> > >>>>>><br class="">
> > >>>>>>which basically acts like<br class="">
> > >>>>>><br class="">
> > >>>>>>for element in array {<br class="">
> > >>>>>>guard someCondition(element) else { continue }<br class="">
> > >>>>>>// …<br class="">
> > >>>>>>}<br class="">
> > >>>>>><br class="">
> > >>>>>>Sometimes you want to break out of the loop when the condition isn’t met instead. I propose a while clause:<br class="">
> > >>>>>><br class="">
> > >>>>>>for element in array while someCondition(element) {<br class="">
> > >>>>>>// …<br class="">
> > >>>>>>}<br class="">
> > >>>>>><br class="">
> > >>>>>>which would be syntactic sugar for<br class="">
> > >>>>>><br class="">
> > >>>>>>for element in array {<br class="">
> > >>>>>>guard someCondition(element) else { break }<br class="">
> > >>>>>>…<br class="">
> > >>>>>>}<br class="">
> > >>>>>><br class="">
> > >>>>>>I can see this particularly being useful if we have a sorted array and we already know that once the condition isn’t met, it won’t be met either for subsequent elements. Another use case could be an infinite sequence that we want to cut off somewhere (which is simply not possible using a where clause).<br class="">
> > >>>>>>_______________________________________________<br class="">
> > >>>>>>swift-evolution mailing list<br class="">
> > >>>>>><a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>(mailto:<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>)(mailto:<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>)(mailto:<a href="mailto:swift-evolution@swift.org" target="_blank" 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="">
> > >>>>_______________________________________________<br class="">
> > >>>>swift-evolution mailing list<br class="">
> > >>>><a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>(mailto:<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>)(mailto:<a href="mailto:swift-evolution@swift.org" target="_blank" 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="">
> > >><br class="">
> > >>_______________________________________________<br class="">
> > >>swift-evolution mailing list<br class="">
> > >><a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>(mailto:<a href="mailto:swift-evolution@swift.org" target="_blank" class="">swift-evolution@swift.org</a>)(mailto:<a href="mailto:swift-evolution@swift.org" target="_blank" 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="">
> > ><br class="">
> > ><br class="">
> > >_______________________________________________<br class="">
> swift-evolution mailing list<br class="">
> <a href="mailto:swift-evolution@swift.org" target="_blank" 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="">
><br class="">
><br class="">
> </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>