[swift-evolution] [Proposal draft] Introducing `indexed()` collections

Kevin Ballard kevin at sb.org
Thu Sep 29 13:36:17 CDT 2016


Well you kind of did say it should be removed. If we came up with a new
design that produced an Int for sequences and an Index for collections,
then you can't get an Int for collections (without wrapping the
collection in AnySequence), which is basically the same thing as just
removing enumerated() for collections.

-Kevin

On Wed, Sep 28, 2016, at 07:08 PM, Colin Barrett wrote:
> I’m aware, which is why I didn’t say it should be removed. (And if I
> hadn’t been aware, this wouldn’t have helped me discover them. :-)
>
>> On Sep 28, 2016, at 8:58 PM, Kevin Ballard <kevin at sb.org> wrote:
>>
>> There's more uses for enumerated() than just producing Array indices.
>>
>> -Kevin
>>
>> On Wed, Sep 28, 2016, at 05:49 PM, Colin Barrett via swift-
>> evolution wrote:
>>> Definitely well motivated. It seems like having both .enumerated()
>>> and .indexed() methods would still leave open the possibility of
>>> novices using .enumerated and making the same mistake as before. I
>>> realize that because of where .enumerated() sits it has to work the
>>> way it does, but is there perhaps a better design (with constrained
>>> extensions?) for a single method that can give an Int for a Sequence
>>> and an appropriate Index for a Collection?
>>>
>>> -Colin
>>>
>>>> On Sep 28, 2016, at 1:55 PM, Erica Sadun via swift-evolution <swift-
>>>> evolution at swift.org> wrote:
>>>>
>>>> Gist here:
>>>> https://gist.github.com/erica/2b2d92e6db787d001c689d3e37a7c3f2
>>>>
>>>> Introducing indexed() collections


>>>>  * Proposal: TBD
>>>>  * Author: Erica Sadun[1], Nate Cook[2], Jacob Bandes-Storch[3],
>>>>    Kevin Ballard[4]
>>>>  * Status: TBD
>>>>  * Review manager: TBD
>>>> Introduction
>>>> This proposal introduces indexed() to the standard library, a
>>>> method on collections that returns an (index, element) tuple
>>>> sequence.
>>>> Swift-evolution thread: TBD[5]
>>>> Motivation
>>>> The standard library's enumerated() method returns a sequence of
>>>> pairs enumerating a sequence. The pair's first member is a
>>>> monotonically incrementing integer starting at zero, and the second
>>>> member is the corresponding element of the sequence. When working
>>>> with arrays, the integer is coincidentally the same type and value
>>>> as an Array index but the enumerated value is not generated with
>>>> index-specific semantics. This may lead to confusion when
>>>> developers attempt to subscript a non-array collection with
>>>> enumerated integers. It can introduce serious bugs when developers
>>>> use enumerated()-based integer subscripting with non-zero-based
>>>> array slices.
>>>> Indices have a specific, fixed meaning in Swift, which are used to
>>>> create valid collection subscripts. This proposal introduces
>>>> indexed() to produce a more semantically relevant sequence by
>>>> pairing a collection's indices with its members. While it is
>>>> trivial to create a solution in Swift, the most common developer
>>>> approach shown here calculates indexes twice:


>>>> extension Collection { /// Returns a sequence of pairs (*idx*,
>>>> *x*), where *idx* represents a /// consecutive collection index,
>>>> and *x* represents an element of /// the sequence. func indexed()
>>>> -> Zip2Sequence<Self.Indices, Self> { return zip(indices, self) } }
>>>>
>>>> Incrementing an index in some collections can be unnecessarily
>>>> costly. In a lazy filtered collection, an index increment is
>>>> potentially O(N). We feel this is better addressed introducing a
>>>> new function into the Standard Library to provide a more efficient
>>>> design that avoids the attractive nuisance of the "obvious"
>>>> solution.
>>>> Detailed Design
>>>> Our vision of indexed() bypasses duplicated index generation with
>>>> their potentially high computation costs. We'd create an iterator
>>>> that calculates each index once and then applies that index to
>>>> subscript the collection. Implementation would take place through
>>>> IndexedSequence, similar to EnumeratedSequence.
>>>> Impact on Existing Code
>>>> This proposal is purely additive and has no impact on existing
>>>> code.
>>>> Alternatives Considered
>>>> Not yet
>>>> _______________________________________________
>>>> swift-evolution mailing list
>>>> swift-evolution at swift.org
>>>> https://lists.swift.org/mailman/listinfo/swift-evolution
>>>
>>> _________________________________________________
>>> swift-evolution mailing list
>>> swift-evolution at swift.org
>>> https://lists.swift.org/mailman/listinfo/swift-evolution
>>


Links:

  1. https://github.com/erica
  2. https://github.com/natecook1000
  3. https://github.com/jtbandes
  4. https://github.com/kballard
  5. https://gist.github.com/erica/tbd
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.swift.org/pipermail/swift-evolution/attachments/20160929/14e3f438/attachment.html>


More information about the swift-evolution mailing list