Index: src/full-codegen/ppc/full-codegen-ppc.cc |
diff --git a/src/full-codegen/ppc/full-codegen-ppc.cc b/src/full-codegen/ppc/full-codegen-ppc.cc |
index e3a6b4b84c70fcb362b16fbb8a643fad60cb2110..f0f12e903cb4de839d2e60c2388e33cf7f637272 100644 |
--- a/src/full-codegen/ppc/full-codegen-ppc.cc |
+++ b/src/full-codegen/ppc/full-codegen-ppc.cc |
@@ -1553,8 +1553,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()); |
// If the subexpression is a literal or a simple materialized literal it |
@@ -1577,27 +1576,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(r3); |
- result_saved = false; |
- } |
- for (; array_index < length; array_index++) { |
- Expression* subexpr = subexprs->at(array_index); |
- |
- PushOperand(r3); |
- DCHECK(!subexpr->IsSpread()); |
- VisitForStackValue(subexpr); |
- CallRuntimeWithOperands(Runtime::kAppendElement); |
- |
- PrepareForBailoutForId(expr->GetIdForElement(array_index), |
- BailoutState::NO_REGISTERS); |
- } |
- |
if (result_saved) { |
context()->PlugTOS(); |
} else { |