Generic Structure

Publishers.TryReduce

A publisher that applies an error-throwing closure to all received elements and produces an accumulated value when the upstream publisher finishes.

Declaration

struct TryReduce<Upstream, Output> where Upstream : Publisher

Topics

Instance Properties

let initial: Output

The initial value provided on the first invocation of the closure.

let nextPartialResult: (Output, Upstream.Output) -> Output

An error-throwing closure that takes the previously-accumulated value and the next element from the upstream to produce a new value.

let upstream: Upstream

The publisher from which this publisher receives elements.

Instance Methods

func allSatisfy((Output) -> Bool) -> Publishers.AllSatisfy<Publishers.TryReduce<Upstream, Output>>

Publishes a single Boolean value that indicates whether all received elements pass a given predicate.

func assertNoFailure(String, file: StaticString, line: UInt) -> Publishers.AssertNoFailure<Publishers.TryReduce<Upstream, Output>>

Raises a fatal error when its upstream publisher fails, and otherwise republishes all received input.

func `catch`<P>((Error) -> P) -> Publishers.Catch<Publishers.TryReduce<Upstream, Output>, P>

Handles errors from an upstream publisher by replacing it with another publisher.

func collect() -> Publishers.Collect<Publishers.TryReduce<Upstream, Output>>

Collects all received elements, and emits a single array of the collection when the upstream publisher finishes.

func collect(Int) -> Publishers.CollectByCount<Publishers.TryReduce<Upstream, Output>>

Collects up to the specified number of elements, and then emits a single array of the collection.

func compactMap<T>((Output) -> T?) -> Publishers.CompactMap<Publishers.TryReduce<Upstream, Output>, T>

Calls a closure with each received element and publishes any returned optional that has a value.

func contains(Output) -> Publishers.Contains<Publishers.TryReduce<Upstream, Output>>

Publishes a Boolean value upon receiving an element equal to the argument.

func contains(where: (Output) -> Bool) -> Publishers.ContainsWhere<Publishers.TryReduce<Upstream, Output>>

Publishes a Boolean value upon receiving an element that satisfies the predicate closure.

func count() -> Publishers.Count<Publishers.TryReduce<Upstream, Output>>

Publishes the number of elements received from the upstream publisher.

func decode<Item, Coder>(type: Item.Type, decoder: Coder) -> Publishers.Decode<Publishers.TryReduce<Upstream, Output>, Item, Coder>

Decodes the output from upstream using a specified TopLevelDecoder. For example, use JSONDecoder.

func drop<P>(untilOutputFrom: P) -> Publishers.DropUntilOutput<Publishers.TryReduce<Upstream, Output>, P>

Ignores elements from the upstream publisher until it receives an element from a second publisher.

func drop(while: (Output) -> Bool) -> Publishers.DropWhile<Publishers.TryReduce<Upstream, Output>>

Omits elements from the upstream publisher until a given closure returns false, before republishing all remaining elements.

func dropFirst(Int) -> Publishers.Drop<Publishers.TryReduce<Upstream, Output>>

Omits the specified number of elements before republishing subsequent elements.

func encode<Coder>(encoder: Coder) -> Publishers.Encode<Publishers.TryReduce<Upstream, Output>, Coder>

Encodes the output from upstream using a specified TopLevelEncoder. For example, use JSONEncoder.

func first() -> Publishers.First<Publishers.TryReduce<Upstream, Output>>

Publishes the first element of a stream, then finishes.

func first(where: (Output) -> Bool) -> Publishers.FirstWhere<Publishers.TryReduce<Upstream, Output>>

Publishes the first element of a stream to satisfy a predicate closure, then finishes.

func ignoreOutput() -> Publishers.IgnoreOutput<Publishers.TryReduce<Upstream, Output>>

Ingores all upstream elements, but passes along a completion state (finished or failed).

func last() -> Publishers.Last<Publishers.TryReduce<Upstream, Output>>

Only publishes the last element of a stream, after the stream finishes.

func last(where: (Output) -> Bool) -> Publishers.LastWhere<Publishers.TryReduce<Upstream, Output>>

Only publishes the last element of a stream that satisfies a predicate closure, after the stream finishes.

func map<T>((Output) -> T) -> Publishers.Map<Publishers.TryReduce<Upstream, Output>, T>

Transforms all elements from the upstream publisher with a provided closure.

func mapError<E>((Error) -> E) -> Publishers.MapError<Publishers.TryReduce<Upstream, Output>, E>

Converts any failure from the upstream publisher into a new error.

func max() -> Publishers.Comparison<Publishers.TryReduce<Upstream, Output>>

