tor-browser

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

private-gen-meth-static-ary-init-iter-close.js (3031B)


      1 // This file was procedurally generated from the following sources:
      2 // - src/dstr-binding/ary-init-iter-close.case
      3 // - src/dstr-binding/default/cls-decl-private-gen-meth-static.template
      4 /*---
      5 description: Iterator is closed when not exhausted by pattern evaluation (private static class expression generator method)
      6 esid: sec-runtime-semantics-bindingclassdeclarationevaluation
      7 features: [Symbol.iterator, class, class-static-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        b. Else,
     22           Let status be the result of performing PropertyDefinitionEvaluation for
     23           m with arguments F and 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.5 Runtime Semantics: BindingInitialization
     62 
     63    BindingPattern : ArrayBindingPattern
     64 
     65    [...]
     66    4. If iteratorRecord.[[done]] is false, return ? IteratorClose(iterator,
     67       result).
     68    [...]
     69 
     70 ---*/
     71 var doneCallCount = 0;
     72 var iter = {};
     73 iter[Symbol.iterator] = function() {
     74  return {
     75    next: function() {
     76      return { value: null, done: false };
     77    },
     78    return: function() {
     79      doneCallCount += 1;
     80      return {};
     81    }
     82  };
     83 };
     84 
     85 var callCount = 0;
     86 class C {
     87  static * #method([x]) {
     88    assert.sameValue(doneCallCount, 1);
     89    callCount = callCount + 1;
     90  }
     91 
     92  static get method() {
     93    return this.#method;
     94  }
     95 };
     96 
     97 C.method(iter).next();
     98 assert.sameValue(callCount, 1, 'method invoked exactly once');
     99 
    100 reportCompare(0, 0);