| Index: src/full-codegen/mips/full-codegen-mips.cc
|
| diff --git a/src/full-codegen/mips/full-codegen-mips.cc b/src/full-codegen/mips/full-codegen-mips.cc
|
| index 7f7799920d83b96240cdad4cd366d9115966a1f9..e3c9dfb1812ecec21240fbf418ad311f614c1fc1 100644
|
| --- a/src/full-codegen/mips/full-codegen-mips.cc
|
| +++ b/src/full-codegen/mips/full-codegen-mips.cc
|
| @@ -1587,8 +1587,7 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|
|
| // Emit code to evaluate all the non-constant subexpressions and to store
|
| // them into the newly cloned array.
|
| - int array_index = 0;
|
| - for (; array_index < length; array_index++) {
|
| + for (int array_index = 0; array_index < length; array_index++) {
|
| Expression* subexpr = subexprs->at(array_index);
|
| DCHECK(!subexpr->IsSpread());
|
|
|
| @@ -1613,27 +1612,6 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
| BailoutState::NO_REGISTERS);
|
| }
|
|
|
| - // In case the array literal contains spread expressions it has two parts. The
|
| - // first part is the "static" array which has a literal index is handled
|
| - // above. The second part is the part after the first spread expression
|
| - // (inclusive) and these elements gets appended to the array. Note that the
|
| - // number elements an iterable produces is unknown ahead of time.
|
| - if (array_index < length && result_saved) {
|
| - PopOperand(v0);
|
| - result_saved = false;
|
| - }
|
| - for (; array_index < length; array_index++) {
|
| - Expression* subexpr = subexprs->at(array_index);
|
| -
|
| - PushOperand(v0);
|
| - DCHECK(!subexpr->IsSpread());
|
| - VisitForStackValue(subexpr);
|
| - CallRuntimeWithOperands(Runtime::kAppendElement);
|
| -
|
| - PrepareForBailoutForId(expr->GetIdForElement(array_index),
|
| - BailoutState::NO_REGISTERS);
|
| - }
|
| -
|
| if (result_saved) {
|
| context()->PlugTOS();
|
| } else {
|
|
|