You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
318 lines
13 KiB
318 lines
13 KiB
using Cysharp.Threading.Tasks.Internal; |
|
using System; |
|
using System.Collections.Generic; |
|
using System.Threading; |
|
|
|
namespace Cysharp.Threading.Tasks.Linq |
|
{ |
|
public static partial class UniTaskAsyncEnumerable |
|
{ |
|
public static UniTask<TSource> AggregateAsync<TSource>(this IUniTaskAsyncEnumerable<TSource> source, Func<TSource, TSource, TSource> accumulator, CancellationToken cancellationToken = default) |
|
{ |
|
Error.ThrowArgumentNullException(source, nameof(source)); |
|
Error.ThrowArgumentNullException(accumulator, nameof(accumulator)); |
|
|
|
return Aggregate.AggregateAsync(source, accumulator, cancellationToken); |
|
} |
|
|
|
public static UniTask<TAccumulate> AggregateAsync<TSource, TAccumulate>(this IUniTaskAsyncEnumerable<TSource> source, TAccumulate seed, Func<TAccumulate, TSource, TAccumulate> accumulator, CancellationToken cancellationToken = default) |
|
{ |
|
Error.ThrowArgumentNullException(source, nameof(source)); |
|
Error.ThrowArgumentNullException(accumulator, nameof(accumulator)); |
|
|
|
return Aggregate.AggregateAsync(source, seed, accumulator, cancellationToken); |
|
} |
|
|
|
public static UniTask<TResult> AggregateAsync<TSource, TAccumulate, TResult>(this IUniTaskAsyncEnumerable<TSource> source, TAccumulate seed, Func<TAccumulate, TSource, TAccumulate> accumulator, Func<TAccumulate, TResult> resultSelector, CancellationToken cancellationToken = default) |
|
{ |
|
Error.ThrowArgumentNullException(source, nameof(source)); |
|
Error.ThrowArgumentNullException(accumulator, nameof(accumulator)); |
|
Error.ThrowArgumentNullException(accumulator, nameof(resultSelector)); |
|
|
|
return Aggregate.AggregateAsync(source, seed, accumulator, resultSelector, cancellationToken); |
|
} |
|
|
|
public static UniTask<TSource> AggregateAwaitAsync<TSource>(this IUniTaskAsyncEnumerable<TSource> source, Func<TSource, TSource, UniTask<TSource>> accumulator, CancellationToken cancellationToken = default) |
|
{ |
|
Error.ThrowArgumentNullException(source, nameof(source)); |
|
Error.ThrowArgumentNullException(accumulator, nameof(accumulator)); |
|
|
|
return Aggregate.AggregateAwaitAsync(source, accumulator, cancellationToken); |
|
} |
|
|
|
public static UniTask<TAccumulate> AggregateAwaitAsync<TSource, TAccumulate>(this IUniTaskAsyncEnumerable<TSource> source, TAccumulate seed, Func<TAccumulate, TSource, UniTask<TAccumulate>> accumulator, CancellationToken cancellationToken = default) |
|
{ |
|
Error.ThrowArgumentNullException(source, nameof(source)); |
|
Error.ThrowArgumentNullException(accumulator, nameof(accumulator)); |
|
|
|
return Aggregate.AggregateAwaitAsync(source, seed, accumulator, cancellationToken); |
|
} |
|
|
|
public static UniTask<TResult> AggregateAwaitAsync<TSource, TAccumulate, TResult>(this IUniTaskAsyncEnumerable<TSource> source, TAccumulate seed, Func<TAccumulate, TSource, UniTask<TAccumulate>> accumulator, Func<TAccumulate, UniTask<TResult>> resultSelector, CancellationToken cancellationToken = default) |
|
{ |
|
Error.ThrowArgumentNullException(source, nameof(source)); |
|
Error.ThrowArgumentNullException(accumulator, nameof(accumulator)); |
|
Error.ThrowArgumentNullException(accumulator, nameof(resultSelector)); |
|
|
|
return Aggregate.AggregateAwaitAsync(source, seed, accumulator, resultSelector, cancellationToken); |
|
} |
|
|
|
public static UniTask<TSource> AggregateAwaitWithCancellationAsync<TSource>(this IUniTaskAsyncEnumerable<TSource> source, Func<TSource, TSource, CancellationToken, UniTask<TSource>> accumulator, CancellationToken cancellationToken = default) |
|
{ |
|
Error.ThrowArgumentNullException(source, nameof(source)); |
|
Error.ThrowArgumentNullException(accumulator, nameof(accumulator)); |
|
|
|
return Aggregate.AggregateAwaitWithCancellationAsync(source, accumulator, cancellationToken); |
|
} |
|
|
|
public static UniTask<TAccumulate> AggregateAwaitWithCancellationAsync<TSource, TAccumulate>(this IUniTaskAsyncEnumerable<TSource> source, TAccumulate seed, Func<TAccumulate, TSource, CancellationToken, UniTask<TAccumulate>> accumulator, CancellationToken cancellationToken = default) |
|
{ |
|
Error.ThrowArgumentNullException(source, nameof(source)); |
|
Error.ThrowArgumentNullException(accumulator, nameof(accumulator)); |
|
|
|
return Aggregate.AggregateAwaitWithCancellationAsync(source, seed, accumulator, cancellationToken); |
|
} |
|
|
|
public static UniTask<TResult> AggregateAwaitWithCancellationAsync<TSource, TAccumulate, TResult>(this IUniTaskAsyncEnumerable<TSource> source, TAccumulate seed, Func<TAccumulate, TSource, CancellationToken, UniTask<TAccumulate>> accumulator, Func<TAccumulate, CancellationToken, UniTask<TResult>> resultSelector, CancellationToken cancellationToken = default) |
|
{ |
|
Error.ThrowArgumentNullException(source, nameof(source)); |
|
Error.ThrowArgumentNullException(accumulator, nameof(accumulator)); |
|
Error.ThrowArgumentNullException(accumulator, nameof(resultSelector)); |
|
|
|
return Aggregate.AggregateAwaitWithCancellationAsync(source, seed, accumulator, resultSelector, cancellationToken); |
|
} |
|
} |
|
|
|
internal static class Aggregate |
|
{ |
|
internal static async UniTask<TSource> AggregateAsync<TSource>(IUniTaskAsyncEnumerable<TSource> source, Func<TSource, TSource, TSource> accumulator, CancellationToken cancellationToken) |
|
{ |
|
var e = source.GetAsyncEnumerator(cancellationToken); |
|
try |
|
{ |
|
TSource value; |
|
if (await e.MoveNextAsync()) |
|
{ |
|
value = e.Current; |
|
} |
|
else |
|
{ |
|
throw Error.NoElements(); |
|
} |
|
|
|
while (await e.MoveNextAsync()) |
|
{ |
|
value = accumulator(value, e.Current); |
|
} |
|
return value; |
|
|
|
} |
|
finally |
|
{ |
|
if (e != null) |
|
{ |
|
await e.DisposeAsync(); |
|
} |
|
} |
|
} |
|
|
|
internal static async UniTask<TAccumulate> AggregateAsync<TSource, TAccumulate>(IUniTaskAsyncEnumerable<TSource> source, TAccumulate seed, Func<TAccumulate, TSource, TAccumulate> accumulator, CancellationToken cancellationToken) |
|
{ |
|
var e = source.GetAsyncEnumerator(cancellationToken); |
|
try |
|
{ |
|
TAccumulate value = seed; |
|
while (await e.MoveNextAsync()) |
|
{ |
|
value = accumulator(value, e.Current); |
|
} |
|
return value; |
|
|
|
} |
|
finally |
|
{ |
|
if (e != null) |
|
{ |
|
await e.DisposeAsync(); |
|
} |
|
} |
|
} |
|
|
|
internal static async UniTask<TResult> AggregateAsync<TSource, TAccumulate, TResult>(IUniTaskAsyncEnumerable<TSource> source, TAccumulate seed, Func<TAccumulate, TSource, TAccumulate> accumulator, Func<TAccumulate, TResult> resultSelector, CancellationToken cancellationToken) |
|
{ |
|
var e = source.GetAsyncEnumerator(cancellationToken); |
|
try |
|
{ |
|
TAccumulate value = seed; |
|
while (await e.MoveNextAsync()) |
|
{ |
|
value = accumulator(value, e.Current); |
|
} |
|
return resultSelector(value); |
|
|
|
} |
|
finally |
|
{ |
|
if (e != null) |
|
{ |
|
await e.DisposeAsync(); |
|
} |
|
} |
|
} |
|
|
|
// with async |
|
|
|
internal static async UniTask<TSource> AggregateAwaitAsync<TSource>(IUniTaskAsyncEnumerable<TSource> source, Func<TSource, TSource, UniTask<TSource>> accumulator, CancellationToken cancellationToken) |
|
{ |
|
var e = source.GetAsyncEnumerator(cancellationToken); |
|
try |
|
{ |
|
TSource value; |
|
if (await e.MoveNextAsync()) |
|
{ |
|
value = e.Current; |
|
} |
|
else |
|
{ |
|
throw Error.NoElements(); |
|
} |
|
|
|
while (await e.MoveNextAsync()) |
|
{ |
|
value = await accumulator(value, e.Current); |
|
} |
|
return value; |
|
|
|
} |
|
finally |
|
{ |
|
if (e != null) |
|
{ |
|
await e.DisposeAsync(); |
|
} |
|
} |
|
} |
|
|
|
internal static async UniTask<TAccumulate> AggregateAwaitAsync<TSource, TAccumulate>(IUniTaskAsyncEnumerable<TSource> source, TAccumulate seed, Func<TAccumulate, TSource, UniTask<TAccumulate>> accumulator, CancellationToken cancellationToken) |
|
{ |
|
var e = source.GetAsyncEnumerator(cancellationToken); |
|
try |
|
{ |
|
TAccumulate value = seed; |
|
while (await e.MoveNextAsync()) |
|
{ |
|
value = await accumulator(value, e.Current); |
|
} |
|
return value; |
|
|
|
} |
|
finally |
|
{ |
|
if (e != null) |
|
{ |
|
await e.DisposeAsync(); |
|
} |
|
} |
|
} |
|
|
|
internal static async UniTask<TResult> AggregateAwaitAsync<TSource, TAccumulate, TResult>(IUniTaskAsyncEnumerable<TSource> source, TAccumulate seed, Func<TAccumulate, TSource, UniTask<TAccumulate>> accumulator, Func<TAccumulate, UniTask<TResult>> resultSelector, CancellationToken cancellationToken) |
|
{ |
|
var e = source.GetAsyncEnumerator(cancellationToken); |
|
try |
|
{ |
|
TAccumulate value = seed; |
|
while (await e.MoveNextAsync()) |
|
{ |
|
value = await accumulator(value, e.Current); |
|
} |
|
return await resultSelector(value); |
|
|
|
} |
|
finally |
|
{ |
|
if (e != null) |
|
{ |
|
await e.DisposeAsync(); |
|
} |
|
} |
|
} |
|
|
|
|
|
// with cancellation |
|
|
|
internal static async UniTask<TSource> AggregateAwaitWithCancellationAsync<TSource>(IUniTaskAsyncEnumerable<TSource> source, Func<TSource, TSource, CancellationToken, UniTask<TSource>> accumulator, CancellationToken cancellationToken) |
|
{ |
|
var e = source.GetAsyncEnumerator(cancellationToken); |
|
try |
|
{ |
|
TSource value; |
|
if (await e.MoveNextAsync()) |
|
{ |
|
value = e.Current; |
|
} |
|
else |
|
{ |
|
throw Error.NoElements(); |
|
} |
|
|
|
while (await e.MoveNextAsync()) |
|
{ |
|
value = await accumulator(value, e.Current, cancellationToken); |
|
} |
|
return value; |
|
|
|
} |
|
finally |
|
{ |
|
if (e != null) |
|
{ |
|
await e.DisposeAsync(); |
|
} |
|
} |
|
} |
|
|
|
internal static async UniTask<TAccumulate> AggregateAwaitWithCancellationAsync<TSource, TAccumulate>(IUniTaskAsyncEnumerable<TSource> source, TAccumulate seed, Func<TAccumulate, TSource, CancellationToken, UniTask<TAccumulate>> accumulator, CancellationToken cancellationToken) |
|
{ |
|
var e = source.GetAsyncEnumerator(cancellationToken); |
|
try |
|
{ |
|
TAccumulate value = seed; |
|
while (await e.MoveNextAsync()) |
|
{ |
|
value = await accumulator(value, e.Current, cancellationToken); |
|
} |
|
return value; |
|
|
|
} |
|
finally |
|
{ |
|
if (e != null) |
|
{ |
|
await e.DisposeAsync(); |
|
} |
|
} |
|
} |
|
|
|
internal static async UniTask<TResult> AggregateAwaitWithCancellationAsync<TSource, TAccumulate, TResult>(IUniTaskAsyncEnumerable<TSource> source, TAccumulate seed, Func<TAccumulate, TSource, CancellationToken, UniTask<TAccumulate>> accumulator, Func<TAccumulate, CancellationToken, UniTask<TResult>> resultSelector, CancellationToken cancellationToken) |
|
{ |
|
var e = source.GetAsyncEnumerator(cancellationToken); |
|
try |
|
{ |
|
TAccumulate value = seed; |
|
while (await e.MoveNextAsync()) |
|
{ |
|
value = await accumulator(value, e.Current, cancellationToken); |
|
} |
|
return await resultSelector(value, cancellationToken); |
|
|
|
} |
|
finally |
|
{ |
|
if (e != null) |
|
{ |
|
await e.DisposeAsync(); |
|
} |
|
} |
|
} |
|
} |
|
} |