|
- #pragma warning disable CS1591 // Missing XML comment for publicly visible type or member
- using System;
- using System.Runtime.CompilerServices;
- using System.Runtime.ExceptionServices;
- using System.Threading;
- using Cysharp.Threading.Tasks.Internal;
-
- namespace Cysharp.Threading.Tasks
- {
- public partial struct UniTask
- {
-
- public static UniTask<(T1, T2)> WhenAll<T1, T2>(UniTask<T1> task1, UniTask<T2> task2)
- {
- if (task1.Status.IsCompletedSuccessfully() && task2.Status.IsCompletedSuccessfully())
- {
- return new UniTask<(T1, T2)>((task1.GetAwaiter().GetResult(), task2.GetAwaiter().GetResult()));
- }
-
- return new UniTask<(T1, T2)>(new WhenAllPromise<T1, T2>(task1, task2), 0);
- }
-
- sealed class WhenAllPromise<T1, T2> : IUniTaskSource<(T1, T2)>
- {
- T1 t1 = default;
- T2 t2 = default;
- int completedCount;
- UniTaskCompletionSourceCore<(T1, T2)> core;
-
- public WhenAllPromise(UniTask<T1> task1, UniTask<T2> task2)
- {
- TaskTracker.TrackActiveTask(this, 3);
-
- this.completedCount = 0;
- {
- var awaiter = task1.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT1(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2>, UniTask<T1>.Awaiter>)state)
- {
- TryInvokeContinuationT1(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task2.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT2(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2>, UniTask<T2>.Awaiter>)state)
- {
- TryInvokeContinuationT2(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- }
-
- static void TryInvokeContinuationT1(WhenAllPromise<T1, T2> self, in UniTask<T1>.Awaiter awaiter)
- {
- try
- {
- self.t1 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 2)
- {
- self.core.TrySetResult((self.t1, self.t2));
- }
- }
-
- static void TryInvokeContinuationT2(WhenAllPromise<T1, T2> self, in UniTask<T2>.Awaiter awaiter)
- {
- try
- {
- self.t2 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 2)
- {
- self.core.TrySetResult((self.t1, self.t2));
- }
- }
-
-
- public (T1, T2) GetResult(short token)
- {
- TaskTracker.RemoveTracking(this);
- GC.SuppressFinalize(this);
- return core.GetResult(token);
- }
-
- void IUniTaskSource.GetResult(short token)
- {
- GetResult(token);
- }
-
- public UniTaskStatus GetStatus(short token)
- {
- return core.GetStatus(token);
- }
-
- public UniTaskStatus UnsafeGetStatus()
- {
- return core.UnsafeGetStatus();
- }
-
- public void OnCompleted(Action<object> continuation, object state, short token)
- {
- core.OnCompleted(continuation, state, token);
- }
- }
-
- public static UniTask<(T1, T2, T3)> WhenAll<T1, T2, T3>(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3)
- {
- if (task1.Status.IsCompletedSuccessfully() && task2.Status.IsCompletedSuccessfully() && task3.Status.IsCompletedSuccessfully())
- {
- return new UniTask<(T1, T2, T3)>((task1.GetAwaiter().GetResult(), task2.GetAwaiter().GetResult(), task3.GetAwaiter().GetResult()));
- }
-
- return new UniTask<(T1, T2, T3)>(new WhenAllPromise<T1, T2, T3>(task1, task2, task3), 0);
- }
-
- sealed class WhenAllPromise<T1, T2, T3> : IUniTaskSource<(T1, T2, T3)>
- {
- T1 t1 = default;
- T2 t2 = default;
- T3 t3 = default;
- int completedCount;
- UniTaskCompletionSourceCore<(T1, T2, T3)> core;
-
- public WhenAllPromise(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3)
- {
- TaskTracker.TrackActiveTask(this, 3);
-
- this.completedCount = 0;
- {
- var awaiter = task1.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT1(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3>, UniTask<T1>.Awaiter>)state)
- {
- TryInvokeContinuationT1(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task2.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT2(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3>, UniTask<T2>.Awaiter>)state)
- {
- TryInvokeContinuationT2(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task3.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT3(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3>, UniTask<T3>.Awaiter>)state)
- {
- TryInvokeContinuationT3(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- }
-
- static void TryInvokeContinuationT1(WhenAllPromise<T1, T2, T3> self, in UniTask<T1>.Awaiter awaiter)
- {
- try
- {
- self.t1 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 3)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3));
- }
- }
-
- static void TryInvokeContinuationT2(WhenAllPromise<T1, T2, T3> self, in UniTask<T2>.Awaiter awaiter)
- {
- try
- {
- self.t2 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 3)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3));
- }
- }
-
- static void TryInvokeContinuationT3(WhenAllPromise<T1, T2, T3> self, in UniTask<T3>.Awaiter awaiter)
- {
- try
- {
- self.t3 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 3)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3));
- }
- }
-
-
- public (T1, T2, T3) GetResult(short token)
- {
- TaskTracker.RemoveTracking(this);
- GC.SuppressFinalize(this);
- return core.GetResult(token);
- }
-
- void IUniTaskSource.GetResult(short token)
- {
- GetResult(token);
- }
-
- public UniTaskStatus GetStatus(short token)
- {
- return core.GetStatus(token);
- }
-
- public UniTaskStatus UnsafeGetStatus()
- {
- return core.UnsafeGetStatus();
- }
-
- public void OnCompleted(Action<object> continuation, object state, short token)
- {
- core.OnCompleted(continuation, state, token);
- }
- }
-
- public static UniTask<(T1, T2, T3, T4)> WhenAll<T1, T2, T3, T4>(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4)
- {
- if (task1.Status.IsCompletedSuccessfully() && task2.Status.IsCompletedSuccessfully() && task3.Status.IsCompletedSuccessfully() && task4.Status.IsCompletedSuccessfully())
- {
- return new UniTask<(T1, T2, T3, T4)>((task1.GetAwaiter().GetResult(), task2.GetAwaiter().GetResult(), task3.GetAwaiter().GetResult(), task4.GetAwaiter().GetResult()));
- }
-
- return new UniTask<(T1, T2, T3, T4)>(new WhenAllPromise<T1, T2, T3, T4>(task1, task2, task3, task4), 0);
- }
-
- sealed class WhenAllPromise<T1, T2, T3, T4> : IUniTaskSource<(T1, T2, T3, T4)>
- {
- T1 t1 = default;
- T2 t2 = default;
- T3 t3 = default;
- T4 t4 = default;
- int completedCount;
- UniTaskCompletionSourceCore<(T1, T2, T3, T4)> core;
-
- public WhenAllPromise(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4)
- {
- TaskTracker.TrackActiveTask(this, 3);
-
- this.completedCount = 0;
- {
- var awaiter = task1.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT1(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4>, UniTask<T1>.Awaiter>)state)
- {
- TryInvokeContinuationT1(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task2.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT2(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4>, UniTask<T2>.Awaiter>)state)
- {
- TryInvokeContinuationT2(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task3.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT3(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4>, UniTask<T3>.Awaiter>)state)
- {
- TryInvokeContinuationT3(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task4.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT4(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4>, UniTask<T4>.Awaiter>)state)
- {
- TryInvokeContinuationT4(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- }
-
- static void TryInvokeContinuationT1(WhenAllPromise<T1, T2, T3, T4> self, in UniTask<T1>.Awaiter awaiter)
- {
- try
- {
- self.t1 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 4)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4));
- }
- }
-
- static void TryInvokeContinuationT2(WhenAllPromise<T1, T2, T3, T4> self, in UniTask<T2>.Awaiter awaiter)
- {
- try
- {
- self.t2 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 4)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4));
- }
- }
-
- static void TryInvokeContinuationT3(WhenAllPromise<T1, T2, T3, T4> self, in UniTask<T3>.Awaiter awaiter)
- {
- try
- {
- self.t3 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 4)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4));
- }
- }
-
- static void TryInvokeContinuationT4(WhenAllPromise<T1, T2, T3, T4> self, in UniTask<T4>.Awaiter awaiter)
- {
- try
- {
- self.t4 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 4)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4));
- }
- }
-
-
- public (T1, T2, T3, T4) GetResult(short token)
- {
- TaskTracker.RemoveTracking(this);
- GC.SuppressFinalize(this);
- return core.GetResult(token);
- }
-
- void IUniTaskSource.GetResult(short token)
- {
- GetResult(token);
- }
-
- public UniTaskStatus GetStatus(short token)
- {
- return core.GetStatus(token);
- }
-
- public UniTaskStatus UnsafeGetStatus()
- {
- return core.UnsafeGetStatus();
- }
-
- public void OnCompleted(Action<object> continuation, object state, short token)
- {
- core.OnCompleted(continuation, state, token);
- }
- }
-
- public static UniTask<(T1, T2, T3, T4, T5)> WhenAll<T1, T2, T3, T4, T5>(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5)
- {
- if (task1.Status.IsCompletedSuccessfully() && task2.Status.IsCompletedSuccessfully() && task3.Status.IsCompletedSuccessfully() && task4.Status.IsCompletedSuccessfully() && task5.Status.IsCompletedSuccessfully())
- {
- return new UniTask<(T1, T2, T3, T4, T5)>((task1.GetAwaiter().GetResult(), task2.GetAwaiter().GetResult(), task3.GetAwaiter().GetResult(), task4.GetAwaiter().GetResult(), task5.GetAwaiter().GetResult()));
- }
-
- return new UniTask<(T1, T2, T3, T4, T5)>(new WhenAllPromise<T1, T2, T3, T4, T5>(task1, task2, task3, task4, task5), 0);
- }
-
- sealed class WhenAllPromise<T1, T2, T3, T4, T5> : IUniTaskSource<(T1, T2, T3, T4, T5)>
- {
- T1 t1 = default;
- T2 t2 = default;
- T3 t3 = default;
- T4 t4 = default;
- T5 t5 = default;
- int completedCount;
- UniTaskCompletionSourceCore<(T1, T2, T3, T4, T5)> core;
-
- public WhenAllPromise(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5)
- {
- TaskTracker.TrackActiveTask(this, 3);
-
- this.completedCount = 0;
- {
- var awaiter = task1.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT1(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5>, UniTask<T1>.Awaiter>)state)
- {
- TryInvokeContinuationT1(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task2.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT2(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5>, UniTask<T2>.Awaiter>)state)
- {
- TryInvokeContinuationT2(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task3.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT3(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5>, UniTask<T3>.Awaiter>)state)
- {
- TryInvokeContinuationT3(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task4.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT4(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5>, UniTask<T4>.Awaiter>)state)
- {
- TryInvokeContinuationT4(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task5.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT5(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5>, UniTask<T5>.Awaiter>)state)
- {
- TryInvokeContinuationT5(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- }
-
- static void TryInvokeContinuationT1(WhenAllPromise<T1, T2, T3, T4, T5> self, in UniTask<T1>.Awaiter awaiter)
- {
- try
- {
- self.t1 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 5)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5));
- }
- }
-
- static void TryInvokeContinuationT2(WhenAllPromise<T1, T2, T3, T4, T5> self, in UniTask<T2>.Awaiter awaiter)
- {
- try
- {
- self.t2 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 5)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5));
- }
- }
-
- static void TryInvokeContinuationT3(WhenAllPromise<T1, T2, T3, T4, T5> self, in UniTask<T3>.Awaiter awaiter)
- {
- try
- {
- self.t3 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 5)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5));
- }
- }
-
- static void TryInvokeContinuationT4(WhenAllPromise<T1, T2, T3, T4, T5> self, in UniTask<T4>.Awaiter awaiter)
- {
- try
- {
- self.t4 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 5)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5));
- }
- }
-
- static void TryInvokeContinuationT5(WhenAllPromise<T1, T2, T3, T4, T5> self, in UniTask<T5>.Awaiter awaiter)
- {
- try
- {
- self.t5 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 5)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5));
- }
- }
-
-
- public (T1, T2, T3, T4, T5) GetResult(short token)
- {
- TaskTracker.RemoveTracking(this);
- GC.SuppressFinalize(this);
- return core.GetResult(token);
- }
-
- void IUniTaskSource.GetResult(short token)
- {
- GetResult(token);
- }
-
- public UniTaskStatus GetStatus(short token)
- {
- return core.GetStatus(token);
- }
-
- public UniTaskStatus UnsafeGetStatus()
- {
- return core.UnsafeGetStatus();
- }
-
- public void OnCompleted(Action<object> continuation, object state, short token)
- {
- core.OnCompleted(continuation, state, token);
- }
- }
-
- public static UniTask<(T1, T2, T3, T4, T5, T6)> WhenAll<T1, T2, T3, T4, T5, T6>(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6)
- {
- if (task1.Status.IsCompletedSuccessfully() && task2.Status.IsCompletedSuccessfully() && task3.Status.IsCompletedSuccessfully() && task4.Status.IsCompletedSuccessfully() && task5.Status.IsCompletedSuccessfully() && task6.Status.IsCompletedSuccessfully())
- {
- return new UniTask<(T1, T2, T3, T4, T5, T6)>((task1.GetAwaiter().GetResult(), task2.GetAwaiter().GetResult(), task3.GetAwaiter().GetResult(), task4.GetAwaiter().GetResult(), task5.GetAwaiter().GetResult(), task6.GetAwaiter().GetResult()));
- }
-
- return new UniTask<(T1, T2, T3, T4, T5, T6)>(new WhenAllPromise<T1, T2, T3, T4, T5, T6>(task1, task2, task3, task4, task5, task6), 0);
- }
-
- sealed class WhenAllPromise<T1, T2, T3, T4, T5, T6> : IUniTaskSource<(T1, T2, T3, T4, T5, T6)>
- {
- T1 t1 = default;
- T2 t2 = default;
- T3 t3 = default;
- T4 t4 = default;
- T5 t5 = default;
- T6 t6 = default;
- int completedCount;
- UniTaskCompletionSourceCore<(T1, T2, T3, T4, T5, T6)> core;
-
- public WhenAllPromise(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6)
- {
- TaskTracker.TrackActiveTask(this, 3);
-
- this.completedCount = 0;
- {
- var awaiter = task1.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT1(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6>, UniTask<T1>.Awaiter>)state)
- {
- TryInvokeContinuationT1(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task2.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT2(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6>, UniTask<T2>.Awaiter>)state)
- {
- TryInvokeContinuationT2(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task3.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT3(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6>, UniTask<T3>.Awaiter>)state)
- {
- TryInvokeContinuationT3(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task4.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT4(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6>, UniTask<T4>.Awaiter>)state)
- {
- TryInvokeContinuationT4(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task5.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT5(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6>, UniTask<T5>.Awaiter>)state)
- {
- TryInvokeContinuationT5(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task6.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT6(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6>, UniTask<T6>.Awaiter>)state)
- {
- TryInvokeContinuationT6(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- }
-
- static void TryInvokeContinuationT1(WhenAllPromise<T1, T2, T3, T4, T5, T6> self, in UniTask<T1>.Awaiter awaiter)
- {
- try
- {
- self.t1 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 6)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6));
- }
- }
-
- static void TryInvokeContinuationT2(WhenAllPromise<T1, T2, T3, T4, T5, T6> self, in UniTask<T2>.Awaiter awaiter)
- {
- try
- {
- self.t2 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 6)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6));
- }
- }
-
- static void TryInvokeContinuationT3(WhenAllPromise<T1, T2, T3, T4, T5, T6> self, in UniTask<T3>.Awaiter awaiter)
- {
- try
- {
- self.t3 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 6)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6));
- }
- }
-
- static void TryInvokeContinuationT4(WhenAllPromise<T1, T2, T3, T4, T5, T6> self, in UniTask<T4>.Awaiter awaiter)
- {
- try
- {
- self.t4 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 6)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6));
- }
- }
-
- static void TryInvokeContinuationT5(WhenAllPromise<T1, T2, T3, T4, T5, T6> self, in UniTask<T5>.Awaiter awaiter)
- {
- try
- {
- self.t5 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 6)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6));
- }
- }
-
- static void TryInvokeContinuationT6(WhenAllPromise<T1, T2, T3, T4, T5, T6> self, in UniTask<T6>.Awaiter awaiter)
- {
- try
- {
- self.t6 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 6)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6));
- }
- }
-
-
- public (T1, T2, T3, T4, T5, T6) GetResult(short token)
- {
- TaskTracker.RemoveTracking(this);
- GC.SuppressFinalize(this);
- return core.GetResult(token);
- }
-
- void IUniTaskSource.GetResult(short token)
- {
- GetResult(token);
- }
-
- public UniTaskStatus GetStatus(short token)
- {
- return core.GetStatus(token);
- }
-
- public UniTaskStatus UnsafeGetStatus()
- {
- return core.UnsafeGetStatus();
- }
-
- public void OnCompleted(Action<object> continuation, object state, short token)
- {
- core.OnCompleted(continuation, state, token);
- }
- }
-
- public static UniTask<(T1, T2, T3, T4, T5, T6, T7)> WhenAll<T1, T2, T3, T4, T5, T6, T7>(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7)
- {
- if (task1.Status.IsCompletedSuccessfully() && task2.Status.IsCompletedSuccessfully() && task3.Status.IsCompletedSuccessfully() && task4.Status.IsCompletedSuccessfully() && task5.Status.IsCompletedSuccessfully() && task6.Status.IsCompletedSuccessfully() && task7.Status.IsCompletedSuccessfully())
- {
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7)>((task1.GetAwaiter().GetResult(), task2.GetAwaiter().GetResult(), task3.GetAwaiter().GetResult(), task4.GetAwaiter().GetResult(), task5.GetAwaiter().GetResult(), task6.GetAwaiter().GetResult(), task7.GetAwaiter().GetResult()));
- }
-
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7)>(new WhenAllPromise<T1, T2, T3, T4, T5, T6, T7>(task1, task2, task3, task4, task5, task6, task7), 0);
- }
-
- sealed class WhenAllPromise<T1, T2, T3, T4, T5, T6, T7> : IUniTaskSource<(T1, T2, T3, T4, T5, T6, T7)>
- {
- T1 t1 = default;
- T2 t2 = default;
- T3 t3 = default;
- T4 t4 = default;
- T5 t5 = default;
- T6 t6 = default;
- T7 t7 = default;
- int completedCount;
- UniTaskCompletionSourceCore<(T1, T2, T3, T4, T5, T6, T7)> core;
-
- public WhenAllPromise(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7)
- {
- TaskTracker.TrackActiveTask(this, 3);
-
- this.completedCount = 0;
- {
- var awaiter = task1.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT1(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7>, UniTask<T1>.Awaiter>)state)
- {
- TryInvokeContinuationT1(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task2.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT2(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7>, UniTask<T2>.Awaiter>)state)
- {
- TryInvokeContinuationT2(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task3.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT3(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7>, UniTask<T3>.Awaiter>)state)
- {
- TryInvokeContinuationT3(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task4.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT4(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7>, UniTask<T4>.Awaiter>)state)
- {
- TryInvokeContinuationT4(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task5.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT5(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7>, UniTask<T5>.Awaiter>)state)
- {
- TryInvokeContinuationT5(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task6.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT6(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7>, UniTask<T6>.Awaiter>)state)
- {
- TryInvokeContinuationT6(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task7.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT7(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7>, UniTask<T7>.Awaiter>)state)
- {
- TryInvokeContinuationT7(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- }
-
- static void TryInvokeContinuationT1(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7> self, in UniTask<T1>.Awaiter awaiter)
- {
- try
- {
- self.t1 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 7)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7));
- }
- }
-
- static void TryInvokeContinuationT2(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7> self, in UniTask<T2>.Awaiter awaiter)
- {
- try
- {
- self.t2 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 7)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7));
- }
- }
-
- static void TryInvokeContinuationT3(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7> self, in UniTask<T3>.Awaiter awaiter)
- {
- try
- {
- self.t3 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 7)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7));
- }
- }
-
- static void TryInvokeContinuationT4(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7> self, in UniTask<T4>.Awaiter awaiter)
- {
- try
- {
- self.t4 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 7)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7));
- }
- }
-
- static void TryInvokeContinuationT5(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7> self, in UniTask<T5>.Awaiter awaiter)
- {
- try
- {
- self.t5 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 7)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7));
- }
- }
-
- static void TryInvokeContinuationT6(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7> self, in UniTask<T6>.Awaiter awaiter)
- {
- try
- {
- self.t6 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 7)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7));
- }
- }
-
- static void TryInvokeContinuationT7(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7> self, in UniTask<T7>.Awaiter awaiter)
- {
- try
- {
- self.t7 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 7)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7));
- }
- }
-
-
- public (T1, T2, T3, T4, T5, T6, T7) GetResult(short token)
- {
- TaskTracker.RemoveTracking(this);
- GC.SuppressFinalize(this);
- return core.GetResult(token);
- }
-
- void IUniTaskSource.GetResult(short token)
- {
- GetResult(token);
- }
-
- public UniTaskStatus GetStatus(short token)
- {
- return core.GetStatus(token);
- }
-
- public UniTaskStatus UnsafeGetStatus()
- {
- return core.UnsafeGetStatus();
- }
-
- public void OnCompleted(Action<object> continuation, object state, short token)
- {
- core.OnCompleted(continuation, state, token);
- }
- }
-
- public static UniTask<(T1, T2, T3, T4, T5, T6, T7, T8)> WhenAll<T1, T2, T3, T4, T5, T6, T7, T8>(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8)
- {
- if (task1.Status.IsCompletedSuccessfully() && task2.Status.IsCompletedSuccessfully() && task3.Status.IsCompletedSuccessfully() && task4.Status.IsCompletedSuccessfully() && task5.Status.IsCompletedSuccessfully() && task6.Status.IsCompletedSuccessfully() && task7.Status.IsCompletedSuccessfully() && task8.Status.IsCompletedSuccessfully())
- {
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8)>((task1.GetAwaiter().GetResult(), task2.GetAwaiter().GetResult(), task3.GetAwaiter().GetResult(), task4.GetAwaiter().GetResult(), task5.GetAwaiter().GetResult(), task6.GetAwaiter().GetResult(), task7.GetAwaiter().GetResult(), task8.GetAwaiter().GetResult()));
- }
-
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8)>(new WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8>(task1, task2, task3, task4, task5, task6, task7, task8), 0);
- }
-
- sealed class WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8> : IUniTaskSource<(T1, T2, T3, T4, T5, T6, T7, T8)>
- {
- T1 t1 = default;
- T2 t2 = default;
- T3 t3 = default;
- T4 t4 = default;
- T5 t5 = default;
- T6 t6 = default;
- T7 t7 = default;
- T8 t8 = default;
- int completedCount;
- UniTaskCompletionSourceCore<(T1, T2, T3, T4, T5, T6, T7, T8)> core;
-
- public WhenAllPromise(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8)
- {
- TaskTracker.TrackActiveTask(this, 3);
-
- this.completedCount = 0;
- {
- var awaiter = task1.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT1(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8>, UniTask<T1>.Awaiter>)state)
- {
- TryInvokeContinuationT1(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task2.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT2(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8>, UniTask<T2>.Awaiter>)state)
- {
- TryInvokeContinuationT2(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task3.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT3(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8>, UniTask<T3>.Awaiter>)state)
- {
- TryInvokeContinuationT3(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task4.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT4(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8>, UniTask<T4>.Awaiter>)state)
- {
- TryInvokeContinuationT4(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task5.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT5(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8>, UniTask<T5>.Awaiter>)state)
- {
- TryInvokeContinuationT5(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task6.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT6(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8>, UniTask<T6>.Awaiter>)state)
- {
- TryInvokeContinuationT6(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task7.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT7(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8>, UniTask<T7>.Awaiter>)state)
- {
- TryInvokeContinuationT7(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task8.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT8(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8>, UniTask<T8>.Awaiter>)state)
- {
- TryInvokeContinuationT8(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- }
-
- static void TryInvokeContinuationT1(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8> self, in UniTask<T1>.Awaiter awaiter)
- {
- try
- {
- self.t1 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 8)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8));
- }
- }
-
- static void TryInvokeContinuationT2(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8> self, in UniTask<T2>.Awaiter awaiter)
- {
- try
- {
- self.t2 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 8)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8));
- }
- }
-
- static void TryInvokeContinuationT3(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8> self, in UniTask<T3>.Awaiter awaiter)
- {
- try
- {
- self.t3 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 8)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8));
- }
- }
-
- static void TryInvokeContinuationT4(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8> self, in UniTask<T4>.Awaiter awaiter)
- {
- try
- {
- self.t4 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 8)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8));
- }
- }
-
- static void TryInvokeContinuationT5(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8> self, in UniTask<T5>.Awaiter awaiter)
- {
- try
- {
- self.t5 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 8)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8));
- }
- }
-
- static void TryInvokeContinuationT6(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8> self, in UniTask<T6>.Awaiter awaiter)
- {
- try
- {
- self.t6 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 8)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8));
- }
- }
-
- static void TryInvokeContinuationT7(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8> self, in UniTask<T7>.Awaiter awaiter)
- {
- try
- {
- self.t7 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 8)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8));
- }
- }
-
- static void TryInvokeContinuationT8(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8> self, in UniTask<T8>.Awaiter awaiter)
- {
- try
- {
- self.t8 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 8)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8));
- }
- }
-
-
- public (T1, T2, T3, T4, T5, T6, T7, T8) GetResult(short token)
- {
- TaskTracker.RemoveTracking(this);
- GC.SuppressFinalize(this);
- return core.GetResult(token);
- }
-
- void IUniTaskSource.GetResult(short token)
- {
- GetResult(token);
- }
-
- public UniTaskStatus GetStatus(short token)
- {
- return core.GetStatus(token);
- }
-
- public UniTaskStatus UnsafeGetStatus()
- {
- return core.UnsafeGetStatus();
- }
-
- public void OnCompleted(Action<object> continuation, object state, short token)
- {
- core.OnCompleted(continuation, state, token);
- }
- }
-
- public static UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9)> WhenAll<T1, T2, T3, T4, T5, T6, T7, T8, T9>(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8, UniTask<T9> task9)
- {
- if (task1.Status.IsCompletedSuccessfully() && task2.Status.IsCompletedSuccessfully() && task3.Status.IsCompletedSuccessfully() && task4.Status.IsCompletedSuccessfully() && task5.Status.IsCompletedSuccessfully() && task6.Status.IsCompletedSuccessfully() && task7.Status.IsCompletedSuccessfully() && task8.Status.IsCompletedSuccessfully() && task9.Status.IsCompletedSuccessfully())
- {
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9)>((task1.GetAwaiter().GetResult(), task2.GetAwaiter().GetResult(), task3.GetAwaiter().GetResult(), task4.GetAwaiter().GetResult(), task5.GetAwaiter().GetResult(), task6.GetAwaiter().GetResult(), task7.GetAwaiter().GetResult(), task8.GetAwaiter().GetResult(), task9.GetAwaiter().GetResult()));
- }
-
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9)>(new WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9>(task1, task2, task3, task4, task5, task6, task7, task8, task9), 0);
- }
-
- sealed class WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9> : IUniTaskSource<(T1, T2, T3, T4, T5, T6, T7, T8, T9)>
- {
- T1 t1 = default;
- T2 t2 = default;
- T3 t3 = default;
- T4 t4 = default;
- T5 t5 = default;
- T6 t6 = default;
- T7 t7 = default;
- T8 t8 = default;
- T9 t9 = default;
- int completedCount;
- UniTaskCompletionSourceCore<(T1, T2, T3, T4, T5, T6, T7, T8, T9)> core;
-
- public WhenAllPromise(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8, UniTask<T9> task9)
- {
- TaskTracker.TrackActiveTask(this, 3);
-
- this.completedCount = 0;
- {
- var awaiter = task1.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT1(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9>, UniTask<T1>.Awaiter>)state)
- {
- TryInvokeContinuationT1(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task2.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT2(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9>, UniTask<T2>.Awaiter>)state)
- {
- TryInvokeContinuationT2(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task3.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT3(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9>, UniTask<T3>.Awaiter>)state)
- {
- TryInvokeContinuationT3(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task4.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT4(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9>, UniTask<T4>.Awaiter>)state)
- {
- TryInvokeContinuationT4(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task5.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT5(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9>, UniTask<T5>.Awaiter>)state)
- {
- TryInvokeContinuationT5(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task6.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT6(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9>, UniTask<T6>.Awaiter>)state)
- {
- TryInvokeContinuationT6(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task7.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT7(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9>, UniTask<T7>.Awaiter>)state)
- {
- TryInvokeContinuationT7(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task8.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT8(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9>, UniTask<T8>.Awaiter>)state)
- {
- TryInvokeContinuationT8(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task9.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT9(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9>, UniTask<T9>.Awaiter>)state)
- {
- TryInvokeContinuationT9(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- }
-
- static void TryInvokeContinuationT1(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9> self, in UniTask<T1>.Awaiter awaiter)
- {
- try
- {
- self.t1 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 9)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9));
- }
- }
-
- static void TryInvokeContinuationT2(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9> self, in UniTask<T2>.Awaiter awaiter)
- {
- try
- {
- self.t2 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 9)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9));
- }
- }
-
- static void TryInvokeContinuationT3(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9> self, in UniTask<T3>.Awaiter awaiter)
- {
- try
- {
- self.t3 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 9)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9));
- }
- }
-
- static void TryInvokeContinuationT4(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9> self, in UniTask<T4>.Awaiter awaiter)
- {
- try
- {
- self.t4 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 9)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9));
- }
- }
-
- static void TryInvokeContinuationT5(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9> self, in UniTask<T5>.Awaiter awaiter)
- {
- try
- {
- self.t5 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 9)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9));
- }
- }
-
- static void TryInvokeContinuationT6(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9> self, in UniTask<T6>.Awaiter awaiter)
- {
- try
- {
- self.t6 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 9)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9));
- }
- }
-
- static void TryInvokeContinuationT7(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9> self, in UniTask<T7>.Awaiter awaiter)
- {
- try
- {
- self.t7 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 9)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9));
- }
- }
-
- static void TryInvokeContinuationT8(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9> self, in UniTask<T8>.Awaiter awaiter)
- {
- try
- {
- self.t8 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 9)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9));
- }
- }
-
- static void TryInvokeContinuationT9(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9> self, in UniTask<T9>.Awaiter awaiter)
- {
- try
- {
- self.t9 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 9)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9));
- }
- }
-
-
- public (T1, T2, T3, T4, T5, T6, T7, T8, T9) GetResult(short token)
- {
- TaskTracker.RemoveTracking(this);
- GC.SuppressFinalize(this);
- return core.GetResult(token);
- }
-
- void IUniTaskSource.GetResult(short token)
- {
- GetResult(token);
- }
-
- public UniTaskStatus GetStatus(short token)
- {
- return core.GetStatus(token);
- }
-
- public UniTaskStatus UnsafeGetStatus()
- {
- return core.UnsafeGetStatus();
- }
-
- public void OnCompleted(Action<object> continuation, object state, short token)
- {
- core.OnCompleted(continuation, state, token);
- }
- }
-
- public static UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10)> WhenAll<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8, UniTask<T9> task9, UniTask<T10> task10)
- {
- if (task1.Status.IsCompletedSuccessfully() && task2.Status.IsCompletedSuccessfully() && task3.Status.IsCompletedSuccessfully() && task4.Status.IsCompletedSuccessfully() && task5.Status.IsCompletedSuccessfully() && task6.Status.IsCompletedSuccessfully() && task7.Status.IsCompletedSuccessfully() && task8.Status.IsCompletedSuccessfully() && task9.Status.IsCompletedSuccessfully() && task10.Status.IsCompletedSuccessfully())
- {
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10)>((task1.GetAwaiter().GetResult(), task2.GetAwaiter().GetResult(), task3.GetAwaiter().GetResult(), task4.GetAwaiter().GetResult(), task5.GetAwaiter().GetResult(), task6.GetAwaiter().GetResult(), task7.GetAwaiter().GetResult(), task8.GetAwaiter().GetResult(), task9.GetAwaiter().GetResult(), task10.GetAwaiter().GetResult()));
- }
-
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10)>(new WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>(task1, task2, task3, task4, task5, task6, task7, task8, task9, task10), 0);
- }
-
- sealed class WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> : IUniTaskSource<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10)>
- {
- T1 t1 = default;
- T2 t2 = default;
- T3 t3 = default;
- T4 t4 = default;
- T5 t5 = default;
- T6 t6 = default;
- T7 t7 = default;
- T8 t8 = default;
- T9 t9 = default;
- T10 t10 = default;
- int completedCount;
- UniTaskCompletionSourceCore<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10)> core;
-
- public WhenAllPromise(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8, UniTask<T9> task9, UniTask<T10> task10)
- {
- TaskTracker.TrackActiveTask(this, 3);
-
- this.completedCount = 0;
- {
- var awaiter = task1.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT1(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>, UniTask<T1>.Awaiter>)state)
- {
- TryInvokeContinuationT1(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task2.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT2(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>, UniTask<T2>.Awaiter>)state)
- {
- TryInvokeContinuationT2(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task3.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT3(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>, UniTask<T3>.Awaiter>)state)
- {
- TryInvokeContinuationT3(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task4.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT4(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>, UniTask<T4>.Awaiter>)state)
- {
- TryInvokeContinuationT4(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task5.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT5(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>, UniTask<T5>.Awaiter>)state)
- {
- TryInvokeContinuationT5(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task6.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT6(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>, UniTask<T6>.Awaiter>)state)
- {
- TryInvokeContinuationT6(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task7.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT7(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>, UniTask<T7>.Awaiter>)state)
- {
- TryInvokeContinuationT7(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task8.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT8(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>, UniTask<T8>.Awaiter>)state)
- {
- TryInvokeContinuationT8(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task9.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT9(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>, UniTask<T9>.Awaiter>)state)
- {
- TryInvokeContinuationT9(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task10.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT10(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>, UniTask<T10>.Awaiter>)state)
- {
- TryInvokeContinuationT10(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- }
-
- static void TryInvokeContinuationT1(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> self, in UniTask<T1>.Awaiter awaiter)
- {
- try
- {
- self.t1 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 10)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10));
- }
- }
-
- static void TryInvokeContinuationT2(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> self, in UniTask<T2>.Awaiter awaiter)
- {
- try
- {
- self.t2 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 10)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10));
- }
- }
-
- static void TryInvokeContinuationT3(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> self, in UniTask<T3>.Awaiter awaiter)
- {
- try
- {
- self.t3 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 10)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10));
- }
- }
-
- static void TryInvokeContinuationT4(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> self, in UniTask<T4>.Awaiter awaiter)
- {
- try
- {
- self.t4 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 10)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10));
- }
- }
-
- static void TryInvokeContinuationT5(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> self, in UniTask<T5>.Awaiter awaiter)
- {
- try
- {
- self.t5 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 10)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10));
- }
- }
-
- static void TryInvokeContinuationT6(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> self, in UniTask<T6>.Awaiter awaiter)
- {
- try
- {
- self.t6 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 10)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10));
- }
- }
-
- static void TryInvokeContinuationT7(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> self, in UniTask<T7>.Awaiter awaiter)
- {
- try
- {
- self.t7 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 10)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10));
- }
- }
-
- static void TryInvokeContinuationT8(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> self, in UniTask<T8>.Awaiter awaiter)
- {
- try
- {
- self.t8 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 10)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10));
- }
- }
-
- static void TryInvokeContinuationT9(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> self, in UniTask<T9>.Awaiter awaiter)
- {
- try
- {
- self.t9 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 10)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10));
- }
- }
-
- static void TryInvokeContinuationT10(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10> self, in UniTask<T10>.Awaiter awaiter)
- {
- try
- {
- self.t10 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 10)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10));
- }
- }
-
-
- public (T1, T2, T3, T4, T5, T6, T7, T8, T9, T10) GetResult(short token)
- {
- TaskTracker.RemoveTracking(this);
- GC.SuppressFinalize(this);
- return core.GetResult(token);
- }
-
- void IUniTaskSource.GetResult(short token)
- {
- GetResult(token);
- }
-
- public UniTaskStatus GetStatus(short token)
- {
- return core.GetStatus(token);
- }
-
- public UniTaskStatus UnsafeGetStatus()
- {
- return core.UnsafeGetStatus();
- }
-
- public void OnCompleted(Action<object> continuation, object state, short token)
- {
- core.OnCompleted(continuation, state, token);
- }
- }
-
- public static UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11)> WhenAll<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11>(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8, UniTask<T9> task9, UniTask<T10> task10, UniTask<T11> task11)
- {
- if (task1.Status.IsCompletedSuccessfully() && task2.Status.IsCompletedSuccessfully() && task3.Status.IsCompletedSuccessfully() && task4.Status.IsCompletedSuccessfully() && task5.Status.IsCompletedSuccessfully() && task6.Status.IsCompletedSuccessfully() && task7.Status.IsCompletedSuccessfully() && task8.Status.IsCompletedSuccessfully() && task9.Status.IsCompletedSuccessfully() && task10.Status.IsCompletedSuccessfully() && task11.Status.IsCompletedSuccessfully())
- {
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11)>((task1.GetAwaiter().GetResult(), task2.GetAwaiter().GetResult(), task3.GetAwaiter().GetResult(), task4.GetAwaiter().GetResult(), task5.GetAwaiter().GetResult(), task6.GetAwaiter().GetResult(), task7.GetAwaiter().GetResult(), task8.GetAwaiter().GetResult(), task9.GetAwaiter().GetResult(), task10.GetAwaiter().GetResult(), task11.GetAwaiter().GetResult()));
- }
-
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11)>(new WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11>(task1, task2, task3, task4, task5, task6, task7, task8, task9, task10, task11), 0);
- }
-
- sealed class WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> : IUniTaskSource<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11)>
- {
- T1 t1 = default;
- T2 t2 = default;
- T3 t3 = default;
- T4 t4 = default;
- T5 t5 = default;
- T6 t6 = default;
- T7 t7 = default;
- T8 t8 = default;
- T9 t9 = default;
- T10 t10 = default;
- T11 t11 = default;
- int completedCount;
- UniTaskCompletionSourceCore<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11)> core;
-
- public WhenAllPromise(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8, UniTask<T9> task9, UniTask<T10> task10, UniTask<T11> task11)
- {
- TaskTracker.TrackActiveTask(this, 3);
-
- this.completedCount = 0;
- {
- var awaiter = task1.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT1(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11>, UniTask<T1>.Awaiter>)state)
- {
- TryInvokeContinuationT1(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task2.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT2(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11>, UniTask<T2>.Awaiter>)state)
- {
- TryInvokeContinuationT2(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task3.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT3(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11>, UniTask<T3>.Awaiter>)state)
- {
- TryInvokeContinuationT3(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task4.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT4(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11>, UniTask<T4>.Awaiter>)state)
- {
- TryInvokeContinuationT4(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task5.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT5(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11>, UniTask<T5>.Awaiter>)state)
- {
- TryInvokeContinuationT5(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task6.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT6(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11>, UniTask<T6>.Awaiter>)state)
- {
- TryInvokeContinuationT6(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task7.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT7(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11>, UniTask<T7>.Awaiter>)state)
- {
- TryInvokeContinuationT7(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task8.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT8(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11>, UniTask<T8>.Awaiter>)state)
- {
- TryInvokeContinuationT8(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task9.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT9(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11>, UniTask<T9>.Awaiter>)state)
- {
- TryInvokeContinuationT9(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task10.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT10(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11>, UniTask<T10>.Awaiter>)state)
- {
- TryInvokeContinuationT10(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task11.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT11(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11>, UniTask<T11>.Awaiter>)state)
- {
- TryInvokeContinuationT11(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- }
-
- static void TryInvokeContinuationT1(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> self, in UniTask<T1>.Awaiter awaiter)
- {
- try
- {
- self.t1 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 11)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11));
- }
- }
-
- static void TryInvokeContinuationT2(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> self, in UniTask<T2>.Awaiter awaiter)
- {
- try
- {
- self.t2 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 11)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11));
- }
- }
-
- static void TryInvokeContinuationT3(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> self, in UniTask<T3>.Awaiter awaiter)
- {
- try
- {
- self.t3 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 11)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11));
- }
- }
-
- static void TryInvokeContinuationT4(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> self, in UniTask<T4>.Awaiter awaiter)
- {
- try
- {
- self.t4 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 11)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11));
- }
- }
-
- static void TryInvokeContinuationT5(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> self, in UniTask<T5>.Awaiter awaiter)
- {
- try
- {
- self.t5 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 11)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11));
- }
- }
-
- static void TryInvokeContinuationT6(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> self, in UniTask<T6>.Awaiter awaiter)
- {
- try
- {
- self.t6 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 11)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11));
- }
- }
-
- static void TryInvokeContinuationT7(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> self, in UniTask<T7>.Awaiter awaiter)
- {
- try
- {
- self.t7 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 11)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11));
- }
- }
-
- static void TryInvokeContinuationT8(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> self, in UniTask<T8>.Awaiter awaiter)
- {
- try
- {
- self.t8 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 11)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11));
- }
- }
-
- static void TryInvokeContinuationT9(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> self, in UniTask<T9>.Awaiter awaiter)
- {
- try
- {
- self.t9 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 11)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11));
- }
- }
-
- static void TryInvokeContinuationT10(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> self, in UniTask<T10>.Awaiter awaiter)
- {
- try
- {
- self.t10 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 11)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11));
- }
- }
-
- static void TryInvokeContinuationT11(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11> self, in UniTask<T11>.Awaiter awaiter)
- {
- try
- {
- self.t11 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 11)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11));
- }
- }
-
-
- public (T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11) GetResult(short token)
- {
- TaskTracker.RemoveTracking(this);
- GC.SuppressFinalize(this);
- return core.GetResult(token);
- }
-
- void IUniTaskSource.GetResult(short token)
- {
- GetResult(token);
- }
-
- public UniTaskStatus GetStatus(short token)
- {
- return core.GetStatus(token);
- }
-
- public UniTaskStatus UnsafeGetStatus()
- {
- return core.UnsafeGetStatus();
- }
-
- public void OnCompleted(Action<object> continuation, object state, short token)
- {
- core.OnCompleted(continuation, state, token);
- }
- }
-
- public static UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12)> WhenAll<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12>(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8, UniTask<T9> task9, UniTask<T10> task10, UniTask<T11> task11, UniTask<T12> task12)
- {
- if (task1.Status.IsCompletedSuccessfully() && task2.Status.IsCompletedSuccessfully() && task3.Status.IsCompletedSuccessfully() && task4.Status.IsCompletedSuccessfully() && task5.Status.IsCompletedSuccessfully() && task6.Status.IsCompletedSuccessfully() && task7.Status.IsCompletedSuccessfully() && task8.Status.IsCompletedSuccessfully() && task9.Status.IsCompletedSuccessfully() && task10.Status.IsCompletedSuccessfully() && task11.Status.IsCompletedSuccessfully() && task12.Status.IsCompletedSuccessfully())
- {
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12)>((task1.GetAwaiter().GetResult(), task2.GetAwaiter().GetResult(), task3.GetAwaiter().GetResult(), task4.GetAwaiter().GetResult(), task5.GetAwaiter().GetResult(), task6.GetAwaiter().GetResult(), task7.GetAwaiter().GetResult(), task8.GetAwaiter().GetResult(), task9.GetAwaiter().GetResult(), task10.GetAwaiter().GetResult(), task11.GetAwaiter().GetResult(), task12.GetAwaiter().GetResult()));
- }
-
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12)>(new WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12>(task1, task2, task3, task4, task5, task6, task7, task8, task9, task10, task11, task12), 0);
- }
-
- sealed class WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> : IUniTaskSource<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12)>
- {
- T1 t1 = default;
- T2 t2 = default;
- T3 t3 = default;
- T4 t4 = default;
- T5 t5 = default;
- T6 t6 = default;
- T7 t7 = default;
- T8 t8 = default;
- T9 t9 = default;
- T10 t10 = default;
- T11 t11 = default;
- T12 t12 = default;
- int completedCount;
- UniTaskCompletionSourceCore<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12)> core;
-
- public WhenAllPromise(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8, UniTask<T9> task9, UniTask<T10> task10, UniTask<T11> task11, UniTask<T12> task12)
- {
- TaskTracker.TrackActiveTask(this, 3);
-
- this.completedCount = 0;
- {
- var awaiter = task1.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT1(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12>, UniTask<T1>.Awaiter>)state)
- {
- TryInvokeContinuationT1(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task2.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT2(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12>, UniTask<T2>.Awaiter>)state)
- {
- TryInvokeContinuationT2(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task3.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT3(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12>, UniTask<T3>.Awaiter>)state)
- {
- TryInvokeContinuationT3(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task4.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT4(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12>, UniTask<T4>.Awaiter>)state)
- {
- TryInvokeContinuationT4(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task5.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT5(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12>, UniTask<T5>.Awaiter>)state)
- {
- TryInvokeContinuationT5(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task6.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT6(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12>, UniTask<T6>.Awaiter>)state)
- {
- TryInvokeContinuationT6(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task7.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT7(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12>, UniTask<T7>.Awaiter>)state)
- {
- TryInvokeContinuationT7(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task8.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT8(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12>, UniTask<T8>.Awaiter>)state)
- {
- TryInvokeContinuationT8(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task9.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT9(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12>, UniTask<T9>.Awaiter>)state)
- {
- TryInvokeContinuationT9(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task10.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT10(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12>, UniTask<T10>.Awaiter>)state)
- {
- TryInvokeContinuationT10(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task11.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT11(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12>, UniTask<T11>.Awaiter>)state)
- {
- TryInvokeContinuationT11(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task12.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT12(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12>, UniTask<T12>.Awaiter>)state)
- {
- TryInvokeContinuationT12(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- }
-
- static void TryInvokeContinuationT1(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> self, in UniTask<T1>.Awaiter awaiter)
- {
- try
- {
- self.t1 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 12)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12));
- }
- }
-
- static void TryInvokeContinuationT2(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> self, in UniTask<T2>.Awaiter awaiter)
- {
- try
- {
- self.t2 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 12)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12));
- }
- }
-
- static void TryInvokeContinuationT3(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> self, in UniTask<T3>.Awaiter awaiter)
- {
- try
- {
- self.t3 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 12)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12));
- }
- }
-
- static void TryInvokeContinuationT4(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> self, in UniTask<T4>.Awaiter awaiter)
- {
- try
- {
- self.t4 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 12)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12));
- }
- }
-
- static void TryInvokeContinuationT5(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> self, in UniTask<T5>.Awaiter awaiter)
- {
- try
- {
- self.t5 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 12)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12));
- }
- }
-
- static void TryInvokeContinuationT6(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> self, in UniTask<T6>.Awaiter awaiter)
- {
- try
- {
- self.t6 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 12)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12));
- }
- }
-
- static void TryInvokeContinuationT7(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> self, in UniTask<T7>.Awaiter awaiter)
- {
- try
- {
- self.t7 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 12)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12));
- }
- }
-
- static void TryInvokeContinuationT8(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> self, in UniTask<T8>.Awaiter awaiter)
- {
- try
- {
- self.t8 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 12)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12));
- }
- }
-
- static void TryInvokeContinuationT9(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> self, in UniTask<T9>.Awaiter awaiter)
- {
- try
- {
- self.t9 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 12)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12));
- }
- }
-
- static void TryInvokeContinuationT10(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> self, in UniTask<T10>.Awaiter awaiter)
- {
- try
- {
- self.t10 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 12)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12));
- }
- }
-
- static void TryInvokeContinuationT11(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> self, in UniTask<T11>.Awaiter awaiter)
- {
- try
- {
- self.t11 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 12)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12));
- }
- }
-
- static void TryInvokeContinuationT12(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12> self, in UniTask<T12>.Awaiter awaiter)
- {
- try
- {
- self.t12 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 12)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12));
- }
- }
-
-
- public (T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12) GetResult(short token)
- {
- TaskTracker.RemoveTracking(this);
- GC.SuppressFinalize(this);
- return core.GetResult(token);
- }
-
- void IUniTaskSource.GetResult(short token)
- {
- GetResult(token);
- }
-
- public UniTaskStatus GetStatus(short token)
- {
- return core.GetStatus(token);
- }
-
- public UniTaskStatus UnsafeGetStatus()
- {
- return core.UnsafeGetStatus();
- }
-
- public void OnCompleted(Action<object> continuation, object state, short token)
- {
- core.OnCompleted(continuation, state, token);
- }
- }
-
- public static UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13)> WhenAll<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13>(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8, UniTask<T9> task9, UniTask<T10> task10, UniTask<T11> task11, UniTask<T12> task12, UniTask<T13> task13)
- {
- if (task1.Status.IsCompletedSuccessfully() && task2.Status.IsCompletedSuccessfully() && task3.Status.IsCompletedSuccessfully() && task4.Status.IsCompletedSuccessfully() && task5.Status.IsCompletedSuccessfully() && task6.Status.IsCompletedSuccessfully() && task7.Status.IsCompletedSuccessfully() && task8.Status.IsCompletedSuccessfully() && task9.Status.IsCompletedSuccessfully() && task10.Status.IsCompletedSuccessfully() && task11.Status.IsCompletedSuccessfully() && task12.Status.IsCompletedSuccessfully() && task13.Status.IsCompletedSuccessfully())
- {
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13)>((task1.GetAwaiter().GetResult(), task2.GetAwaiter().GetResult(), task3.GetAwaiter().GetResult(), task4.GetAwaiter().GetResult(), task5.GetAwaiter().GetResult(), task6.GetAwaiter().GetResult(), task7.GetAwaiter().GetResult(), task8.GetAwaiter().GetResult(), task9.GetAwaiter().GetResult(), task10.GetAwaiter().GetResult(), task11.GetAwaiter().GetResult(), task12.GetAwaiter().GetResult(), task13.GetAwaiter().GetResult()));
- }
-
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13)>(new WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13>(task1, task2, task3, task4, task5, task6, task7, task8, task9, task10, task11, task12, task13), 0);
- }
-
- sealed class WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13> : IUniTaskSource<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13)>
- {
- T1 t1 = default;
- T2 t2 = default;
- T3 t3 = default;
- T4 t4 = default;
- T5 t5 = default;
- T6 t6 = default;
- T7 t7 = default;
- T8 t8 = default;
- T9 t9 = default;
- T10 t10 = default;
- T11 t11 = default;
- T12 t12 = default;
- T13 t13 = default;
- int completedCount;
- UniTaskCompletionSourceCore<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13)> core;
-
- public WhenAllPromise(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8, UniTask<T9> task9, UniTask<T10> task10, UniTask<T11> task11, UniTask<T12> task12, UniTask<T13> task13)
- {
- TaskTracker.TrackActiveTask(this, 3);
-
- this.completedCount = 0;
- {
- var awaiter = task1.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT1(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13>, UniTask<T1>.Awaiter>)state)
- {
- TryInvokeContinuationT1(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task2.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT2(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13>, UniTask<T2>.Awaiter>)state)
- {
- TryInvokeContinuationT2(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task3.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT3(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13>, UniTask<T3>.Awaiter>)state)
- {
- TryInvokeContinuationT3(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task4.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT4(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13>, UniTask<T4>.Awaiter>)state)
- {
- TryInvokeContinuationT4(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task5.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT5(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13>, UniTask<T5>.Awaiter>)state)
- {
- TryInvokeContinuationT5(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task6.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT6(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13>, UniTask<T6>.Awaiter>)state)
- {
- TryInvokeContinuationT6(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task7.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT7(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13>, UniTask<T7>.Awaiter>)state)
- {
- TryInvokeContinuationT7(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task8.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT8(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13>, UniTask<T8>.Awaiter>)state)
- {
- TryInvokeContinuationT8(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task9.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT9(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13>, UniTask<T9>.Awaiter>)state)
- {
- TryInvokeContinuationT9(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task10.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT10(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13>, UniTask<T10>.Awaiter>)state)
- {
- TryInvokeContinuationT10(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task11.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT11(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13>, UniTask<T11>.Awaiter>)state)
- {
- TryInvokeContinuationT11(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task12.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT12(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13>, UniTask<T12>.Awaiter>)state)
- {
- TryInvokeContinuationT12(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task13.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT13(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13>, UniTask<T13>.Awaiter>)state)
- {
- TryInvokeContinuationT13(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- }
-
- static void TryInvokeContinuationT1(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13> self, in UniTask<T1>.Awaiter awaiter)
- {
- try
- {
- self.t1 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 13)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13));
- }
- }
-
- static void TryInvokeContinuationT2(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13> self, in UniTask<T2>.Awaiter awaiter)
- {
- try
- {
- self.t2 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 13)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13));
- }
- }
-
- static void TryInvokeContinuationT3(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13> self, in UniTask<T3>.Awaiter awaiter)
- {
- try
- {
- self.t3 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 13)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13));
- }
- }
-
- static void TryInvokeContinuationT4(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13> self, in UniTask<T4>.Awaiter awaiter)
- {
- try
- {
- self.t4 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 13)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13));
- }
- }
-
- static void TryInvokeContinuationT5(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13> self, in UniTask<T5>.Awaiter awaiter)
- {
- try
- {
- self.t5 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 13)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13));
- }
- }
-
- static void TryInvokeContinuationT6(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13> self, in UniTask<T6>.Awaiter awaiter)
- {
- try
- {
- self.t6 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 13)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13));
- }
- }
-
- static void TryInvokeContinuationT7(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13> self, in UniTask<T7>.Awaiter awaiter)
- {
- try
- {
- self.t7 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 13)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13));
- }
- }
-
- static void TryInvokeContinuationT8(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13> self, in UniTask<T8>.Awaiter awaiter)
- {
- try
- {
- self.t8 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 13)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13));
- }
- }
-
- static void TryInvokeContinuationT9(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13> self, in UniTask<T9>.Awaiter awaiter)
- {
- try
- {
- self.t9 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 13)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13));
- }
- }
-
- static void TryInvokeContinuationT10(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13> self, in UniTask<T10>.Awaiter awaiter)
- {
- try
- {
- self.t10 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 13)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13));
- }
- }
-
- static void TryInvokeContinuationT11(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13> self, in UniTask<T11>.Awaiter awaiter)
- {
- try
- {
- self.t11 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 13)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13));
- }
- }
-
- static void TryInvokeContinuationT12(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13> self, in UniTask<T12>.Awaiter awaiter)
- {
- try
- {
- self.t12 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 13)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13));
- }
- }
-
- static void TryInvokeContinuationT13(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13> self, in UniTask<T13>.Awaiter awaiter)
- {
- try
- {
- self.t13 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 13)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13));
- }
- }
-
-
- public (T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13) GetResult(short token)
- {
- TaskTracker.RemoveTracking(this);
- GC.SuppressFinalize(this);
- return core.GetResult(token);
- }
-
- void IUniTaskSource.GetResult(short token)
- {
- GetResult(token);
- }
-
- public UniTaskStatus GetStatus(short token)
- {
- return core.GetStatus(token);
- }
-
- public UniTaskStatus UnsafeGetStatus()
- {
- return core.UnsafeGetStatus();
- }
-
- public void OnCompleted(Action<object> continuation, object state, short token)
- {
- core.OnCompleted(continuation, state, token);
- }
- }
-
- public static UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14)> WhenAll<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8, UniTask<T9> task9, UniTask<T10> task10, UniTask<T11> task11, UniTask<T12> task12, UniTask<T13> task13, UniTask<T14> task14)
- {
- if (task1.Status.IsCompletedSuccessfully() && task2.Status.IsCompletedSuccessfully() && task3.Status.IsCompletedSuccessfully() && task4.Status.IsCompletedSuccessfully() && task5.Status.IsCompletedSuccessfully() && task6.Status.IsCompletedSuccessfully() && task7.Status.IsCompletedSuccessfully() && task8.Status.IsCompletedSuccessfully() && task9.Status.IsCompletedSuccessfully() && task10.Status.IsCompletedSuccessfully() && task11.Status.IsCompletedSuccessfully() && task12.Status.IsCompletedSuccessfully() && task13.Status.IsCompletedSuccessfully() && task14.Status.IsCompletedSuccessfully())
- {
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14)>((task1.GetAwaiter().GetResult(), task2.GetAwaiter().GetResult(), task3.GetAwaiter().GetResult(), task4.GetAwaiter().GetResult(), task5.GetAwaiter().GetResult(), task6.GetAwaiter().GetResult(), task7.GetAwaiter().GetResult(), task8.GetAwaiter().GetResult(), task9.GetAwaiter().GetResult(), task10.GetAwaiter().GetResult(), task11.GetAwaiter().GetResult(), task12.GetAwaiter().GetResult(), task13.GetAwaiter().GetResult(), task14.GetAwaiter().GetResult()));
- }
-
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14)>(new WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>(task1, task2, task3, task4, task5, task6, task7, task8, task9, task10, task11, task12, task13, task14), 0);
- }
-
- sealed class WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> : IUniTaskSource<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14)>
- {
- T1 t1 = default;
- T2 t2 = default;
- T3 t3 = default;
- T4 t4 = default;
- T5 t5 = default;
- T6 t6 = default;
- T7 t7 = default;
- T8 t8 = default;
- T9 t9 = default;
- T10 t10 = default;
- T11 t11 = default;
- T12 t12 = default;
- T13 t13 = default;
- T14 t14 = default;
- int completedCount;
- UniTaskCompletionSourceCore<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14)> core;
-
- public WhenAllPromise(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8, UniTask<T9> task9, UniTask<T10> task10, UniTask<T11> task11, UniTask<T12> task12, UniTask<T13> task13, UniTask<T14> task14)
- {
- TaskTracker.TrackActiveTask(this, 3);
-
- this.completedCount = 0;
- {
- var awaiter = task1.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT1(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>, UniTask<T1>.Awaiter>)state)
- {
- TryInvokeContinuationT1(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task2.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT2(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>, UniTask<T2>.Awaiter>)state)
- {
- TryInvokeContinuationT2(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task3.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT3(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>, UniTask<T3>.Awaiter>)state)
- {
- TryInvokeContinuationT3(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task4.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT4(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>, UniTask<T4>.Awaiter>)state)
- {
- TryInvokeContinuationT4(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task5.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT5(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>, UniTask<T5>.Awaiter>)state)
- {
- TryInvokeContinuationT5(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task6.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT6(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>, UniTask<T6>.Awaiter>)state)
- {
- TryInvokeContinuationT6(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task7.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT7(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>, UniTask<T7>.Awaiter>)state)
- {
- TryInvokeContinuationT7(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task8.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT8(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>, UniTask<T8>.Awaiter>)state)
- {
- TryInvokeContinuationT8(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task9.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT9(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>, UniTask<T9>.Awaiter>)state)
- {
- TryInvokeContinuationT9(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task10.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT10(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>, UniTask<T10>.Awaiter>)state)
- {
- TryInvokeContinuationT10(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task11.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT11(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>, UniTask<T11>.Awaiter>)state)
- {
- TryInvokeContinuationT11(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task12.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT12(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>, UniTask<T12>.Awaiter>)state)
- {
- TryInvokeContinuationT12(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task13.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT13(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>, UniTask<T13>.Awaiter>)state)
- {
- TryInvokeContinuationT13(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task14.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT14(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14>, UniTask<T14>.Awaiter>)state)
- {
- TryInvokeContinuationT14(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- }
-
- static void TryInvokeContinuationT1(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> self, in UniTask<T1>.Awaiter awaiter)
- {
- try
- {
- self.t1 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 14)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14));
- }
- }
-
- static void TryInvokeContinuationT2(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> self, in UniTask<T2>.Awaiter awaiter)
- {
- try
- {
- self.t2 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 14)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14));
- }
- }
-
- static void TryInvokeContinuationT3(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> self, in UniTask<T3>.Awaiter awaiter)
- {
- try
- {
- self.t3 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 14)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14));
- }
- }
-
- static void TryInvokeContinuationT4(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> self, in UniTask<T4>.Awaiter awaiter)
- {
- try
- {
- self.t4 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 14)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14));
- }
- }
-
- static void TryInvokeContinuationT5(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> self, in UniTask<T5>.Awaiter awaiter)
- {
- try
- {
- self.t5 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 14)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14));
- }
- }
-
- static void TryInvokeContinuationT6(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> self, in UniTask<T6>.Awaiter awaiter)
- {
- try
- {
- self.t6 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 14)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14));
- }
- }
-
- static void TryInvokeContinuationT7(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> self, in UniTask<T7>.Awaiter awaiter)
- {
- try
- {
- self.t7 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 14)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14));
- }
- }
-
- static void TryInvokeContinuationT8(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> self, in UniTask<T8>.Awaiter awaiter)
- {
- try
- {
- self.t8 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 14)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14));
- }
- }
-
- static void TryInvokeContinuationT9(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> self, in UniTask<T9>.Awaiter awaiter)
- {
- try
- {
- self.t9 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 14)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14));
- }
- }
-
- static void TryInvokeContinuationT10(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> self, in UniTask<T10>.Awaiter awaiter)
- {
- try
- {
- self.t10 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 14)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14));
- }
- }
-
- static void TryInvokeContinuationT11(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> self, in UniTask<T11>.Awaiter awaiter)
- {
- try
- {
- self.t11 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 14)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14));
- }
- }
-
- static void TryInvokeContinuationT12(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> self, in UniTask<T12>.Awaiter awaiter)
- {
- try
- {
- self.t12 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 14)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14));
- }
- }
-
- static void TryInvokeContinuationT13(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> self, in UniTask<T13>.Awaiter awaiter)
- {
- try
- {
- self.t13 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 14)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14));
- }
- }
-
- static void TryInvokeContinuationT14(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14> self, in UniTask<T14>.Awaiter awaiter)
- {
- try
- {
- self.t14 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 14)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14));
- }
- }
-
-
- public (T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14) GetResult(short token)
- {
- TaskTracker.RemoveTracking(this);
- GC.SuppressFinalize(this);
- return core.GetResult(token);
- }
-
- void IUniTaskSource.GetResult(short token)
- {
- GetResult(token);
- }
-
- public UniTaskStatus GetStatus(short token)
- {
- return core.GetStatus(token);
- }
-
- public UniTaskStatus UnsafeGetStatus()
- {
- return core.UnsafeGetStatus();
- }
-
- public void OnCompleted(Action<object> continuation, object state, short token)
- {
- core.OnCompleted(continuation, state, token);
- }
- }
-
- public static UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15)> WhenAll<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8, UniTask<T9> task9, UniTask<T10> task10, UniTask<T11> task11, UniTask<T12> task12, UniTask<T13> task13, UniTask<T14> task14, UniTask<T15> task15)
- {
- if (task1.Status.IsCompletedSuccessfully() && task2.Status.IsCompletedSuccessfully() && task3.Status.IsCompletedSuccessfully() && task4.Status.IsCompletedSuccessfully() && task5.Status.IsCompletedSuccessfully() && task6.Status.IsCompletedSuccessfully() && task7.Status.IsCompletedSuccessfully() && task8.Status.IsCompletedSuccessfully() && task9.Status.IsCompletedSuccessfully() && task10.Status.IsCompletedSuccessfully() && task11.Status.IsCompletedSuccessfully() && task12.Status.IsCompletedSuccessfully() && task13.Status.IsCompletedSuccessfully() && task14.Status.IsCompletedSuccessfully() && task15.Status.IsCompletedSuccessfully())
- {
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15)>((task1.GetAwaiter().GetResult(), task2.GetAwaiter().GetResult(), task3.GetAwaiter().GetResult(), task4.GetAwaiter().GetResult(), task5.GetAwaiter().GetResult(), task6.GetAwaiter().GetResult(), task7.GetAwaiter().GetResult(), task8.GetAwaiter().GetResult(), task9.GetAwaiter().GetResult(), task10.GetAwaiter().GetResult(), task11.GetAwaiter().GetResult(), task12.GetAwaiter().GetResult(), task13.GetAwaiter().GetResult(), task14.GetAwaiter().GetResult(), task15.GetAwaiter().GetResult()));
- }
-
- return new UniTask<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15)>(new WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>(task1, task2, task3, task4, task5, task6, task7, task8, task9, task10, task11, task12, task13, task14, task15), 0);
- }
-
- sealed class WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> : IUniTaskSource<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15)>
- {
- T1 t1 = default;
- T2 t2 = default;
- T3 t3 = default;
- T4 t4 = default;
- T5 t5 = default;
- T6 t6 = default;
- T7 t7 = default;
- T8 t8 = default;
- T9 t9 = default;
- T10 t10 = default;
- T11 t11 = default;
- T12 t12 = default;
- T13 t13 = default;
- T14 t14 = default;
- T15 t15 = default;
- int completedCount;
- UniTaskCompletionSourceCore<(T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15)> core;
-
- public WhenAllPromise(UniTask<T1> task1, UniTask<T2> task2, UniTask<T3> task3, UniTask<T4> task4, UniTask<T5> task5, UniTask<T6> task6, UniTask<T7> task7, UniTask<T8> task8, UniTask<T9> task9, UniTask<T10> task10, UniTask<T11> task11, UniTask<T12> task12, UniTask<T13> task13, UniTask<T14> task14, UniTask<T15> task15)
- {
- TaskTracker.TrackActiveTask(this, 3);
-
- this.completedCount = 0;
- {
- var awaiter = task1.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT1(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>, UniTask<T1>.Awaiter>)state)
- {
- TryInvokeContinuationT1(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task2.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT2(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>, UniTask<T2>.Awaiter>)state)
- {
- TryInvokeContinuationT2(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task3.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT3(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>, UniTask<T3>.Awaiter>)state)
- {
- TryInvokeContinuationT3(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task4.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT4(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>, UniTask<T4>.Awaiter>)state)
- {
- TryInvokeContinuationT4(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task5.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT5(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>, UniTask<T5>.Awaiter>)state)
- {
- TryInvokeContinuationT5(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task6.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT6(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>, UniTask<T6>.Awaiter>)state)
- {
- TryInvokeContinuationT6(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task7.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT7(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>, UniTask<T7>.Awaiter>)state)
- {
- TryInvokeContinuationT7(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task8.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT8(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>, UniTask<T8>.Awaiter>)state)
- {
- TryInvokeContinuationT8(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task9.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT9(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>, UniTask<T9>.Awaiter>)state)
- {
- TryInvokeContinuationT9(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task10.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT10(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>, UniTask<T10>.Awaiter>)state)
- {
- TryInvokeContinuationT10(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task11.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT11(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>, UniTask<T11>.Awaiter>)state)
- {
- TryInvokeContinuationT11(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task12.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT12(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>, UniTask<T12>.Awaiter>)state)
- {
- TryInvokeContinuationT12(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task13.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT13(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>, UniTask<T13>.Awaiter>)state)
- {
- TryInvokeContinuationT13(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task14.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT14(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>, UniTask<T14>.Awaiter>)state)
- {
- TryInvokeContinuationT14(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- {
- var awaiter = task15.GetAwaiter();
- if (awaiter.IsCompleted)
- {
- TryInvokeContinuationT15(this, awaiter);
- }
- else
- {
- awaiter.SourceOnCompleted(state =>
- {
- using (var t = (StateTuple<WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15>, UniTask<T15>.Awaiter>)state)
- {
- TryInvokeContinuationT15(t.Item1, t.Item2);
- }
- }, StateTuple.Create(this, awaiter));
- }
- }
- }
-
- static void TryInvokeContinuationT1(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> self, in UniTask<T1>.Awaiter awaiter)
- {
- try
- {
- self.t1 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 15)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14, self.t15));
- }
- }
-
- static void TryInvokeContinuationT2(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> self, in UniTask<T2>.Awaiter awaiter)
- {
- try
- {
- self.t2 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 15)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14, self.t15));
- }
- }
-
- static void TryInvokeContinuationT3(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> self, in UniTask<T3>.Awaiter awaiter)
- {
- try
- {
- self.t3 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 15)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14, self.t15));
- }
- }
-
- static void TryInvokeContinuationT4(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> self, in UniTask<T4>.Awaiter awaiter)
- {
- try
- {
- self.t4 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 15)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14, self.t15));
- }
- }
-
- static void TryInvokeContinuationT5(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> self, in UniTask<T5>.Awaiter awaiter)
- {
- try
- {
- self.t5 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 15)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14, self.t15));
- }
- }
-
- static void TryInvokeContinuationT6(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> self, in UniTask<T6>.Awaiter awaiter)
- {
- try
- {
- self.t6 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 15)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14, self.t15));
- }
- }
-
- static void TryInvokeContinuationT7(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> self, in UniTask<T7>.Awaiter awaiter)
- {
- try
- {
- self.t7 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 15)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14, self.t15));
- }
- }
-
- static void TryInvokeContinuationT8(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> self, in UniTask<T8>.Awaiter awaiter)
- {
- try
- {
- self.t8 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 15)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14, self.t15));
- }
- }
-
- static void TryInvokeContinuationT9(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> self, in UniTask<T9>.Awaiter awaiter)
- {
- try
- {
- self.t9 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 15)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14, self.t15));
- }
- }
-
- static void TryInvokeContinuationT10(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> self, in UniTask<T10>.Awaiter awaiter)
- {
- try
- {
- self.t10 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 15)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14, self.t15));
- }
- }
-
- static void TryInvokeContinuationT11(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> self, in UniTask<T11>.Awaiter awaiter)
- {
- try
- {
- self.t11 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 15)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14, self.t15));
- }
- }
-
- static void TryInvokeContinuationT12(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> self, in UniTask<T12>.Awaiter awaiter)
- {
- try
- {
- self.t12 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 15)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14, self.t15));
- }
- }
-
- static void TryInvokeContinuationT13(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> self, in UniTask<T13>.Awaiter awaiter)
- {
- try
- {
- self.t13 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 15)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14, self.t15));
- }
- }
-
- static void TryInvokeContinuationT14(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> self, in UniTask<T14>.Awaiter awaiter)
- {
- try
- {
- self.t14 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 15)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14, self.t15));
- }
- }
-
- static void TryInvokeContinuationT15(WhenAllPromise<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15> self, in UniTask<T15>.Awaiter awaiter)
- {
- try
- {
- self.t15 = awaiter.GetResult();
- }
- catch (Exception ex)
- {
- self.core.TrySetException(ex);
- return;
- }
-
- if (Interlocked.Increment(ref self.completedCount) == 15)
- {
- self.core.TrySetResult((self.t1, self.t2, self.t3, self.t4, self.t5, self.t6, self.t7, self.t8, self.t9, self.t10, self.t11, self.t12, self.t13, self.t14, self.t15));
- }
- }
-
-
- public (T1, T2, T3, T4, T5, T6, T7, T8, T9, T10, T11, T12, T13, T14, T15) GetResult(short token)
- {
- TaskTracker.RemoveTracking(this);
- GC.SuppressFinalize(this);
- return core.GetResult(token);
- }
-
- void IUniTaskSource.GetResult(short token)
- {
- GetResult(token);
- }
-
- public UniTaskStatus GetStatus(short token)
- {
- return core.GetStatus(token);
- }
-
- public UniTaskStatus UnsafeGetStatus()
- {
- return core.UnsafeGetStatus();
- }
-
- public void OnCompleted(Action<object> continuation, object state, short token)
- {
- core.OnCompleted(continuation, state, token);
- }
- }
- }
- }
|