diff --git a/src/UniTask/Assets/Plugins/UniTask/Runtime/TriggerEvent.cs b/src/UniTask/Assets/Plugins/UniTask/Runtime/TriggerEvent.cs index 503e9db9..0b817fe3 100644 --- a/src/UniTask/Assets/Plugins/UniTask/Runtime/TriggerEvent.cs +++ b/src/UniTask/Assets/Plugins/UniTask/Runtime/TriggerEvent.cs @@ -20,8 +20,6 @@ public struct TriggerEvent { ITriggerHandler head; // head.prev is last ITriggerHandler iteratingHead; - - bool preserveRemoveSelf; ITriggerHandler iteratingNode; void LogError(Exception ex) @@ -55,18 +53,9 @@ public void SetResult(T value) Remove(h); } - if (preserveRemoveSelf) - { - preserveRemoveSelf = false; - iteratingNode = null; - var next = h.Next; - Remove(h); - h = next; - } - else - { - h = h.Next; - } + // If `h` itself is removed by OnNext, h.Next is null. + // Therefore, instead of looking at h.Next, the `iteratingNode` reference itself is replaced. + h = h == iteratingNode ? h.Next : iteratingNode; } iteratingNode = null; @@ -97,9 +86,8 @@ public void SetCanceled(CancellationToken cancellationToken) LogError(ex); } - preserveRemoveSelf = false; + var next = h == iteratingNode ? h.Next : iteratingNode; iteratingNode = null; - var next = h.Next; Remove(h); h = next; } @@ -132,9 +120,8 @@ public void SetCompleted() LogError(ex); } - preserveRemoveSelf = false; + var next = h == iteratingNode ? h.Next : iteratingNode; iteratingNode = null; - var next = h.Next; Remove(h); h = next; } @@ -167,9 +154,8 @@ public void SetError(Exception exception) LogError(ex); } - preserveRemoveSelf = false; + var next = h == iteratingNode ? h.Next : iteratingNode; iteratingNode = null; - var next = h.Next; Remove(h); h = next; } @@ -241,71 +227,65 @@ public void Remove(ITriggerHandler handler) { if (handler == null) throw new ArgumentNullException(nameof(handler)); - if (iteratingNode != null && iteratingNode == handler) + var prev = handler.Prev; + var next = handler.Next; + + if (next != null) { - // if remove self, reserve remove self after invoke completed. - preserveRemoveSelf = true; + next.Prev = prev; } - else + + if (handler == head) + { + head = next; + } + // when handler is head, prev indicate last so don't use it. + else if (prev != null) { - var prev = handler.Prev; - var next = handler.Next; + prev.Next = next; + } - if (next != null) - { - next.Prev = prev; - } + if (handler == iteratingNode) + { + iteratingNode = next; + } + if (handler == iteratingHead) + { + iteratingHead = next; + } - if (handler == head) - { - head = next; - } - else if (handler == iteratingHead) - { - iteratingHead = next; - } - else + if (head != null) + { + if (head.Prev == handler) { - // when handler is head, prev indicate last so don't use it. - if (prev != null) + if (prev != head) { - prev.Next = next; + head.Prev = prev; } - } - - if (head != null) - { - if (head.Prev == handler) + else { - if (prev != head) - { - head.Prev = prev; - } - else - { - head.Prev = null; - } + head.Prev = null; } } + } - if (iteratingHead != null) + if (iteratingHead != null) + { + if (iteratingHead.Prev == handler) { - if (iteratingHead.Prev == handler) + if (prev != iteratingHead.Prev) { - if (prev != iteratingHead.Prev) - { - iteratingHead.Prev = prev; - } - else - { - iteratingHead.Prev = null; - } + iteratingHead.Prev = prev; + } + else + { + iteratingHead.Prev = null; } } - - handler.Prev = null; - handler.Next = null; } + + handler.Prev = null; + handler.Next = null; } } }