| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- /*
- * Copyright 2021, gRPC Authors All rights reserved.
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- #if compiler(>=5.5.2) && canImport(_Concurrency)
- /// This is currently a wrapper around AsyncThrowingStream because we want to be
- /// able to swap out the implementation for something else in the future.
- @available(macOS 10.15, iOS 13, tvOS 13, watchOS 6, *)
- public struct GRPCAsyncRequestStream<Element>: AsyncSequence {
- @usableFromInline
- internal typealias _WrappedStream = PassthroughMessageSequence<Element, Error>
- @usableFromInline
- internal let _stream: _WrappedStream
- @inlinable
- internal init(_ stream: _WrappedStream) {
- self._stream = stream
- }
- @inlinable
- public func makeAsyncIterator() -> Iterator {
- Self.AsyncIterator(self._stream)
- }
- public struct Iterator: AsyncIteratorProtocol {
- @usableFromInline
- internal var iterator: _WrappedStream.AsyncIterator
- @usableFromInline
- internal init(_ stream: _WrappedStream) {
- self.iterator = stream.makeAsyncIterator()
- }
- @inlinable
- public mutating func next() async throws -> Element? {
- try await self.iterator.next()
- }
- }
- }
- #endif
|