1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
|
//===----------------------------------------------------------------------===//
//
// This source file is part of the Swift Async Algorithms open source project
//
// Copyright (c) 2022 Apple Inc. and the Swift project authors
// Licensed under Apache License v2.0 with Runtime Library Exception
//
// See https://swift.org/LICENSE.txt for license information
//
//===----------------------------------------------------------------------===//
final class ReportingSequence<Element>: Sequence, IteratorProtocol {
enum Event: Equatable, CustomStringConvertible {
case next
case makeIterator
var description: String {
switch self {
case .next: return "next()"
case .makeIterator: return "makeIterator()"
}
}
}
var events = [Event]()
var elements: [Element]
init(_ elements: [Element]) {
self.elements = elements
}
func next() -> Element? {
events.append(.next)
guard elements.count > 0 else {
return nil
}
return elements.removeFirst()
}
func makeIterator() -> ReportingSequence {
events.append(.makeIterator)
return self
}
}
final class ReportingAsyncSequence<Element: Sendable>: AsyncSequence, AsyncIteratorProtocol, @unchecked Sendable {
enum Event: Equatable, CustomStringConvertible {
case next
case makeAsyncIterator
var description: String {
switch self {
case .next: return "next()"
case .makeAsyncIterator: return "makeAsyncIterator()"
}
}
}
var events = [Event]()
var elements: [Element]
init(_ elements: [Element]) {
self.elements = elements
}
func next() async -> Element? {
events.append(.next)
guard elements.count > 0 else {
return nil
}
return elements.removeFirst()
}
func makeAsyncIterator() -> ReportingAsyncSequence {
events.append(.makeAsyncIterator)
return self
}
}
|