mirror of
https://github.com/apple/sourcekit-lsp.git
synced 2026-03-02 18:23:24 +01:00
This allows us to easily get rid of some `@_inheritActorContext`. The others seem to be a little more tricky and I haven’t spent too much time at trying to figure out how to remove the attribute from those.
90 lines
2.6 KiB
Swift
90 lines
2.6 KiB
Swift
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This source file is part of the Swift.org open source project
|
|
//
|
|
// Copyright (c) 2014 - 2020 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
|
|
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
extension Sequence {
|
|
/// Just like `Sequence.map` but allows an `async` transform function.
|
|
package func asyncMap<T>(
|
|
_ transform: (Element) async throws -> T
|
|
) async rethrows -> [T] {
|
|
var result: [T] = []
|
|
result.reserveCapacity(self.underestimatedCount)
|
|
|
|
for element in self {
|
|
try await result.append(transform(element))
|
|
}
|
|
|
|
return result
|
|
}
|
|
|
|
/// Just like `Sequence.flatMap` but allows an `async` transform function.
|
|
package func asyncFlatMap<SegmentOfResult: Sequence>(
|
|
_ transform: (Element) async throws -> SegmentOfResult
|
|
) async rethrows -> [SegmentOfResult.Element] {
|
|
var result: [SegmentOfResult.Element] = []
|
|
result.reserveCapacity(self.underestimatedCount)
|
|
|
|
for element in self {
|
|
result += try await transform(element)
|
|
}
|
|
|
|
return result
|
|
}
|
|
|
|
/// Just like `Sequence.compactMap` but allows an `async` transform function.
|
|
package func asyncCompactMap<T>(
|
|
_ transform: (Element) async throws -> T?
|
|
) async rethrows -> [T] {
|
|
var result: [T] = []
|
|
|
|
for element in self {
|
|
if let transformed = try await transform(element) {
|
|
result.append(transformed)
|
|
}
|
|
}
|
|
|
|
return result
|
|
}
|
|
|
|
/// Just like `Sequence.map` but allows an `async` transform function.
|
|
package func asyncFilter(
|
|
_ predicate: (Element) async throws -> Bool
|
|
) async rethrows -> [Element] {
|
|
var result: [Element] = []
|
|
|
|
for element in self {
|
|
if try await predicate(element) {
|
|
result.append(element)
|
|
}
|
|
}
|
|
|
|
return result
|
|
}
|
|
|
|
/// Just like `Sequence.first` but allows an `async` predicate function.
|
|
package func asyncFirst(where predicate: (Element) async throws -> Bool) async rethrows -> Element? {
|
|
for element in self {
|
|
if try await predicate(element) {
|
|
return element
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
/// Just like `Sequence.contains` but allows an `async` predicate function.
|
|
package func asyncContains(
|
|
where predicate: (Element) async throws -> Bool
|
|
) async rethrows -> Bool {
|
|
return try await asyncFirst(where: predicate) != nil
|
|
}
|
|
}
|