array-rest-iter-thrw-close.js (2815B)
1 // This file was procedurally generated from the following sources: 2 // - src/dstr-assignment/array-rest-iter-thrw-close.case 3 // - src/dstr-assignment/error/for-of.template 4 /*--- 5 description: IteratorClose is called when reference evaluation produces a "throw" completion (For..of statement) 6 esid: sec-for-in-and-for-of-statements-runtime-semantics-labelledevaluation 7 features: [Symbol.iterator, destructuring-binding] 8 flags: [generated] 9 info: | 10 IterationStatement : 11 for ( LeftHandSideExpression of AssignmentExpression ) Statement 12 13 1. Let keyResult be the result of performing ? ForIn/OfHeadEvaluation(« », 14 AssignmentExpression, iterate). 15 2. Return ? ForIn/OfBodyEvaluation(LeftHandSideExpression, Statement, 16 keyResult, assignment, labelSet). 17 18 13.7.5.13 Runtime Semantics: ForIn/OfBodyEvaluation 19 20 [...] 21 4. If destructuring is true and if lhsKind is assignment, then 22 a. Assert: lhs is a LeftHandSideExpression. 23 b. Let assignmentPattern be the parse of the source text corresponding to 24 lhs using AssignmentPattern as the goal symbol. 25 [...] 26 27 ArrayAssignmentPattern : [ Elisionopt AssignmentRestElement ] 28 29 [...] 30 5. Let result be the result of performing 31 IteratorDestructuringAssignmentEvaluation of AssignmentRestElement with 32 iteratorRecord as the argument 33 6. If iteratorRecord.[[done]] is false, return IteratorClose(iterator, 34 result). 35 36 AssignmentRestElement[Yield] : ... DestructuringAssignmentTarget 37 38 1. If DestructuringAssignmentTarget is neither an ObjectLiteral nor an 39 ArrayLiteral, then 40 a. Let lref be the result of evaluating DestructuringAssignmentTarget. 41 b. ReturnIfAbrupt(lref). 42 43 7.4.6 IteratorClose( iterator, completion ) 44 45 [...] 46 6. Let innerResult be Call(return, iterator, « »). 47 [...] 48 49 ---*/ 50 var nextCount = 0; 51 var returnCount = 0; 52 var thisValue = null; 53 var args = null; 54 var x; 55 var iterable = {}; 56 var iterator = { 57 next: function() { 58 nextCount += 1; 59 // Set an upper-bound to limit unnecessary iteration in non-conformant 60 // implementations 61 return { done: nextCount > 10 }; 62 }, 63 return: function() { 64 returnCount += 1; 65 thisValue = this; 66 args = arguments; 67 } 68 }; 69 var thrower = function() { 70 throw new Test262Error(); 71 }; 72 iterable[Symbol.iterator] = function() { 73 return iterator; 74 }; 75 76 var counter = 0; 77 78 assert.throws(Test262Error, function() { 79 for ([...{}[thrower()]] of [iterable]) { 80 counter += 1; 81 } 82 counter += 1; 83 }); 84 85 assert.sameValue(counter, 0); 86 87 assert.sameValue(nextCount, 0); 88 assert.sameValue(returnCount, 1); 89 assert.sameValue(thisValue, iterator, 'correct `this` value'); 90 assert(!!args, 'arguments object provided'); 91 assert.sameValue(args.length, 0, 'zero arguments specified'); 92 93 reportCompare(0, 0);