1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
|
// This file was procedurally generated from the following sources:
// - src/class-elements/computed-name-toprimitive-symbol.case
// - src/class-elements/default/cls-decl.template
/*---
description: ToPrimitive evaluation in the ComputedPropertyName (field definitions in a class declaration)
esid: prod-FieldDefinition
features: [class-fields-public, computed-property-names, Symbol.toPrimitive, Symbol, class]
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: 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 {
[obj1] = 42;
[obj2] = 43;
[obj3] = 44;
}
var c = new C();
assert(
!Object.prototype.hasOwnProperty.call(C.prototype, s1),
"s1 doesn't appear as an own property on C prototype"
);
assert(
!Object.prototype.hasOwnProperty.call(C, s1),
"s1 doesn't appear as an own property on C constructor"
);
verifyProperty(c, s1, {
value: 42,
enumerable: true,
writable: true,
configurable: true
});
assert(
!Object.prototype.hasOwnProperty.call(C.prototype, s2),
"s2 doesn't appear as an own property on C prototype"
);
assert(
!Object.prototype.hasOwnProperty.call(C, s2),
"s2 doesn't appear as an own property on C constructor"
);
verifyProperty(c, s2, {
value: 43,
enumerable: true,
writable: true,
configurable: true
});
assert(
!Object.prototype.hasOwnProperty.call(C.prototype, s3),
"s3 doesn't appear as an own property on C prototype"
);
assert(
!Object.prototype.hasOwnProperty.call(C, s3),
"s3 doesn't appear as an own property on C constructor"
);
verifyProperty(c, s3, {
value: 44,
enumerable: true,
writable: true,
configurable: true
});
reportCompare(0, 0);
|