From 55728c964fa20391d31b31562033a2a63f1da40d Mon Sep 17 00:00:00 2001 From: Gaming4JC Date: Sat, 14 Dec 2019 09:25:14 -0500 Subject: Bug 1331092 - Part 11: Await on the innerResult.value when innerResult.done is true in yield*. Tag #1287 --- js/src/frontend/BytecodeEmitter.cpp | 9 +++++++++ 1 file changed, 9 insertions(+) (limited to 'js') diff --git a/js/src/frontend/BytecodeEmitter.cpp b/js/src/frontend/BytecodeEmitter.cpp index 36495bdb2..f16450db9 100644 --- a/js/src/frontend/BytecodeEmitter.cpp +++ b/js/src/frontend/BytecodeEmitter.cpp @@ -8896,6 +8896,10 @@ BytecodeEmitter::emitYieldStar(ParseNode* iter) return false; if (!emitAtomOp(cx->names().value, JSOP_GETPROP)) // ITER OLDRESULT FTYPE FVALUE VALUE return false; + if (isAsyncGenerator) { + if (!emitAwait()) // ITER OLDRESULT FTYPE FVALUE VALUE + return false; + } if (!emitPrepareIteratorResult()) // ITER OLDRESULT FTYPE FVALUE VALUE RESULT return false; if (!emit1(JSOP_SWAP)) // ITER OLDRESULT FTYPE FVALUE RESULT VALUE @@ -8988,6 +8992,11 @@ BytecodeEmitter::emitYieldStar(ParseNode* iter) if (!emitAtomOp(cx->names().value, JSOP_GETPROP)) // VALUE return false; + if (isAsyncGenerator) { + if (!emitAwait()) // VALUE + return false; + } + MOZ_ASSERT(this->stackDepth == startDepth - 1); return true; -- cgit v1.2.3