| Index: src/full-codegen/arm64/full-codegen-arm64.cc
|
| diff --git a/src/full-codegen/arm64/full-codegen-arm64.cc b/src/full-codegen/arm64/full-codegen-arm64.cc
|
| index 5a0b8b74fef53e7655ace24f7db933112316de9b..3b71a5f30191db1ab6d87a2c8bbbd527bc02d612 100644
|
| --- a/src/full-codegen/arm64/full-codegen-arm64.cc
|
| +++ b/src/full-codegen/arm64/full-codegen-arm64.cc
|
| @@ -1887,6 +1887,30 @@ void FullCodeGenerator::EmitClassDefineProperties(ClassLiteral* lit) {
|
| ClassLiteral::Property* property = lit->properties()->at(i);
|
| Expression* value = property->value();
|
|
|
| + if (property->kind() == ClassLiteral::Property::FIELD &&
|
| + !property->is_static()) {
|
| + // Non-static properties produced by the parser have as their 'key' an
|
| + // expression producing their name and as their 'value' a variable which
|
| + // is refered to by the synthetic initializer function in order to
|
| + // determine the name during class instantiation. This is necessary
|
| + // because computed names must only be evaluated once, at class definition
|
| + // time.
|
| + // That is, code which looks like `class C { [f()] = 1; }` is desugared
|
| + // into something like
|
| + // class C { constructor(){ this.[.class-field-0-name] = 1; } };
|
| + // let .class-field-0-name = f();
|
| + // except that the assignment to .class-field-name-0 occurs interleaved
|
| + // with the rest of the class body; it is performed by the block in which
|
| + // this comment appears.
|
| + DCHECK(property->value()->IsVariableProxy());
|
| + Variable* variable = property->value()->AsVariableProxy()->var();
|
| + VisitForStackValue(property->key());
|
| + EmitVariableAssignment(variable, Token::INIT,
|
| + FeedbackVectorSlot::Invalid());
|
| + DropOperands(1);
|
| + continue;
|
| + }
|
| +
|
| Register scratch = x1;
|
| if (property->is_static()) {
|
| __ Peek(scratch, kPointerSize); // constructor
|
| @@ -1928,8 +1952,11 @@ void FullCodeGenerator::EmitClassDefineProperties(ClassLiteral* lit) {
|
| break;
|
|
|
| case ClassLiteral::Property::FIELD:
|
| - default:
|
| - UNREACHABLE();
|
| + DCHECK(property->is_static());
|
| + PushOperand(Smi::FromInt(DONT_ENUM));
|
| + PushOperand(Smi::FromInt(property->NeedsSetFunctionName()));
|
| + CallRuntimeWithOperands(Runtime::kDefineDataPropertyInLiteral);
|
| + break;
|
| }
|
| }
|
| }
|
|
|