Index: src/full-codegen/arm64/full-codegen-arm64.cc |
diff --git a/src/full-codegen/arm64/full-codegen-arm64.cc b/src/full-codegen/arm64/full-codegen-arm64.cc |
index 0570774234dc8ff48e560df2f67d99e6661e2f1a..c2ec9b6b27482a35ed5b63614ef695d2860aa479 100644 |
--- a/src/full-codegen/arm64/full-codegen-arm64.cc |
+++ b/src/full-codegen/arm64/full-codegen-arm64.cc |
@@ -1575,8 +1575,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()); |
@@ -1599,27 +1598,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(x0); |
- result_saved = false; |
- } |
- for (; array_index < length; array_index++) { |
- Expression* subexpr = subexprs->at(array_index); |
- |
- PushOperand(x0); |
- DCHECK(!subexpr->IsSpread()); |
- VisitForStackValue(subexpr); |
- CallRuntimeWithOperands(Runtime::kAppendElement); |
- |
- PrepareForBailoutForId(expr->GetIdForElement(array_index), |
- BailoutState::NO_REGISTERS); |
- } |
- |
if (result_saved) { |
context()->PlugTOS(); |
} else { |