2017-11-13 23:32:32 +01:00
|
|
|
// This file was procedurally generated from the following sources:
|
|
|
|
// - src/class-fields/static-computed-name-toprimitive-symbol.case
|
|
|
|
// - src/class-fields/default/cls-decl.template
|
|
|
|
/*---
|
|
|
|
description: ToPrimitive evaluation in the ComputedPropertyName (field definitions in a class declaration)
|
|
|
|
esid: prod-FieldDefinition
|
2017-11-28 18:49:12 +01:00
|
|
|
features: [computed-property-names, Symbol.toPrimitive, Symbol, class, class-fields-public]
|
2017-11-13 23:32:32 +01:00
|
|
|
flags: [generated]
|
|
|
|
includes: [propertyHelper.js]
|
|
|
|
info: |
|
|
|
|
Runtime Semantics: ClassDefinitionEvaluation
|
|
|
|
|
|
|
|
...
|
|
|
|
27. For each ClassElement e in order from elements
|
|
|
|
a. If IsStatic of me is false, then
|
|
|
|
i. Let fields be the result of performing ClassElementEvaluation for e with arguments proto and false.
|
|
|
|
b. Else,
|
|
|
|
i. Let fields be the result of performing ClassElementEvaluation for e with arguments F and false.
|
|
|
|
c. If fields is an abrupt completion, then
|
|
|
|
i. Set the running execution context's LexicalEnvironment to lex.
|
|
|
|
ii. Set the running execution context's PrivateNameEnvironment to outerPrivateEnvironment.
|
|
|
|
iii. Return Completion(status).
|
|
|
|
...
|
|
|
|
|
|
|
|
Runtime Semantics: ClassElementEvaluation
|
|
|
|
|
|
|
|
ClassElement: static FieldDefinition;
|
|
|
|
Return ClassFieldDefinitionEvaluation of FieldDefinition with parameter true and object.
|
|
|
|
|
|
|
|
ClassElement: FieldDefinition;
|
|
|
|
Return ClassFieldDefinitionEvaluation of FieldDefinition with parameter false and object.
|
|
|
|
|
|
|
|
Runtime Semantics: ClassFieldDefinitionEvaluation
|
|
|
|
With parameters isStatic and homeObject.
|
|
|
|
|
|
|
|
1. Let fieldName be the result of evaluating ClassElementName.
|
|
|
|
2. ReturnIfAbrupt(fieldName).
|
|
|
|
...
|
|
|
|
|
|
|
|
Runtime Semantics: Evaluation
|
|
|
|
ComputedPropertyName: [ AssignmentExpression ]
|
|
|
|
|
|
|
|
1. Let exprValue be the result of evaluating AssignmentExpression.
|
|
|
|
2. Let propName be ? GetValue(exprValue).
|
|
|
|
3. Return ? ToPropertyKey(propName).
|
|
|
|
|
|
|
|
---*/
|
|
|
|
var s1 = Symbol();
|
|
|
|
var s2 = Symbol();
|
|
|
|
var s3 = Symbol();
|
|
|
|
var err = function() { throw new Test262Error(); };
|
|
|
|
var obj1 = {
|
|
|
|
[Symbol.toPrimitive]: function() { return s1; },
|
|
|
|
toString: err,
|
|
|
|
valueOf: err
|
|
|
|
};
|
|
|
|
|
|
|
|
var obj2 = {
|
|
|
|
toString: function() { return s2; },
|
|
|
|
valueOf: err
|
|
|
|
};
|
|
|
|
|
|
|
|
var obj3 = {
|
|
|
|
toString: undefined,
|
|
|
|
valueOf: function() { return s3; }
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class C {
|
|
|
|
static [obj1] = 42;
|
|
|
|
static [obj2] = 43;
|
|
|
|
static [obj3] = 44;
|
|
|
|
}
|
|
|
|
|
|
|
|
assert.sameValue(Object.hasOwnProperty.call(C.prototype, s1), false);
|
|
|
|
assert.sameValue(Object.hasOwnProperty.call(C.prototype, s2), false);
|
|
|
|
assert.sameValue(Object.hasOwnProperty.call(C.prototype, s3), false);
|
|
|
|
|
|
|
|
verifyProperty(C, s1, {
|
|
|
|
value: 42,
|
|
|
|
enumerable: true,
|
|
|
|
writable: true,
|
|
|
|
configurable: true
|
|
|
|
});
|
|
|
|
|
|
|
|
verifyProperty(C, s2, {
|
|
|
|
value: 43,
|
|
|
|
enumerable: true,
|
|
|
|
writable: true,
|
|
|
|
configurable: true
|
|
|
|
});
|
|
|
|
|
|
|
|
verifyProperty(C, s3, {
|
|
|
|
value: 44,
|
|
|
|
enumerable: true,
|
|
|
|
writable: true,
|
|
|
|
configurable: true
|
|
|
|
});
|
|
|
|
|
|
|
|
var c = new C();
|
|
|
|
|
|
|
|
assert.sameValue(Object.hasOwnProperty.call(c, s1), false);
|
|
|
|
assert.sameValue(Object.hasOwnProperty.call(c, s2), false);
|
|
|
|
assert.sameValue(Object.hasOwnProperty.call(c, s3), false);
|