tor-browser

The Tor Browser
git clone https://git.dasho.dev/tor-browser.git
Log | Files | Refs | README | LICENSE

private-gen-meth-ary-ptrn-elem-ary-rest-init.js (3219B)


      1 // This file was procedurally generated from the following sources:
      2 // - src/dstr-binding/ary-ptrn-elem-ary-rest-init.case
      3 // - src/dstr-binding/default/cls-decl-private-gen-meth.template
      4 /*---
      5 description: BindingElement with array binding pattern and initializer is used (private class expression method)
      6 esid: sec-class-definitions-runtime-semantics-evaluation
      7 features: [class, class-methods-private, generators, destructuring-binding]
      8 flags: [generated]
      9 info: |
     10    ClassDeclaration : class BindingIdentifier ClassTail
     11 
     12    1. Let className be StringValue of BindingIdentifier.
     13    2. Let value be the result of ClassDefinitionEvaluation of ClassTail with
     14       argument className.
     15    [...]
     16 
     17    14.5.14 Runtime Semantics: ClassDefinitionEvaluation
     18 
     19    21. For each ClassElement m in order from methods
     20        a. If IsStatic of m is false, then
     21           i. Let status be the result of performing
     22              PropertyDefinitionEvaluation for m with arguments proto and
     23              false.
     24        [...]
     25 
     26    14.4.13 Runtime Semantics: PropertyDefinitionEvaluation
     27 
     28    GeneratorMethod : * PropertyName ( StrictFormalParameters ) { GeneratorBody }
     29 
     30    1. Let propKey be the result of evaluating PropertyName.
     31    2. ReturnIfAbrupt(propKey).
     32    3. If the function code for this GeneratorMethod is strict mode code,
     33       let strict be true. Otherwise let strict be false.
     34    4. Let scope be the running execution context's LexicalEnvironment.
     35    5. Let closure be GeneratorFunctionCreate(Method,
     36       StrictFormalParameters, GeneratorBody, scope, strict).
     37 
     38    9.2.1 [[Call]] ( thisArgument, argumentsList)
     39 
     40    [...]
     41    7. Let result be OrdinaryCallEvaluateBody(F, argumentsList).
     42    [...]
     43 
     44    9.2.1.3 OrdinaryCallEvaluateBody ( F, argumentsList )
     45 
     46    1. Let status be FunctionDeclarationInstantiation(F, argumentsList).
     47    [...]
     48 
     49    9.2.12 FunctionDeclarationInstantiation(func, argumentsList)
     50 
     51    [...]
     52    23. Let iteratorRecord be Record {[[iterator]]:
     53        CreateListIterator(argumentsList), [[done]]: false}.
     54    24. If hasDuplicates is true, then
     55        [...]
     56    25. Else,
     57        b. Let formalStatus be IteratorBindingInitialization for formals with
     58           iteratorRecord and env as arguments.
     59    [...]
     60 
     61    13.3.3.6 Runtime Semantics: IteratorBindingInitialization
     62 
     63    BindingElement : BindingPatternInitializer opt
     64 
     65    [...]
     66    2. If iteratorRecord.[[done]] is true, let v be undefined.
     67    3. If Initializer is present and v is undefined, then
     68       a. Let defaultValue be the result of evaluating Initializer.
     69       b. Let v be ? GetValue(defaultValue).
     70    4. Return the result of performing BindingInitialization of BindingPattern
     71       with v and environment as the arguments.
     72 ---*/
     73 var values = [2, 1, 3];
     74 
     75 var callCount = 0;
     76 class C {
     77  * #method([[...x] = values]) {
     78    assert(Array.isArray(x));
     79    assert.sameValue(x[0], 2);
     80    assert.sameValue(x[1], 1);
     81    assert.sameValue(x[2], 3);
     82    assert.sameValue(x.length, 3);
     83    assert.notSameValue(x, values);
     84    callCount = callCount + 1;
     85  }
     86 
     87  get method() {
     88    return this.#method;
     89  }
     90 };
     91 
     92 new C().method([]).next();
     93 assert.sameValue(callCount, 1, 'method invoked exactly once');
     94 
     95 reportCompare(0, 0);