Publishes the maximum value received from the upstream publisher, after it finishes.

func max(by: (Output, Output) -> Bool) -> Publishers.Comparison<Publishers.TryReduce<Upstream, Output>>

Publishes the maximum value received from the upstream publisher, using the provided ordering closure.

func merge(with: Publishers.TryReduce<Upstream, Output>) -> Publishers.MergeMany<Publishers.TryReduce<Upstream, Output>>

Combines elements from this publisher with those from another publisher of the same type, delivering an interleaved sequence of elements.

func merge<B, C>(with: B, C) -> Publishers.Merge3<Publishers.TryReduce<Upstream, Output>, B, C>

Combines elements from this publisher with those from two other publishers, delivering an interleaved sequence of elements.

func merge<B, C, D>(with: B, C, D) -> Publishers.Merge4<Publishers.TryReduce<Upstream, Output>, B, C, D>

Combines elements from this publisher with those from three other publishers, delivering an interleaved sequence of elements.

func merge<B, C, D, E>(with: B, C, D, E) -> Publishers.Merge5<Publishers.TryReduce<Upstream, Output>, B, C, D, E>

Combines elements from this publisher with those from four other publishers, delivering an interleaved sequence of elements.

func merge<B, C, D, E, F>(with: B, C, D, E, F) -> Publishers.Merge6<Publishers.TryReduce<Upstream, Output>, B, C, D, E, F>

Combines elements from this publisher with those from five other publishers, delivering an interleaved sequence of elements.

func merge<B, C, D, E, F, G>(with: B, C, D, E, F, G) -> Publishers.Merge7<Publishers.TryReduce<Upstream, Output>, B, C, D, E, F, G>

Combines elements from this publisher with those from six other publishers, delivering an interleaved sequence of elements.

func merge<B, C, D, E, F, G, H>(with: B, C, D, E, F, G, H) -> Publishers.Merge8<Publishers.TryReduce<Upstream, Output>, B, C, D, E, F, G, H>

Combines elements from this publisher with those from seven other publishers, delivering an interleaved sequence of elements.

func min() -> Publishers.Comparison<Publishers.TryReduce<Upstream, Output>>

Publishes the minimum value received from the upstream publisher, after it finishes.

func min(by: (Output, Output) -> Bool) -> Publishers.Comparison<Publishers.TryReduce<Upstream, Output>>

Publishes the minimum value received from the upstream publisher, after it finishes.

func output(at: Int) -> Publishers.Output<Publishers.TryReduce<Upstream, Output>>

Publishes a specific element, indicated by its index in the sequence of published elements.

func output<R>(in: R) -> Publishers.Output<Publishers.TryReduce<Upstream, Output>>

Publishes elements specified by their range in the sequence of published elements.

func prefix(Int) -> Publishers.Output<Publishers.TryReduce<Upstream, Output>>

Republishes elements up to the specified maximum count.

func prefix(while: (Output) -> Bool) -> Publishers.PrefixWhile<Publishers.TryReduce<Upstream, Output>>

Republishes elements while a predicate closure indicates publishing should continue.

func reduce<T>(T, (T, Output) -> T) -> Publishers.Reduce<Publishers.TryReduce<Upstream, Output>, T>

Applies a closure that accumulates each element of a stream and publishes a final result upon completion.

func removeDuplicates() -> Publishers.RemoveDuplicates<Publishers.TryReduce<Upstream, Output>>

Publishes only elements that don’t match the previous element.

func replaceNil<T>(with: T) -> Publishers.Map<Publishers.TryReduce<Upstream, Output>, T>

Replaces nil elements in the stream with the proviced element.

func retry(Int) -> Publishers.Retry<Publishers.TryReduce<Upstream, Output>>

Attempts to recreate a failed subscription with the upstream publisher using a specified number of attempts to establish the connection.

func scan<T>(T, (T, Output) -> T) -> Publishers.Scan<Publishers.TryReduce<Upstream, Output>, T>

Transforms elements from the upstream publisher by providing the current element to a closure along with the last value returned by the closure.

func subscribe<S>(S) -> AnyCancellable

Attaches the specified Subscriber to this Publisher.

func subscribe<S>(S)

Attaches the specified subscriber to this publisher.

func subscribe<S>(on: S, options: S.SchedulerOptions?) -> Publishers.SubscribeOn<Publishers.TryReduce<Upstream, Output>, S>

Specifies the scheduler on which to perform subscribe, cancel, and request operations.

func switchToLatest() -> Publishers.SwitchToLatest<Output, Publishers.TryReduce<Upstream, Output>>

Flattens the stream of events from multiple upstream publishers to appear as if they were coming from a single stream of events.

