diff --git a/src/accessor-names/default/cls-private-decl-inst.template b/src/accessor-names/default/cls-private-decl-inst.template new file mode 100644 index 0000000000000000000000000000000000000000..ba8a7c25eaaa93d89efbe3b72408e9b9a8eddcef --- /dev/null +++ b/src/accessor-names/default/cls-private-decl-inst.template @@ -0,0 +1,26 @@ +// Copyright (C) 2017 Mike Pennisi. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +path: language/statements/class/accessor-name-inst- +name: Class declaration, instance method +esid: sec-runtime-semantics-classdefinitionevaluation +es6id: 14.5.14 +info: | + [...] + 21. For each ClassElement m in order from methods + a. If IsStatic of m is false, then + i. Let status be the result of performing PropertyDefinitionEvaluation + for m with arguments proto and false. +---*/ + +var stringSet; + +class C { + get /*{ declareWith }*/() { return 'get string'; } + set /*{ declareWith }*/(param) { stringSet = param; } +} + +assert.sameValue(C.prototype[/*{ referenceWith }*/], 'get string'); + +C.prototype[/*{ referenceWith }*/] = 'set string'; +assert.sameValue(stringSet, 'set string'); diff --git a/src/accessor-names/default/cls-private-decl-static.template b/src/accessor-names/default/cls-private-decl-static.template new file mode 100644 index 0000000000000000000000000000000000000000..bb7f71b3aed115699a56597505f6286d0d6868f1 --- /dev/null +++ b/src/accessor-names/default/cls-private-decl-static.template @@ -0,0 +1,46 @@ +// Copyright (C) 2018 Katie Broida. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +path: language/statements/class/private-accessor-name-static- +name: Class declaration, static method +esid: #prod-MethodDefinition +info: | + [...] + MethodDefinition[Yield, Await]: + PropertyNameClassElementName [?Yield, ?Await]( + UniqueFormalParameters [~Yield, ~Await] ) { + FunctionBody [~Yield, ~Await] } + AsyncMethod[?Yield, ?Await] + get PropertyName ClassElementName [?Yield, ?Await] (){ + FunctionBody [~Yield, ~Await] } + set PropertyNameClassElementName [?Yield, ?Await] ( + PropertySetParameterList ) { FunctionBody [~Yield, ~Await] } + AsyncMethod [Yield, Await]: + async [no LineTerminator here] PropertyName + ClassElementName[?Yield, ?Await]( + UniqueFormalParameters[~Yield, +Await] ) { AsyncFunctionBody } + +---*/ + +var stringSet; + +class C { + static get #/*{ declareWith }*/() { return 'get string'; } + static set #/*{ declareWith }*/(param) { stringSet = param; } + + static getPrivateReference() { + return this.#/*{ referenceWith }*/; + } + + static setPrivateReference(value) { + this.#/*{ referenceWith }*/ = value; + } +} + +var inst = C(); + +assert.sameValue(inst.getPrivateReference(), 'get string'); + +inst.setPrivateReference('set string'); +assert.sameValue(stringSet, 'set string'); + diff --git a/src/accessor-names/default/cls-private-expr-inst.template b/src/accessor-names/default/cls-private-expr-inst.template new file mode 100644 index 0000000000000000000000000000000000000000..1a14db69f12d671f80f795f30742440635413627 --- /dev/null +++ b/src/accessor-names/default/cls-private-expr-inst.template @@ -0,0 +1,45 @@ +// Copyright (C) 2018 Katie Broida. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +path: language/expressions/class/private-accessor-name-inst- +name: Class expression, instance private method +esid: #prod-MethodDefinition +info: | + [...] + MethodDefinition[Yield, Await]: + PropertyNameClassElementName [?Yield, ?Await]( + UniqueFormalParameters [~Yield, ~Await] ) { + FunctionBody [~Yield, ~Await] } + AsyncMethod[?Yield, ?Await] + get PropertyName ClassElementName [?Yield, ?Await] (){ + FunctionBody [~Yield, ~Await] } + set PropertyNameClassElementName [?Yield, ?Await] ( + PropertySetParameterList ) { FunctionBody [~Yield, ~Await] } + AsyncMethod [Yield, Await]: + async [no LineTerminator here] PropertyName + ClassElementName[?Yield, ?Await]( + UniqueFormalParameters[~Yield, +Await] ) { AsyncFunctionBody } + +---*/ + +var stringSet; + +var C = class { + get #/*{ declareWith }*/() { return 'get string'; } + set #/*{ declareWith }*/(param) { stringSet = param; } + + getPrivateReference() { + return this.#/*{ referenceWith }*/; + } + + setPrivateReference(value) { + this.#/*{ referenceWith }*/ = value; + } +}; + +var inst = C(); + +assert.sameValue(inst.getPrivateReference(), 'get string'); + +inst.setPrivateReference('set string'); +assert.sameValue(stringSet, 'set string'); diff --git a/src/accessor-names/default/cls-private-expr-static.template b/src/accessor-names/default/cls-private-expr-static.template new file mode 100644 index 0000000000000000000000000000000000000000..e004113c28b575dde45ce616055d2ed1942a8df6 --- /dev/null +++ b/src/accessor-names/default/cls-private-expr-static.template @@ -0,0 +1,45 @@ +// Copyright (C) 2018 Katie Broida. All rights reserved. +// This code is governed by the BSD license found in the LICENSE file. +/*--- +path: language/expressions/class/private-accessor-name-static- +name: Class expression, static private method +esid: #prod-MethodDefinition +info: | + [...] + MethodDefinition[Yield, Await]: + PropertyNameClassElementName [?Yield, ?Await]( + UniqueFormalParameters [~Yield, ~Await] ) { + FunctionBody [~Yield, ~Await] } + AsyncMethod[?Yield, ?Await] + get PropertyName ClassElementName [?Yield, ?Await] (){ + FunctionBody [~Yield, ~Await] } + set PropertyNameClassElementName [?Yield, ?Await] ( + PropertySetParameterList ) { FunctionBody [~Yield, ~Await] } + AsyncMethod [Yield, Await]: + async [no LineTerminator here] PropertyName + ClassElementName[?Yield, ?Await]( + UniqueFormalParameters[~Yield, +Await] ) { AsyncFunctionBody } + +---*/ + +var stringSet; + +var C = class { + static get #/*{ declareWith }*/() { return 'get string'; } + static set #/*{ declareWith }*/(param) { stringSet = param; } + + static getPrivateReference() { + return this.#/*{ referenceWith }*/; + } + + static setPrivateReference(value) { + this.#/*{ referenceWith }*/ = value; + } +}; + +var inst = C(); + +assert.sameValue(inst.getPrivateReference(), 'get string'); + +inst.setPrivateReference('set string'); +assert.sameValue(stringSet, 'set string');