Compare commits

...

3 Commits

Author SHA1 Message Date
Scormave 1911ff25ef
Merge 76697eb172 into d210e3d76a 2023-06-26 03:29:12 +09:00
Sergey Andreev 76697eb172 Removed default for CancellationToken, since there can be ambiguous calls 2023-05-09 15:50:52 +02:00
Sergey Andreev 7cba23dd62 Added AsUniTask methods with CancellationToken support 2023-05-09 15:38:06 +02:00
1 changed files with 62 additions and 0 deletions

View File

@ -41,6 +41,37 @@ namespace Cysharp.Threading.Tasks
return promise.Task;
}
public static UniTask<T> AsUniTask<T>(this Task<T> task, CancellationToken cancellationToken, bool useCurrentSynchronizationContext = true)
{
var promise = new UniTaskCompletionSource<T>();
var state = StatePool<UniTaskCompletionSource<T>, CancellationToken>.Create(promise, cancellationToken);
task.ContinueWith((x, state) =>
{
var tuple = (StateTuple<UniTaskCompletionSource<T>, CancellationToken>)state;
tuple.Deconstruct(out var p, out var token);
switch (x.Status)
{
case TaskStatus.Canceled:
p.TrySetCanceled(token);
break;
case TaskStatus.Faulted:
p.TrySetException(x.Exception);
break;
case TaskStatus.RanToCompletion:
p.TrySetResult(x.Result);
break;
default:
throw new NotSupportedException();
}
tuple.Dispose();
}, state, useCurrentSynchronizationContext ? TaskScheduler.FromCurrentSynchronizationContext() : TaskScheduler.Current);
return promise.Task;
}
/// <summary>
/// Convert Task -> UniTask.
/// </summary>
@ -71,6 +102,37 @@ namespace Cysharp.Threading.Tasks
return promise.Task;
}
public static UniTask AsUniTask(this Task task, CancellationToken cancellationToken, bool useCurrentSynchronizationContext = true)
{
var promise = new UniTaskCompletionSource();
var state = StatePool<UniTaskCompletionSource, CancellationToken>.Create(promise, cancellationToken);
task.ContinueWith((x, state) =>
{
var tuple = (StateTuple<UniTaskCompletionSource, CancellationToken>)state;
tuple.Deconstruct(out var p, out var token);
switch (x.Status)
{
case TaskStatus.Canceled:
p.TrySetCanceled(token);
break;
case TaskStatus.Faulted:
p.TrySetException(x.Exception);
break;
case TaskStatus.RanToCompletion:
p.TrySetResult();
break;
default:
throw new NotSupportedException();
}
tuple.Dispose();
}, state, useCurrentSynchronizationContext ? TaskScheduler.FromCurrentSynchronizationContext() : TaskScheduler.Current);
return promise.Task;
}
public static Task<T> AsTask<T>(this UniTask<T> task)
{
try