// 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
}
}