| // This file was procedurally generated from the following sources: |
| // - src/dstr-binding/ary-ptrn-rest-id-elision.case |
| // - src/dstr-binding/default/async-gen-func-decl.template |
| /*--- |
| description: Rest element following elision elements (async generator function declaration) |
| esid: sec-asyncgenerator-definitions-instantiatefunctionobject |
| features: [async-iteration] |
| flags: [generated, async] |
| info: | |
| AsyncGeneratorDeclaration : async [no LineTerminator here] function * BindingIdentifier |
| ( FormalParameters ) { AsyncGeneratorBody } |
| |
| [...] |
| 3. Let F be ! AsyncGeneratorFunctionCreate(Normal, FormalParameters, AsyncGeneratorBody, |
| scope, strict). |
| [...] |
| |
| |
| 13.3.3.6 Runtime Semantics: IteratorBindingInitialization |
| ArrayBindingPattern : [ Elisionopt BindingRestElement ] |
| 1. If Elision is present, then |
| a. Let status be the result of performing |
| IteratorDestructuringAssignmentEvaluation of Elision with |
| iteratorRecord as the argument. |
| b. ReturnIfAbrupt(status). |
| 2. Return the result of performing IteratorBindingInitialization for |
| BindingRestElement with iteratorRecord and environment as arguments. |
| ---*/ |
| var values = [1, 2, 3, 4, 5]; |
| |
| |
| var callCount = 0; |
| async function* f([ , , ...x]) { |
| assert(Array.isArray(x)); |
| assert.sameValue(x.length, 3); |
| assert.sameValue(x[0], 3); |
| assert.sameValue(x[1], 4); |
| assert.sameValue(x[2], 5); |
| assert.notSameValue(x, values); |
| callCount = callCount + 1; |
| }; |
| f(values).next().then(() => { |
| assert.sameValue(callCount, 1, 'invoked exactly once'); |
| }).then($DONE, $DONE); |