// Licensed to the .NET Foundation under one or more agreements. // The .NET Foundation licenses this file to you under the Apache 2.0 License. // See the LICENSE file in the project root for more information. using System.Collections.Generic; using System.Threading; using System.Threading.Tasks; namespace System.Linq { public static partial class AsyncEnumerable { /// /// Computes the sum of a sequence of values. /// /// A sequence of values to calculate the sum of. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); return Core(source, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, CancellationToken cancellationToken) { var sum = 0; await foreach (int value in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { checked { sum += value; } } return sum; } } /// /// Computes the sum of a sequence of values that are obtained by invoking a transform function on each element of the input sequence. /// /// The type of the elements in the source sequence. /// A sequence of values that are used to calculate a sum. /// A transform function to apply to each element. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// or is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, Func selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func selector, CancellationToken cancellationToken) { var sum = 0; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = selector(item); checked { sum += value; } } return sum; } } internal static ValueTask SumAwaitAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item).ConfigureAwait(false); checked { sum += value; } } return sum; } } #if !NO_DEEP_CANCELLATION internal static ValueTask SumAwaitWithCancellationAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item, cancellationToken).ConfigureAwait(false); checked { sum += value; } } return sum; } } #endif /// /// Computes the sum of a sequence of values. /// /// A sequence of values to calculate the sum of. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); return Core(source, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, CancellationToken cancellationToken) { var sum = 0L; await foreach (long value in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { checked { sum += value; } } return sum; } } /// /// Computes the sum of a sequence of values that are obtained by invoking a transform function on each element of the input sequence. /// /// The type of the elements in the source sequence. /// A sequence of values that are used to calculate a sum. /// A transform function to apply to each element. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// or is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, Func selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func selector, CancellationToken cancellationToken) { var sum = 0L; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = selector(item); checked { sum += value; } } return sum; } } internal static ValueTask SumAwaitAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0L; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item).ConfigureAwait(false); checked { sum += value; } } return sum; } } #if !NO_DEEP_CANCELLATION internal static ValueTask SumAwaitWithCancellationAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0L; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item, cancellationToken).ConfigureAwait(false); checked { sum += value; } } return sum; } } #endif /// /// Computes the sum of a sequence of values. /// /// A sequence of values to calculate the sum of. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); return Core(source, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, CancellationToken cancellationToken) { var sum = 0.0f; await foreach (float value in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { sum += value; } return sum; } } /// /// Computes the sum of a sequence of values that are obtained by invoking a transform function on each element of the input sequence. /// /// The type of the elements in the source sequence. /// A sequence of values that are used to calculate a sum. /// A transform function to apply to each element. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// or is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, Func selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func selector, CancellationToken cancellationToken) { var sum = 0.0f; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = selector(item); sum += value; } return sum; } } internal static ValueTask SumAwaitAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0.0f; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item).ConfigureAwait(false); sum += value; } return sum; } } #if !NO_DEEP_CANCELLATION internal static ValueTask SumAwaitWithCancellationAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0.0f; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item, cancellationToken).ConfigureAwait(false); sum += value; } return sum; } } #endif /// /// Computes the sum of a sequence of values. /// /// A sequence of values to calculate the sum of. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); return Core(source, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, CancellationToken cancellationToken) { var sum = 0.0; await foreach (double value in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { sum += value; } return sum; } } /// /// Computes the sum of a sequence of values that are obtained by invoking a transform function on each element of the input sequence. /// /// The type of the elements in the source sequence. /// A sequence of values that are used to calculate a sum. /// A transform function to apply to each element. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// or is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, Func selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func selector, CancellationToken cancellationToken) { var sum = 0.0; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = selector(item); sum += value; } return sum; } } internal static ValueTask SumAwaitAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0.0; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item).ConfigureAwait(false); sum += value; } return sum; } } #if !NO_DEEP_CANCELLATION internal static ValueTask SumAwaitWithCancellationAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0.0; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item, cancellationToken).ConfigureAwait(false); sum += value; } return sum; } } #endif /// /// Computes the sum of a sequence of values. /// /// A sequence of values to calculate the sum of. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); return Core(source, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, CancellationToken cancellationToken) { var sum = 0m; await foreach (decimal value in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { sum += value; } return sum; } } /// /// Computes the sum of a sequence of values that are obtained by invoking a transform function on each element of the input sequence. /// /// The type of the elements in the source sequence. /// A sequence of values that are used to calculate a sum. /// A transform function to apply to each element. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// or is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, Func selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func selector, CancellationToken cancellationToken) { var sum = 0m; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = selector(item); sum += value; } return sum; } } internal static ValueTask SumAwaitAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0m; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item).ConfigureAwait(false); sum += value; } return sum; } } #if !NO_DEEP_CANCELLATION internal static ValueTask SumAwaitWithCancellationAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0m; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item, cancellationToken).ConfigureAwait(false); sum += value; } return sum; } } #endif /// /// Computes the sum of a sequence of values. /// /// A sequence of values to calculate the sum of. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); return Core(source, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, CancellationToken cancellationToken) { var sum = 0; await foreach (int? value in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { checked { sum += value.GetValueOrDefault(); } } return sum; } } /// /// Computes the sum of a sequence of values that are obtained by invoking a transform function on each element of the input sequence. /// /// The type of the elements in the source sequence. /// A sequence of values that are used to calculate a sum. /// A transform function to apply to each element. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// or is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, Func selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func selector, CancellationToken cancellationToken) { var sum = 0; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = selector(item); checked { sum += value.GetValueOrDefault(); } } return sum; } } internal static ValueTask SumAwaitAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item).ConfigureAwait(false); checked { sum += value.GetValueOrDefault(); } } return sum; } } #if !NO_DEEP_CANCELLATION internal static ValueTask SumAwaitWithCancellationAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item, cancellationToken).ConfigureAwait(false); checked { sum += value.GetValueOrDefault(); } } return sum; } } #endif /// /// Computes the sum of a sequence of values. /// /// A sequence of values to calculate the sum of. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); return Core(source, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, CancellationToken cancellationToken) { var sum = 0L; await foreach (long? value in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { checked { sum += value.GetValueOrDefault(); } } return sum; } } /// /// Computes the sum of a sequence of values that are obtained by invoking a transform function on each element of the input sequence. /// /// The type of the elements in the source sequence. /// A sequence of values that are used to calculate a sum. /// A transform function to apply to each element. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// or is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, Func selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func selector, CancellationToken cancellationToken) { var sum = 0L; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = selector(item); checked { sum += value.GetValueOrDefault(); } } return sum; } } internal static ValueTask SumAwaitAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0L; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item).ConfigureAwait(false); checked { sum += value.GetValueOrDefault(); } } return sum; } } #if !NO_DEEP_CANCELLATION internal static ValueTask SumAwaitWithCancellationAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0L; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item, cancellationToken).ConfigureAwait(false); checked { sum += value.GetValueOrDefault(); } } return sum; } } #endif /// /// Computes the sum of a sequence of values. /// /// A sequence of values to calculate the sum of. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); return Core(source, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, CancellationToken cancellationToken) { var sum = 0.0f; await foreach (float? value in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { sum += value.GetValueOrDefault(); } return sum; } } /// /// Computes the sum of a sequence of values that are obtained by invoking a transform function on each element of the input sequence. /// /// The type of the elements in the source sequence. /// A sequence of values that are used to calculate a sum. /// A transform function to apply to each element. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// or is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, Func selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func selector, CancellationToken cancellationToken) { var sum = 0.0f; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = selector(item); sum += value.GetValueOrDefault(); } return sum; } } internal static ValueTask SumAwaitAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0.0f; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item).ConfigureAwait(false); sum += value.GetValueOrDefault(); } return sum; } } #if !NO_DEEP_CANCELLATION internal static ValueTask SumAwaitWithCancellationAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0.0f; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item, cancellationToken).ConfigureAwait(false); sum += value.GetValueOrDefault(); } return sum; } } #endif /// /// Computes the sum of a sequence of values. /// /// A sequence of values to calculate the sum of. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); return Core(source, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, CancellationToken cancellationToken) { var sum = 0.0; await foreach (double? value in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { sum += value.GetValueOrDefault(); } return sum; } } /// /// Computes the sum of a sequence of values that are obtained by invoking a transform function on each element of the input sequence. /// /// The type of the elements in the source sequence. /// A sequence of values that are used to calculate a sum. /// A transform function to apply to each element. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// or is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, Func selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func selector, CancellationToken cancellationToken) { var sum = 0.0; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = selector(item); sum += value.GetValueOrDefault(); } return sum; } } internal static ValueTask SumAwaitAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0.0; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item).ConfigureAwait(false); sum += value.GetValueOrDefault(); } return sum; } } #if !NO_DEEP_CANCELLATION internal static ValueTask SumAwaitWithCancellationAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0.0; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item, cancellationToken).ConfigureAwait(false); sum += value.GetValueOrDefault(); } return sum; } } #endif /// /// Computes the sum of a sequence of values. /// /// A sequence of values to calculate the sum of. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); return Core(source, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, CancellationToken cancellationToken) { var sum = 0m; await foreach (decimal? value in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { sum += value.GetValueOrDefault(); } return sum; } } /// /// Computes the sum of a sequence of values that are obtained by invoking a transform function on each element of the input sequence. /// /// The type of the elements in the source sequence. /// A sequence of values that are used to calculate a sum. /// A transform function to apply to each element. /// The optional cancellation token to be used for cancelling the sequence at any time. /// An async-enumerable sequence containing a single element with the sum of the values in the source sequence. /// or is null. /// The return type of this operator differs from the corresponding operator on IEnumerable in order to retain asynchronous behavior. public static ValueTask SumAsync(this IAsyncEnumerable source, Func selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func selector, CancellationToken cancellationToken) { var sum = 0m; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = selector(item); sum += value.GetValueOrDefault(); } return sum; } } internal static ValueTask SumAwaitAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0m; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item).ConfigureAwait(false); sum += value.GetValueOrDefault(); } return sum; } } #if !NO_DEEP_CANCELLATION internal static ValueTask SumAwaitWithCancellationAsyncCore(this IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken = default) { if (source == null) throw Error.ArgumentNull(nameof(source)); if (selector == null) throw Error.ArgumentNull(nameof(selector)); return Core(source, selector, cancellationToken); static async ValueTask Core(IAsyncEnumerable source, Func> selector, CancellationToken cancellationToken) { var sum = 0m; await foreach (TSource item in source.WithCancellation(cancellationToken).ConfigureAwait(false)) { var value = await selector(item, cancellationToken).ConfigureAwait(false); sum += value.GetValueOrDefault(); } return sum; } } #endif } }