func throttle<S>(for: S.SchedulerTimeType.Stride, scheduler: S, latest: Bool) -> Publishers.Throttle<Publishers.TryReduce<Upstream, Output>, S>

Publishes either the most-recent or first element published by the upstream publisher in the specified time interval.

func tryAllSatisfy((Output) -> Bool) -> Publishers.TryAllSatisfy<Publishers.TryReduce<Upstream, Output>>

Publishes a single Boolean value that indicates whether all received elements pass a given error-throwing predicate.

func tryCompactMap<T>((Output) -> T?) -> Publishers.TryCompactMap<Publishers.TryReduce<Upstream, Output>, T>

Calls an error-throwing closure with each received element and publishes any returned optional that has a value.

func tryContains(where: (Output) -> Bool) -> Publishers.TryContainsWhere<Publishers.TryReduce<Upstream, Output>>

Publishes a Boolean value upon receiving an element that satisfies the throwing predicate closure.

func tryDrop(while: (Output) -> Bool) -> Publishers.TryDropWhile<Publishers.TryReduce<Upstream, Output>>

Omits elements from the upstream publisher until an error-throwing closure returns false, before republishing all remaining elements.

func tryFilter((Output) -> Bool) -> Publishers.TryFilter<Publishers.TryReduce<Upstream, Output>>

Republishes all elements that match a provided error-throwing closure.

func tryFirst(where: (Output) -> Bool) -> Publishers.TryFirstWhere<Publishers.TryReduce<Upstream, Output>>

Publishes the first element of a stream to satisfy a throwing predicate closure, then finishes.

func tryLast(where: (Output) -> Bool) -> Publishers.TryLastWhere<Publishers.TryReduce<Upstream, Output>>

Only publishes the last element of a stream that satisfies a error-throwing predicate closure, after the stream finishes.

func tryMap<T>((Output) -> T) -> Publishers.TryMap<Publishers.TryReduce<Upstream, Output>, T>

Transforms all elements from the upstream publisher with a provided error-throwing closure.

func tryMax(by: (Output, Output) -> Bool) -> Publishers.TryComparison<Publishers.TryReduce<Upstream, Output>>

Publishes the maximum value received from the upstream publisher, using the provided error-throwing closure to order the items.

func tryMin(by: (Output, Output) -> Bool) -> Publishers.TryComparison<Publishers.TryReduce<Upstream, Output>>

Publishes the minimum value received from the upstream publisher, using the provided error-throwing closure to order the items.

func tryPrefix(while: (Output) -> Bool) -> Publishers.TryPrefixWhile<Publishers.TryReduce<Upstream, Output>>

Republishes elements while a error-throwing predicate closure indicates publishing should continue.

func tryReduce<T>(T, (T, Output) -> T) -> Publishers.TryReduce<Publishers.TryReduce<Upstream, Output>, T>

Applies an error-throwing closure that accumulates each element of a stream and publishes a final result upon completion.

func tryScan<T>(T, (T, Output) -> T) -> Publishers.TryScan<Publishers.TryReduce<Upstream, Output>, T>

Transforms elements from the upstream publisher by providing the current element to an error-throwing closure along with the last value returned by the closure.

func zip<P>(P) -> Publishers.Zip<Publishers.TryReduce<Upstream, Output>, P>

Combine elements from another publisher and deliver pairs of elements as tuples.

func zip<P, Q>(P, Q) -> Publishers.Zip3<Publishers.TryReduce<Upstream, Output>, P, Q>

Combine elements from two other publishers and deliver groups of elements as tuples.

func zip<P, Q, R>(P, Q, R) -> Publishers.Zip4<Publishers.TryReduce<Upstream, Output>, P, Q, R>

Combine elements from three other publishers and deliver groups of elements as tuples.

Relationships

Conforms To

See Also

Reducing Elements

struct Publishers.Collect

A publisher that buffers items.

Beta
struct Publishers.CollectByCount

A publisher that buffers a maximum number of items.

Beta
struct Publishers.CollectByTime

A publisher that buffers and periodically publishes its items.

Beta
enum Publishers.TimeGroupingStrategy

A strategy for collecting received elements.

Beta
struct Publishers.IgnoreOutput

A publisher that ignores all upstream elements, but passes along a completion state (finish or failed).

Beta
struct Publishers.Reduce

A publisher that applies a closure to all received elements and produces an accumulated value when the upstream publisher finishes.

Beta

Beta Software

This documentation contains preliminary information about an API or technology in development. This information is subject to change, and software implemented according to this documentation should be tested with final operating system software.

Learn more about using Apple's beta software