| Index: src/x64/full-codegen-x64.cc
|
| diff --git a/src/x64/full-codegen-x64.cc b/src/x64/full-codegen-x64.cc
|
| index 564c3def865d6b3535209e5bcf8fb32f19605a3c..672d7cc9fd9c273039de2253e3c8ce609cd592fb 100644
|
| --- a/src/x64/full-codegen-x64.cc
|
| +++ b/src/x64/full-codegen-x64.cc
|
| @@ -1907,6 +1907,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);
|
| + __ movq(context_register(),
|
| + Operand(rbp, StandardFrameConstants::kContextOffset));
|
| + }
|
| +
|
| + Label resume;
|
| + __ CompareRoot(result_register(), Heap::kTheHoleValueRootIndex);
|
| + __ j(not_equal, &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();
|
|
|