Index: src/full-codegen/arm/full-codegen-arm.cc |
diff --git a/src/full-codegen/arm/full-codegen-arm.cc b/src/full-codegen/arm/full-codegen-arm.cc |
index 2612e224a7569260bca12bfa9a96436934f7a95a..3e020a4365591b9ab3e231ed3f829df2b06f1f6b 100644 |
--- a/src/full-codegen/arm/full-codegen-arm.cc |
+++ b/src/full-codegen/arm/full-codegen-arm.cc |
@@ -1592,8 +1592,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()); |
@@ -1616,27 +1615,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(r0); |
- result_saved = false; |
- } |
- for (; array_index < length; array_index++) { |
- Expression* subexpr = subexprs->at(array_index); |
- |
- PushOperand(r0); |
- DCHECK(!subexpr->IsSpread()); |
- VisitForStackValue(subexpr); |
- CallRuntimeWithOperands(Runtime::kAppendElement); |
- |
- PrepareForBailoutForId(expr->GetIdForElement(array_index), |
- BailoutState::NO_REGISTERS); |
- } |
- |
if (result_saved) { |
context()->PlugTOS(); |
} else { |