[swift-evolution] [Review] SE-0094: Add sequence(initial:next:) and sequence(state:next:) to the stdlib

Dave Abrahams dabrahams at apple.com
Wed May 25 17:27:14 CDT 2016


on Wed May 25 2016, Erica Sadun <erica-AT-ericasadun.com> wrote:

>  On May 25, 2016, at 2:18 PM, Kevin Ballard via swift-evolution <swift-evolution at swift.org> wrote:
>
>  We think the need to do a capture is icky, so the sequence form is
>  almost always better.
>
>  I agree that the need for a capture is ugly.
>
>  The design of AnySequence and AnyIterator dates from a time when the
>  compiler was very immature and many design avenues we might have taken
>  were not available. I find the `sequence` forms to be superior in
>  general, and IMO at some point we should re-evaluate the interfaces to
>  AnySequence and AnyIterator.
>
>  That sounds like a reasonable justification for keeping sequence(state:next:).
>
>  -Kevin Ballard
>
> I think Kevin will agree that I was really slow on uptake in terms of
> the state version, but once I *got* it, I found that I kept using
> it. Yesterday, I was showing someone some math using cubic Beziers,
> and boom there was the extra "var t = 0.0" sitting out there, which I
> immediately recognized and refactored into the sequence(state:next:)
> version instead. It produced a much cleaner and more pleasing result,
> imo. (I also found a dandy playground bug unrelated.)
>
> I know that the idea of an extra capture mentally feels ugly but it's
> really useful. A week ago, I wouldn't have fought to keep the
> option. Now, I would.

These two paragraphs sound like they're almost saying opposite things.
It's only AnyIterator/AnySequence that makes you create captures.  Care
to clarify?

-- 
-Dave


More information about the swift-evolution mailing list