mirror of https://github.com/tc39/test262.git
51 lines
1.7 KiB
JavaScript
51 lines
1.7 KiB
JavaScript
|
// This file was procedurally generated from the following sources:
|
||
|
// - src/spread/mult-literal.case
|
||
|
// - src/spread/default/array.template
|
||
|
/*---
|
||
|
description: Spread operator applied to AssignmentExpression following other elements (Array initializer)
|
||
|
esid: sec-runtime-semantics-arrayaccumulation
|
||
|
es6id: 12.2.5.2
|
||
|
flags: [generated]
|
||
|
info: |
|
||
|
SpreadElement : ...AssignmentExpression
|
||
|
|
||
|
1. Let spreadRef be the result of evaluating AssignmentExpression.
|
||
|
2. Let spreadObj be ? GetValue(spreadRef).
|
||
|
3. Let iterator be ? GetIterator(spreadObj).
|
||
|
4. Repeat
|
||
|
a. Let next be ? IteratorStep(iterator).
|
||
|
b. If next is false, return nextIndex.
|
||
|
c. Let nextValue be ? IteratorValue(next).
|
||
|
d. Let status be CreateDataProperty(array, ToString(ToUint32(nextIndex)),
|
||
|
nextValue).
|
||
|
e. Assert: status is true.
|
||
|
f. Let nextIndex be nextIndex + 1.
|
||
|
|
||
|
12.3.6.1 Runtime Semantics: ArgumentListEvaluation
|
||
|
|
||
|
ArgumentList : ArgumentList , ... AssignmentExpression
|
||
|
|
||
|
1. Let precedingArgs be the result of evaluating ArgumentList.
|
||
|
2. Let spreadRef be the result of evaluating AssignmentExpression.
|
||
|
3. Let iterator be GetIterator(GetValue(spreadRef) ).
|
||
|
4. ReturnIfAbrupt(iterator).
|
||
|
5. Repeat
|
||
|
a. Let next be IteratorStep(iterator).
|
||
|
b. ReturnIfAbrupt(next).
|
||
|
c. If next is false, return precedingArgs.
|
||
|
---*/
|
||
|
|
||
|
var callCount = 0;
|
||
|
|
||
|
(function() {
|
||
|
assert.sameValue(arguments.length, 5);
|
||
|
assert.sameValue(arguments[0], 5);
|
||
|
assert.sameValue(arguments[1], 6);
|
||
|
assert.sameValue(arguments[2], 7);
|
||
|
assert.sameValue(arguments[3], 8);
|
||
|
assert.sameValue(arguments[4], 9);
|
||
|
callCount += 1;
|
||
|
}.apply(null, [5, ...[6, 7, 8], 9]));
|
||
|
|
||
|
assert.sameValue(callCount, 1);
|