Merge pull request from RamType-0/OptimizeConsumeEnumerator

Optimize EnumeratorPromise.ConsumeEnumerator while consuming CustomYieldInstruction
pull/162/head
Yoshifumi Kawai 2020-09-07 17:23:08 +09:00 committed by GitHub
commit 4955ed18f1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 2 additions and 12 deletions
src/UniTask/Assets/Plugins/UniTask/Runtime

View File

@ -163,11 +163,10 @@ namespace Cysharp.Threading.Tasks
{
yield return null;
}
else if (current is CustomYieldInstruction)
else if (current is CustomYieldInstruction cyi)
{
// WWW, WaitForSecondsRealtime
var e2 = UnwrapWaitCustomYieldInstruction((CustomYieldInstruction)current);
while (e2.MoveNext())
while (cyi.keepWaiting)
{
yield return null;
}
@ -212,15 +211,6 @@ namespace Cysharp.Threading.Tasks
}
}
// WWW and others as CustomYieldInstruction.
static IEnumerator UnwrapWaitCustomYieldInstruction(CustomYieldInstruction yieldInstruction)
{
while (yieldInstruction.keepWaiting)
{
yield return null;
}
}
static readonly FieldInfo waitForSeconds_Seconds = typeof(WaitForSeconds).GetField("m_Seconds", BindingFlags.Instance | BindingFlags.GetField | BindingFlags.NonPublic);
static IEnumerator UnwrapWaitForSeconds(WaitForSeconds waitForSeconds)