From 716402a1800b5d9988fde8a05b4f00ef00916d4f Mon Sep 17 00:00:00 2001 From: hadashiA Date: Thu, 31 Aug 2023 19:21:43 +0900 Subject: [PATCH 1/2] Fix a problem in dotween where an extra update would run after canceling --- .../UniTask/Runtime/External/DOTween/DOTweenAsyncExtensions.cs | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/src/UniTask/Assets/Plugins/UniTask/Runtime/External/DOTween/DOTweenAsyncExtensions.cs b/src/UniTask/Assets/Plugins/UniTask/Runtime/External/DOTween/DOTweenAsyncExtensions.cs index 80ae27c0..1f7829bc 100644 --- a/src/UniTask/Assets/Plugins/UniTask/Runtime/External/DOTween/DOTweenAsyncExtensions.cs +++ b/src/UniTask/Assets/Plugins/UniTask/Runtime/External/DOTween/DOTweenAsyncExtensions.cs @@ -257,10 +257,9 @@ void OnCompleteCallbackDelegate() void OnUpdate() { - originalUpdateAction?.Invoke(); - if (!cancellationToken.IsCancellationRequested) { + originalUpdateAction?.Invoke(); return; } From afe5f57adc03da3e074ee3578aeadc05cf11e5ee Mon Sep 17 00:00:00 2001 From: hadashiA Date: Thu, 7 Sep 2023 17:05:11 +0900 Subject: [PATCH 2/2] Use CancellationToken.Register to cancel DOTWeen --- .../DOTween/DOTweenAsyncExtensions.cs | 153 ++++++++---------- 1 file changed, 68 insertions(+), 85 deletions(-) diff --git a/src/UniTask/Assets/Plugins/UniTask/Runtime/External/DOTween/DOTweenAsyncExtensions.cs b/src/UniTask/Assets/Plugins/UniTask/Runtime/External/DOTween/DOTweenAsyncExtensions.cs index 1f7829bc..076bed51 100644 --- a/src/UniTask/Assets/Plugins/UniTask/Runtime/External/DOTween/DOTweenAsyncExtensions.cs +++ b/src/UniTask/Assets/Plugins/UniTask/Runtime/External/DOTween/DOTweenAsyncExtensions.cs @@ -144,7 +144,6 @@ static TweenConfiguredSource() } readonly TweenCallback onCompleteCallbackDelegate; - readonly TweenCallback onUpdateDelegate; Tween tween; TweenCancelBehaviour cancelBehaviour; @@ -152,14 +151,12 @@ static TweenConfiguredSource() CallbackType callbackType; bool canceled; - TweenCallback originalUpdateAction; TweenCallback originalCompleteAction; UniTaskCompletionSourceCore core; TweenConfiguredSource() { onCompleteCallbackDelegate = OnCompleteCallbackDelegate; - onUpdateDelegate = OnUpdate; } public static IUniTaskSource Create(Tween tween, TweenCancelBehaviour cancelBehaviour, CancellationToken cancellationToken, CallbackType callbackType, out short token) @@ -179,17 +176,8 @@ public static IUniTaskSource Create(Tween tween, TweenCancelBehaviour cancelBeha result.cancelBehaviour = cancelBehaviour; result.cancellationToken = cancellationToken; result.callbackType = callbackType; - - result.originalUpdateAction = tween.onUpdate; result.canceled = false; - if (result.originalUpdateAction == result.onUpdateDelegate) - { - result.originalUpdateAction = null; - } - - tween.onUpdate = result.onUpdateDelegate; - switch (callbackType) { case CallbackType.Kill: @@ -219,12 +207,79 @@ public static IUniTaskSource Create(Tween tween, TweenCancelBehaviour cancelBeha default: break; } - + if (result.originalCompleteAction == result.onCompleteCallbackDelegate) { result.originalCompleteAction = null; } + if (cancellationToken.CanBeCanceled) + { + cancellationToken.RegisterWithoutCaptureExecutionContext(x => + { + var source = (TweenConfiguredSource)x; + switch (source.cancelBehaviour) + { + case TweenCancelBehaviour.Kill: + default: + source.tween.Kill(false); + break; + case TweenCancelBehaviour.KillAndCancelAwait: + source.canceled = true; + source.tween.Kill(false); + break; + case TweenCancelBehaviour.KillWithCompleteCallback: + source.tween.Kill(true); + break; + case TweenCancelBehaviour.KillWithCompleteCallbackAndCancelAwait: + source.canceled = true; + source.tween.Kill(true); + break; + case TweenCancelBehaviour.Complete: + source.tween.Complete(false); + break; + case TweenCancelBehaviour.CompleteAndCancelAwait: + source.canceled = true; + source.tween.Complete(false); + break; + case TweenCancelBehaviour.CompleteWithSequenceCallback: + source.tween.Complete(true); + break; + case TweenCancelBehaviour.CompleteWithSequenceCallbackAndCancelAwait: + source.canceled = true; + source.tween.Complete(true); + break; + case TweenCancelBehaviour.CancelAwait: + // restore to original callback + switch (callbackType) + { + case CallbackType.Kill: + tween.onKill = source.originalCompleteAction; + break; + case CallbackType.Complete: + tween.onComplete = source.originalCompleteAction; + break; + case CallbackType.Pause: + tween.onPause = source.originalCompleteAction; + break; + case CallbackType.Play: + tween.onPlay = source.originalCompleteAction; + break; + case CallbackType.Rewind: + tween.onRewind = source.originalCompleteAction; + break; + case CallbackType.StepComplete: + tween.onStepComplete = source.originalCompleteAction; + break; + default: + break; + } + source.core.TrySetCanceled(source.cancellationToken); + break; + } + }, result); + } + TaskTracker.TrackActiveTask(result, 3); token = result.core.Version; @@ -255,76 +310,6 @@ void OnCompleteCallbackDelegate() } } - void OnUpdate() - { - if (!cancellationToken.IsCancellationRequested) - { - originalUpdateAction?.Invoke(); - return; - } - - switch (this.cancelBehaviour) - { - case TweenCancelBehaviour.Kill: - default: - this.tween.Kill(false); - break; - case TweenCancelBehaviour.KillAndCancelAwait: - this.canceled = true; - this.tween.Kill(false); - break; - case TweenCancelBehaviour.KillWithCompleteCallback: - this.tween.Kill(true); - break; - case TweenCancelBehaviour.KillWithCompleteCallbackAndCancelAwait: - this.canceled = true; - this.tween.Kill(true); - break; - case TweenCancelBehaviour.Complete: - this.tween.Complete(false); - break; - case TweenCancelBehaviour.CompleteAndCancelAwait: - this.canceled = true; - this.tween.Complete(false); - break; - case TweenCancelBehaviour.CompleteWithSequenceCallback: - this.tween.Complete(true); - break; - case TweenCancelBehaviour.CompleteWithSequenceCallbackAndCancelAwait: - this.canceled = true; - this.tween.Complete(true); - break; - case TweenCancelBehaviour.CancelAwait: - // restore to original callback - switch (callbackType) - { - case CallbackType.Kill: - tween.onKill = originalCompleteAction; - break; - case CallbackType.Complete: - tween.onComplete = originalCompleteAction; - break; - case CallbackType.Pause: - tween.onPause = originalCompleteAction; - break; - case CallbackType.Play: - tween.onPlay = originalCompleteAction; - break; - case CallbackType.Rewind: - tween.onRewind = originalCompleteAction; - break; - case CallbackType.StepComplete: - tween.onStepComplete = originalCompleteAction; - break; - default: - break; - } - - this.core.TrySetCanceled(this.cancellationToken); - break; - } - } - static void DoCancelBeforeCreate(Tween tween, TweenCancelBehaviour tweenCancelBehaviour) { @@ -391,7 +376,6 @@ bool TryReturn() { TaskTracker.RemoveTracking(this); core.Reset(); - tween.onUpdate = originalUpdateAction; switch (callbackType) { @@ -419,7 +403,6 @@ bool TryReturn() tween = default; cancellationToken = default; - originalUpdateAction = default; originalCompleteAction = default; return pool.TryPush(this); }