mirror of https://github.com/Cysharp/UniTask
Added new extension method
Added new extension method that fixes DoTween null-reference, when using GetCancellationOnDestroy()pull/404/head
parent
f48cb4b03e
commit
5e266f5538
|
@ -98,6 +98,25 @@ namespace Cysharp.Threading.Tasks
|
|||
if (!tween.IsActive()) return UniTask.CompletedTask;
|
||||
return new UniTask(TweenConfiguredSource.Create(tween, tweenCancelBehaviour, cancellationToken, CallbackType.StepComplete, out var token), token);
|
||||
}
|
||||
|
||||
public static UniTask AwaitWithCancellation(this Tween tween, CancellationToken cancellationToken)
|
||||
{
|
||||
Error.ThrowArgumentNullException(tween, nameof(tween));
|
||||
|
||||
if (!tween.IsActive()) return UniTask.CompletedTask;
|
||||
|
||||
var registration = cancellationToken.Register(() =>
|
||||
{
|
||||
if (tween.IsActive())
|
||||
{
|
||||
tween.Kill();
|
||||
}
|
||||
});
|
||||
|
||||
tween.OnKill((() => registration.Dispose()));
|
||||
|
||||
return tween.ToUniTask(TweenCancelBehaviour.KillAndCancelAwait, cancellationToken);
|
||||
}
|
||||
|
||||
public struct TweenAwaiter : ICriticalNotifyCompletion
|
||||
{
|
||||
|
|
Loading…
Reference in New Issue