mirror of https://github.com/Cysharp/UniTask
Compare commits
3 Commits
2ee247c48a
...
1911ff25ef
Author | SHA1 | Date |
---|---|---|
|
1911ff25ef | |
|
76697eb172 | |
|
7cba23dd62 |
|
@ -41,6 +41,37 @@ namespace Cysharp.Threading.Tasks
|
||||||
return promise.Task;
|
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>
|
/// <summary>
|
||||||
/// Convert Task -> UniTask.
|
/// Convert Task -> UniTask.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
|
@ -71,6 +102,37 @@ namespace Cysharp.Threading.Tasks
|
||||||
return promise.Task;
|
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)
|
public static Task<T> AsTask<T>(this UniTask<T> task)
|
||||||
{
|
{
|
||||||
try
|
try
|
||||||
|
|
Loading…
Reference in New Issue