| Index: src/arm/full-codegen-arm.cc
|
| diff --git a/src/arm/full-codegen-arm.cc b/src/arm/full-codegen-arm.cc
|
| index d34b46054098cd70793898d613d817d91ced041f..748e02cd0dff1f6410c03b32ac52f6a6dd999fb3 100644
|
| --- a/src/arm/full-codegen-arm.cc
|
| +++ b/src/arm/full-codegen-arm.cc
|
| @@ -1922,6 +1922,46 @@ void FullCodeGenerator::VisitAssignment(Assignment* expr) {
|
| }
|
|
|
|
|
| +void FullCodeGenerator::VisitYield(Yield* expr) {
|
| + Comment cmnt(masm_, "[ Yield");
|
| + // Evaluate yielded value first; the initial iterator definition depends on
|
| + // this. It stays on the stack while we update the iterator.
|
| + VisitForStackValue(expr->expression());
|
| + VisitForStackValue(expr->generator_object());
|
| +
|
| + if (expr->kind() == Yield::FINAL) {
|
| + // TODO(wingo): Mark the iterator as closed.
|
| + } else {
|
| + __ CallRuntime(Runtime::kSuspendJSGeneratorObject, 1);
|
| + __ ldr(context_register(),
|
| + MemOperand(fp, StandardFrameConstants::kContextOffset));
|
| + }
|
| +
|
| + Label resume;
|
| + __ CompareRoot(result_register(), Heap::kTheHoleValueRootIndex);
|
| + __ b(ne, &resume);
|
| + switch (expr->kind()) {
|
| + case Yield::INITIAL:
|
| + __ pop(result_register());
|
| + break;
|
| + case Yield::SUSPEND:
|
| + // TODO(wingo): Box into { value: VALUE, done: false }.
|
| + __ pop(result_register());
|
| + break;
|
| + case Yield::FINAL:
|
| + // TODO(wingo): Box into { value: VALUE, done: true }.
|
| + __ pop(result_register());
|
| + break;
|
| + case Yield::DELEGATING:
|
| + UNIMPLEMENTED();
|
| + }
|
| + EmitReturnSequence();
|
| +
|
| + __ bind(&resume);
|
| + context()->Plug(result_register());
|
| +}
|
| +
|
| +
|
| void FullCodeGenerator::EmitNamedPropertyLoad(Property* prop) {
|
| SetSourcePosition(prop->position());
|
| Literal* key = prop->key()->AsLiteral();
|
|
|