Skip to content

Latest commit

 

History

History
39 lines (27 loc) · 1.34 KB

File metadata and controls

39 lines (27 loc) · 1.34 KB

AsyncSyncSequence

[Source | Tests]

Converts a non-asynchronous sequence into an asynchronous one.

This operation is available for all Sequence types.

let numbers = [1, 2, 3, 4].async
let characters = "abcde".async

This transformation can be useful to test operations specifically available on AsyncSequence but also is useful to combine with other AsyncSequence types to provide well known sources of data.

Detailed Design

The .async property returns an AsyncSyncSequence that is generic upon the base Sequence it was constructed from.

extension Sequence {
  public var async: AsyncSyncSequence<Self> { get }
}

public struct AsyncSyncSequence<Base: Sequence>: AsyncSequence {
  ...
}

extension AsyncSyncSequence: Sendable where Base: Sendable { }
extension AsyncSyncSequence.Iterator: Sendable where Base.Iterator: Sendable { }

Naming

This property's and type's name match the naming approaches in the Swift standard library. The property is named with a succinct name in inspiration from .lazy, and the type is named in reference to the lazy behavior of the constructed AsyncSequence.