private-meth-static-ary-ptrn-elem-id-init-skipped.js (3025B)
1 // This file was procedurally generated from the following sources: 2 // - src/dstr-binding/ary-ptrn-elem-id-init-skipped.case 3 // - src/dstr-binding/default/cls-expr-private-meth-static.template 4 /*--- 5 description: Destructuring initializer is not evaluated when value is not `undefined` (private static class expression method) 6 esid: sec-class-definitions-runtime-semantics-evaluation 7 features: [class, class-static-methods-private, destructuring-binding] 8 flags: [generated] 9 info: | 10 ClassExpression : class BindingIdentifieropt ClassTail 11 12 1. If BindingIdentifieropt is not present, let className be undefined. 13 2. Else, let className be StringValue of BindingIdentifier. 14 3. Let value be the result of ClassDefinitionEvaluation of ClassTail 15 with argument className. 16 [...] 17 18 14.5.14 Runtime Semantics: ClassDefinitionEvaluation 19 20 21. For each ClassElement m in order from methods 21 a. If IsStatic of m is false, then 22 b. Else, 23 Let status be the result of performing PropertyDefinitionEvaluation for 24 m with arguments F and false. 25 [...] 26 27 14.3.8 Runtime Semantics: DefineMethod 28 29 MethodDefinition : PropertyName ( StrictFormalParameters ) { FunctionBody } 30 31 [...] 32 6. Let closure be FunctionCreate(kind, StrictFormalParameters, FunctionBody, 33 scope, strict). If functionPrototype was passed as a parameter then pass its 34 value as the functionPrototype optional argument of FunctionCreate. 35 [...] 36 37 9.2.1 [[Call]] ( thisArgument, argumentsList) 38 39 [...] 40 7. Let result be OrdinaryCallEvaluateBody(F, argumentsList). 41 [...] 42 43 9.2.1.3 OrdinaryCallEvaluateBody ( F, argumentsList ) 44 45 1. Let status be FunctionDeclarationInstantiation(F, argumentsList). 46 [...] 47 48 9.2.12 FunctionDeclarationInstantiation(func, argumentsList) 49 50 [...] 51 23. Let iteratorRecord be Record {[[iterator]]: 52 CreateListIterator(argumentsList), [[done]]: false}. 53 24. If hasDuplicates is true, then 54 [...] 55 25. Else, 56 b. Let formalStatus be IteratorBindingInitialization for formals with 57 iteratorRecord and env as arguments. 58 [...] 59 60 13.3.3.6 Runtime Semantics: IteratorBindingInitialization 61 62 SingleNameBinding : BindingIdentifier Initializeropt 63 64 [...] 65 6. If Initializer is present and v is undefined, then 66 [...] 67 7. If environment is undefined, return PutValue(lhs, v). 68 8. Return InitializeReferencedBinding(lhs, v). 69 ---*/ 70 var initCount = 0; 71 function counter() { 72 initCount += 1; 73 } 74 75 var callCount = 0; 76 var C = class { 77 static #method([w = counter(), x = counter(), y = counter(), z = counter()]) { 78 assert.sameValue(w, null); 79 assert.sameValue(x, 0); 80 assert.sameValue(y, false); 81 assert.sameValue(z, ''); 82 assert.sameValue(initCount, 0); 83 callCount = callCount + 1; 84 } 85 86 static get method() { 87 return this.#method; 88 } 89 }; 90 91 C.method([null, 0, false, '']); 92 assert.sameValue(callCount, 1, 'method invoked exactly once'); 93 94 reportCompare(0, 0);