mirror of
https://github.com/tc39/test262.git
synced 2025-07-23 14:04:51 +02:00
Merge pull request #2178 from mkubilayk/private-before-super-return
Check private methods are not installed before super returns
This commit is contained in:
commit
dce80ecde1
@ -0,0 +1,42 @@
|
|||||||
|
// Copyright (C) 2019 Kubilay Kahveci (Bloomberg LP). All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
desc: Private getters are installed "when super returns" and no earlier (call in constructor)
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
template: default
|
||||||
|
features: [class-methods-private]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
//- elements
|
||||||
|
constructor() {
|
||||||
|
this.f();
|
||||||
|
}
|
||||||
|
|
||||||
|
//- assertions
|
||||||
|
class D extends C {
|
||||||
|
f() { this.#m; }
|
||||||
|
get #m() { return 42; }
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('f'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private getters are not installed before super returns');
|
@ -0,0 +1,40 @@
|
|||||||
|
// Copyright (C) 2019 Kubilay Kahveci (Bloomberg LP). All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
desc: Private getters are installed "when super returns" and no earlier (call in field initializer)
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
template: default
|
||||||
|
features: [class-methods-private]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
//- elements
|
||||||
|
f = this.g();
|
||||||
|
|
||||||
|
//- assertions
|
||||||
|
class D extends C {
|
||||||
|
g() { this.#m; }
|
||||||
|
get #m() { return 42; }
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('g'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private getters are not installed before super returns');
|
@ -0,0 +1,42 @@
|
|||||||
|
// Copyright (C) 2019 Kubilay Kahveci (Bloomberg LP). All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
desc: Private methods are installed "when super returns" and no earlier (call in constructor)
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
template: default
|
||||||
|
features: [class-methods-private]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
//- elements
|
||||||
|
constructor() {
|
||||||
|
this.f();
|
||||||
|
}
|
||||||
|
|
||||||
|
//- assertions
|
||||||
|
class D extends C {
|
||||||
|
f() { this.#m(); }
|
||||||
|
#m() { return 42; }
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('f'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private methods are not installed before super returns');
|
@ -0,0 +1,40 @@
|
|||||||
|
// Copyright (C) 2019 Kubilay Kahveci (Bloomberg LP). All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
desc: Private methods are installed "when super returns" and no earlier (call in field initializer)
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
template: default
|
||||||
|
features: [class-methods-private]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
//- elements
|
||||||
|
f = this.g();
|
||||||
|
|
||||||
|
//- assertions
|
||||||
|
class D extends C {
|
||||||
|
g() { this.#m(); }
|
||||||
|
#m() { return 42; }
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('g'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private methods are not installed before super returns');
|
@ -0,0 +1,42 @@
|
|||||||
|
// Copyright (C) 2019 Kubilay Kahveci (Bloomberg LP). All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
desc: Private setters are installed "when super returns" and no earlier (call in constructor)
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
template: default
|
||||||
|
features: [class-methods-private]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
//- elements
|
||||||
|
constructor() {
|
||||||
|
this.f();
|
||||||
|
}
|
||||||
|
|
||||||
|
//- assertions
|
||||||
|
class D extends C {
|
||||||
|
f() { this.#m = 42; }
|
||||||
|
set #m(val) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('f'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private setters are not installed before super returns');
|
@ -0,0 +1,40 @@
|
|||||||
|
// Copyright (C) 2019 Kubilay Kahveci (Bloomberg LP). All rights reserved.
|
||||||
|
// This code is governed by the BSD license found in the LICENSE file.
|
||||||
|
|
||||||
|
/*---
|
||||||
|
desc: Private settters are installed "when super returns" and no earlier (call in field initializer)
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
template: default
|
||||||
|
features: [class-methods-private]
|
||||||
|
---*/
|
||||||
|
|
||||||
|
//- elements
|
||||||
|
f = this.g();
|
||||||
|
|
||||||
|
//- assertions
|
||||||
|
class D extends C {
|
||||||
|
g() { this.#m = 42; }
|
||||||
|
set #m(val) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('g'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private setters are not installed before super returns');
|
@ -0,0 +1,46 @@
|
|||||||
|
// This file was procedurally generated from the following sources:
|
||||||
|
// - src/class-elements/prod-private-getter-before-super-return-in-constructor.case
|
||||||
|
// - src/class-elements/default/cls-expr.template
|
||||||
|
/*---
|
||||||
|
description: Private getters are installed "when super returns" and no earlier (call in constructor) (field definitions in a class expression)
|
||||||
|
esid: prod-FieldDefinition
|
||||||
|
features: [class-methods-private, class]
|
||||||
|
flags: [generated]
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
|
||||||
|
---*/
|
||||||
|
|
||||||
|
|
||||||
|
var C = class {
|
||||||
|
constructor() {
|
||||||
|
this.f();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class D extends C {
|
||||||
|
f() { this.#m; }
|
||||||
|
get #m() { return 42; }
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('f'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private getters are not installed before super returns');
|
@ -0,0 +1,44 @@
|
|||||||
|
// This file was procedurally generated from the following sources:
|
||||||
|
// - src/class-elements/prod-private-getter-before-super-return-in-field-initializer.case
|
||||||
|
// - src/class-elements/default/cls-expr.template
|
||||||
|
/*---
|
||||||
|
description: Private getters are installed "when super returns" and no earlier (call in field initializer) (field definitions in a class expression)
|
||||||
|
esid: prod-FieldDefinition
|
||||||
|
features: [class-methods-private, class]
|
||||||
|
flags: [generated]
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
|
||||||
|
---*/
|
||||||
|
|
||||||
|
|
||||||
|
var C = class {
|
||||||
|
f = this.g();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class D extends C {
|
||||||
|
g() { this.#m; }
|
||||||
|
get #m() { return 42; }
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('g'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private getters are not installed before super returns');
|
@ -0,0 +1,46 @@
|
|||||||
|
// This file was procedurally generated from the following sources:
|
||||||
|
// - src/class-elements/prod-private-method-before-super-return-in-constructor.case
|
||||||
|
// - src/class-elements/default/cls-expr.template
|
||||||
|
/*---
|
||||||
|
description: Private methods are installed "when super returns" and no earlier (call in constructor) (field definitions in a class expression)
|
||||||
|
esid: prod-FieldDefinition
|
||||||
|
features: [class-methods-private, class]
|
||||||
|
flags: [generated]
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
|
||||||
|
---*/
|
||||||
|
|
||||||
|
|
||||||
|
var C = class {
|
||||||
|
constructor() {
|
||||||
|
this.f();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class D extends C {
|
||||||
|
f() { this.#m(); }
|
||||||
|
#m() { return 42; }
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('f'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private methods are not installed before super returns');
|
@ -0,0 +1,44 @@
|
|||||||
|
// This file was procedurally generated from the following sources:
|
||||||
|
// - src/class-elements/prod-private-method-before-super-return-in-field-initializer.case
|
||||||
|
// - src/class-elements/default/cls-expr.template
|
||||||
|
/*---
|
||||||
|
description: Private methods are installed "when super returns" and no earlier (call in field initializer) (field definitions in a class expression)
|
||||||
|
esid: prod-FieldDefinition
|
||||||
|
features: [class-methods-private, class]
|
||||||
|
flags: [generated]
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
|
||||||
|
---*/
|
||||||
|
|
||||||
|
|
||||||
|
var C = class {
|
||||||
|
f = this.g();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class D extends C {
|
||||||
|
g() { this.#m(); }
|
||||||
|
#m() { return 42; }
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('g'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private methods are not installed before super returns');
|
@ -0,0 +1,46 @@
|
|||||||
|
// This file was procedurally generated from the following sources:
|
||||||
|
// - src/class-elements/prod-private-setter-before-super-return-in-constructor.case
|
||||||
|
// - src/class-elements/default/cls-expr.template
|
||||||
|
/*---
|
||||||
|
description: Private setters are installed "when super returns" and no earlier (call in constructor) (field definitions in a class expression)
|
||||||
|
esid: prod-FieldDefinition
|
||||||
|
features: [class-methods-private, class]
|
||||||
|
flags: [generated]
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
|
||||||
|
---*/
|
||||||
|
|
||||||
|
|
||||||
|
var C = class {
|
||||||
|
constructor() {
|
||||||
|
this.f();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class D extends C {
|
||||||
|
f() { this.#m = 42; }
|
||||||
|
set #m(val) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('f'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private setters are not installed before super returns');
|
@ -0,0 +1,44 @@
|
|||||||
|
// This file was procedurally generated from the following sources:
|
||||||
|
// - src/class-elements/prod-private-setter-before-super-return-in-field-initializer.case
|
||||||
|
// - src/class-elements/default/cls-expr.template
|
||||||
|
/*---
|
||||||
|
description: Private settters are installed "when super returns" and no earlier (call in field initializer) (field definitions in a class expression)
|
||||||
|
esid: prod-FieldDefinition
|
||||||
|
features: [class-methods-private, class]
|
||||||
|
flags: [generated]
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
|
||||||
|
---*/
|
||||||
|
|
||||||
|
|
||||||
|
var C = class {
|
||||||
|
f = this.g();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class D extends C {
|
||||||
|
g() { this.#m = 42; }
|
||||||
|
set #m(val) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('g'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private setters are not installed before super returns');
|
@ -0,0 +1,46 @@
|
|||||||
|
// This file was procedurally generated from the following sources:
|
||||||
|
// - src/class-elements/prod-private-getter-before-super-return-in-constructor.case
|
||||||
|
// - src/class-elements/default/cls-decl.template
|
||||||
|
/*---
|
||||||
|
description: Private getters are installed "when super returns" and no earlier (call in constructor) (field definitions in a class declaration)
|
||||||
|
esid: prod-FieldDefinition
|
||||||
|
features: [class-methods-private, class]
|
||||||
|
flags: [generated]
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
|
||||||
|
---*/
|
||||||
|
|
||||||
|
|
||||||
|
class C {
|
||||||
|
constructor() {
|
||||||
|
this.f();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class D extends C {
|
||||||
|
f() { this.#m; }
|
||||||
|
get #m() { return 42; }
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('f'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private getters are not installed before super returns');
|
@ -0,0 +1,44 @@
|
|||||||
|
// This file was procedurally generated from the following sources:
|
||||||
|
// - src/class-elements/prod-private-getter-before-super-return-in-field-initializer.case
|
||||||
|
// - src/class-elements/default/cls-decl.template
|
||||||
|
/*---
|
||||||
|
description: Private getters are installed "when super returns" and no earlier (call in field initializer) (field definitions in a class declaration)
|
||||||
|
esid: prod-FieldDefinition
|
||||||
|
features: [class-methods-private, class]
|
||||||
|
flags: [generated]
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
|
||||||
|
---*/
|
||||||
|
|
||||||
|
|
||||||
|
class C {
|
||||||
|
f = this.g();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class D extends C {
|
||||||
|
g() { this.#m; }
|
||||||
|
get #m() { return 42; }
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('g'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private getters are not installed before super returns');
|
@ -0,0 +1,46 @@
|
|||||||
|
// This file was procedurally generated from the following sources:
|
||||||
|
// - src/class-elements/prod-private-method-before-super-return-in-constructor.case
|
||||||
|
// - src/class-elements/default/cls-decl.template
|
||||||
|
/*---
|
||||||
|
description: Private methods are installed "when super returns" and no earlier (call in constructor) (field definitions in a class declaration)
|
||||||
|
esid: prod-FieldDefinition
|
||||||
|
features: [class-methods-private, class]
|
||||||
|
flags: [generated]
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
|
||||||
|
---*/
|
||||||
|
|
||||||
|
|
||||||
|
class C {
|
||||||
|
constructor() {
|
||||||
|
this.f();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class D extends C {
|
||||||
|
f() { this.#m(); }
|
||||||
|
#m() { return 42; }
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('f'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private methods are not installed before super returns');
|
@ -0,0 +1,44 @@
|
|||||||
|
// This file was procedurally generated from the following sources:
|
||||||
|
// - src/class-elements/prod-private-method-before-super-return-in-field-initializer.case
|
||||||
|
// - src/class-elements/default/cls-decl.template
|
||||||
|
/*---
|
||||||
|
description: Private methods are installed "when super returns" and no earlier (call in field initializer) (field definitions in a class declaration)
|
||||||
|
esid: prod-FieldDefinition
|
||||||
|
features: [class-methods-private, class]
|
||||||
|
flags: [generated]
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
|
||||||
|
---*/
|
||||||
|
|
||||||
|
|
||||||
|
class C {
|
||||||
|
f = this.g();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class D extends C {
|
||||||
|
g() { this.#m(); }
|
||||||
|
#m() { return 42; }
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('g'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private methods are not installed before super returns');
|
@ -0,0 +1,46 @@
|
|||||||
|
// This file was procedurally generated from the following sources:
|
||||||
|
// - src/class-elements/prod-private-setter-before-super-return-in-constructor.case
|
||||||
|
// - src/class-elements/default/cls-decl.template
|
||||||
|
/*---
|
||||||
|
description: Private setters are installed "when super returns" and no earlier (call in constructor) (field definitions in a class declaration)
|
||||||
|
esid: prod-FieldDefinition
|
||||||
|
features: [class-methods-private, class]
|
||||||
|
flags: [generated]
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
|
||||||
|
---*/
|
||||||
|
|
||||||
|
|
||||||
|
class C {
|
||||||
|
constructor() {
|
||||||
|
this.f();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class D extends C {
|
||||||
|
f() { this.#m = 42; }
|
||||||
|
set #m(val) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('f'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private setters are not installed before super returns');
|
@ -0,0 +1,44 @@
|
|||||||
|
// This file was procedurally generated from the following sources:
|
||||||
|
// - src/class-elements/prod-private-setter-before-super-return-in-field-initializer.case
|
||||||
|
// - src/class-elements/default/cls-decl.template
|
||||||
|
/*---
|
||||||
|
description: Private settters are installed "when super returns" and no earlier (call in field initializer) (field definitions in a class declaration)
|
||||||
|
esid: prod-FieldDefinition
|
||||||
|
features: [class-methods-private, class]
|
||||||
|
flags: [generated]
|
||||||
|
info: |
|
||||||
|
SuperCall: super Arguments
|
||||||
|
1. Let newTarget be GetNewTarget().
|
||||||
|
2. If newTarget is undefined, throw a ReferenceError exception.
|
||||||
|
3. Let func be ? GetSuperConstructor().
|
||||||
|
4. Let argList be ArgumentListEvaluation of Arguments.
|
||||||
|
5. ReturnIfAbrupt(argList).
|
||||||
|
6. Let result be ? Construct(func, argList, newTarget).
|
||||||
|
7. Let thisER be GetThisEnvironment( ).
|
||||||
|
8. Let F be thisER.[[FunctionObject]].
|
||||||
|
9. Assert: F is an ECMAScript function object.
|
||||||
|
10. Perform ? InitializeInstanceElements(result, F).
|
||||||
|
|
||||||
|
EDITOR'S NOTE:
|
||||||
|
Private fields are added to the object one by one, interspersed with
|
||||||
|
evaluation of the initializers, following the construction of the
|
||||||
|
receiver. These semantics allow for a later initializer to refer to
|
||||||
|
a previous private field.
|
||||||
|
|
||||||
|
---*/
|
||||||
|
|
||||||
|
|
||||||
|
class C {
|
||||||
|
f = this.g();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
class D extends C {
|
||||||
|
g() { this.#m = 42; }
|
||||||
|
set #m(val) {}
|
||||||
|
}
|
||||||
|
|
||||||
|
assert(D.prototype.hasOwnProperty('g'));
|
||||||
|
assert.throws(TypeError, function() {
|
||||||
|
var d = new D();
|
||||||
|
}, 'private setters are not installed before super returns');
|
Loading…
x
Reference in New Issue
Block a user