[cleanup] Remove dead code for handling pre-desugaring spread implementation
The array spread operator is now handled by desugaring in the parser. Review-Url: https://codereview.chromium.org/2324013002 Cr-Commit-Position: refs/heads/master@{#39317}
This commit is contained in:
parent
39c9158f8e
commit
ca7eaa30a1
@ -649,8 +649,7 @@ void ArrayLiteral::AssignFeedbackVectorSlots(Isolate* isolate,
|
|||||||
FeedbackVectorSlotCache* cache) {
|
FeedbackVectorSlotCache* cache) {
|
||||||
// This logic that computes the number of slots needed for vector store
|
// This logic that computes the number of slots needed for vector store
|
||||||
// ics must mirror FullCodeGenerator::VisitArrayLiteral.
|
// ics must mirror FullCodeGenerator::VisitArrayLiteral.
|
||||||
int array_index = 0;
|
for (int array_index = 0; array_index < values()->length(); array_index++) {
|
||||||
for (; array_index < values()->length(); array_index++) {
|
|
||||||
Expression* subexpr = values()->at(array_index);
|
Expression* subexpr = values()->at(array_index);
|
||||||
DCHECK(!subexpr->IsSpread());
|
DCHECK(!subexpr->IsSpread());
|
||||||
if (CompileTimeValue::IsCompileTimeValue(subexpr)) continue;
|
if (CompileTimeValue::IsCompileTimeValue(subexpr)) continue;
|
||||||
|
@ -1948,8 +1948,8 @@ void AstGraphBuilder::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
|
|
||||||
// Create nodes to evaluate all the non-constant subexpressions and to store
|
// Create nodes to evaluate all the non-constant subexpressions and to store
|
||||||
// them into the newly cloned array.
|
// them into the newly cloned array.
|
||||||
int array_index = 0;
|
for (int array_index = 0; array_index < expr->values()->length();
|
||||||
for (; array_index < expr->values()->length(); array_index++) {
|
array_index++) {
|
||||||
Expression* subexpr = expr->values()->at(array_index);
|
Expression* subexpr = expr->values()->at(array_index);
|
||||||
DCHECK(!subexpr->IsSpread());
|
DCHECK(!subexpr->IsSpread());
|
||||||
if (CompileTimeValue::IsCompileTimeValue(subexpr)) continue;
|
if (CompileTimeValue::IsCompileTimeValue(subexpr)) continue;
|
||||||
@ -1964,26 +1964,6 @@ void AstGraphBuilder::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
OutputFrameStateCombine::Ignore());
|
OutputFrameStateCombine::Ignore());
|
||||||
}
|
}
|
||||||
|
|
||||||
// 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.
|
|
||||||
for (; array_index < expr->values()->length(); array_index++) {
|
|
||||||
Expression* subexpr = expr->values()->at(array_index);
|
|
||||||
DCHECK(!subexpr->IsSpread());
|
|
||||||
|
|
||||||
VisitForValue(subexpr);
|
|
||||||
{
|
|
||||||
Node* value = environment()->Pop();
|
|
||||||
Node* array = environment()->Pop();
|
|
||||||
const Operator* op = javascript()->CallRuntime(Runtime::kAppendElement);
|
|
||||||
Node* result = NewNode(op, array, value);
|
|
||||||
PrepareFrameState(result, expr->GetIdForElement(array_index));
|
|
||||||
environment()->Push(result);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ast_context()->ProduceValue(expr, environment()->Pop());
|
ast_context()->ProduceValue(expr, environment()->Pop());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1592,8 +1592,7 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
|
|
||||||
// Emit code to evaluate all the non-constant subexpressions and to store
|
// Emit code to evaluate all the non-constant subexpressions and to store
|
||||||
// them into the newly cloned array.
|
// them into the newly cloned array.
|
||||||
int array_index = 0;
|
for (int array_index = 0; array_index < length; array_index++) {
|
||||||
for (; array_index < length; array_index++) {
|
|
||||||
Expression* subexpr = subexprs->at(array_index);
|
Expression* subexpr = subexprs->at(array_index);
|
||||||
DCHECK(!subexpr->IsSpread());
|
DCHECK(!subexpr->IsSpread());
|
||||||
|
|
||||||
@ -1616,27 +1615,6 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
BailoutState::NO_REGISTERS);
|
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) {
|
if (result_saved) {
|
||||||
context()->PlugTOS();
|
context()->PlugTOS();
|
||||||
} else {
|
} else {
|
||||||
|
@ -1575,8 +1575,7 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
|
|
||||||
// Emit code to evaluate all the non-constant subexpressions and to store
|
// Emit code to evaluate all the non-constant subexpressions and to store
|
||||||
// them into the newly cloned array.
|
// them into the newly cloned array.
|
||||||
int array_index = 0;
|
for (int array_index = 0; array_index < length; array_index++) {
|
||||||
for (; array_index < length; array_index++) {
|
|
||||||
Expression* subexpr = subexprs->at(array_index);
|
Expression* subexpr = subexprs->at(array_index);
|
||||||
DCHECK(!subexpr->IsSpread());
|
DCHECK(!subexpr->IsSpread());
|
||||||
|
|
||||||
@ -1599,27 +1598,6 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
BailoutState::NO_REGISTERS);
|
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) {
|
if (result_saved) {
|
||||||
context()->PlugTOS();
|
context()->PlugTOS();
|
||||||
} else {
|
} else {
|
||||||
|
@ -1509,8 +1509,7 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
|
|
||||||
// Emit code to evaluate all the non-constant subexpressions and to store
|
// Emit code to evaluate all the non-constant subexpressions and to store
|
||||||
// them into the newly cloned array.
|
// them into the newly cloned array.
|
||||||
int array_index = 0;
|
for (int array_index = 0; array_index < length; array_index++) {
|
||||||
for (; array_index < length; array_index++) {
|
|
||||||
Expression* subexpr = subexprs->at(array_index);
|
Expression* subexpr = subexprs->at(array_index);
|
||||||
DCHECK(!subexpr->IsSpread());
|
DCHECK(!subexpr->IsSpread());
|
||||||
|
|
||||||
@ -1533,27 +1532,6 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
BailoutState::NO_REGISTERS);
|
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(eax);
|
|
||||||
result_saved = false;
|
|
||||||
}
|
|
||||||
for (; array_index < length; array_index++) {
|
|
||||||
Expression* subexpr = subexprs->at(array_index);
|
|
||||||
|
|
||||||
PushOperand(eax);
|
|
||||||
DCHECK(!subexpr->IsSpread());
|
|
||||||
VisitForStackValue(subexpr);
|
|
||||||
CallRuntimeWithOperands(Runtime::kAppendElement);
|
|
||||||
|
|
||||||
PrepareForBailoutForId(expr->GetIdForElement(array_index),
|
|
||||||
BailoutState::NO_REGISTERS);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (result_saved) {
|
if (result_saved) {
|
||||||
context()->PlugTOS();
|
context()->PlugTOS();
|
||||||
} else {
|
} else {
|
||||||
|
@ -1587,8 +1587,7 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
|
|
||||||
// Emit code to evaluate all the non-constant subexpressions and to store
|
// Emit code to evaluate all the non-constant subexpressions and to store
|
||||||
// them into the newly cloned array.
|
// them into the newly cloned array.
|
||||||
int array_index = 0;
|
for (int array_index = 0; array_index < length; array_index++) {
|
||||||
for (; array_index < length; array_index++) {
|
|
||||||
Expression* subexpr = subexprs->at(array_index);
|
Expression* subexpr = subexprs->at(array_index);
|
||||||
DCHECK(!subexpr->IsSpread());
|
DCHECK(!subexpr->IsSpread());
|
||||||
|
|
||||||
@ -1613,27 +1612,6 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
BailoutState::NO_REGISTERS);
|
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) {
|
if (result_saved) {
|
||||||
context()->PlugTOS();
|
context()->PlugTOS();
|
||||||
} else {
|
} else {
|
||||||
|
@ -1588,8 +1588,7 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
|
|
||||||
// Emit code to evaluate all the non-constant subexpressions and to store
|
// Emit code to evaluate all the non-constant subexpressions and to store
|
||||||
// them into the newly cloned array.
|
// them into the newly cloned array.
|
||||||
int array_index = 0;
|
for (int array_index = 0; array_index < length; array_index++) {
|
||||||
for (; array_index < length; array_index++) {
|
|
||||||
Expression* subexpr = subexprs->at(array_index);
|
Expression* subexpr = subexprs->at(array_index);
|
||||||
DCHECK(!subexpr->IsSpread());
|
DCHECK(!subexpr->IsSpread());
|
||||||
|
|
||||||
@ -1614,27 +1613,6 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
BailoutState::NO_REGISTERS);
|
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) {
|
if (result_saved) {
|
||||||
context()->PlugTOS();
|
context()->PlugTOS();
|
||||||
} else {
|
} else {
|
||||||
|
@ -1553,8 +1553,7 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
|
|
||||||
// Emit code to evaluate all the non-constant subexpressions and to store
|
// Emit code to evaluate all the non-constant subexpressions and to store
|
||||||
// them into the newly cloned array.
|
// them into the newly cloned array.
|
||||||
int array_index = 0;
|
for (int array_index = 0; array_index < length; array_index++) {
|
||||||
for (; array_index < length; array_index++) {
|
|
||||||
Expression* subexpr = subexprs->at(array_index);
|
Expression* subexpr = subexprs->at(array_index);
|
||||||
DCHECK(!subexpr->IsSpread());
|
DCHECK(!subexpr->IsSpread());
|
||||||
// If the subexpression is a literal or a simple materialized literal it
|
// If the subexpression is a literal or a simple materialized literal it
|
||||||
@ -1577,27 +1576,6 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
BailoutState::NO_REGISTERS);
|
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) {
|
if (result_saved) {
|
||||||
context()->PlugTOS();
|
context()->PlugTOS();
|
||||||
} else {
|
} else {
|
||||||
|
@ -1513,8 +1513,7 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
|
|
||||||
// Emit code to evaluate all the non-constant subexpressions and to store
|
// Emit code to evaluate all the non-constant subexpressions and to store
|
||||||
// them into the newly cloned array.
|
// them into the newly cloned array.
|
||||||
int array_index = 0;
|
for (int array_index = 0; array_index < length; array_index++) {
|
||||||
for (; array_index < length; array_index++) {
|
|
||||||
Expression* subexpr = subexprs->at(array_index);
|
Expression* subexpr = subexprs->at(array_index);
|
||||||
DCHECK(!subexpr->IsSpread());
|
DCHECK(!subexpr->IsSpread());
|
||||||
// If the subexpression is a literal or a simple materialized literal it
|
// If the subexpression is a literal or a simple materialized literal it
|
||||||
@ -1537,27 +1536,6 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
BailoutState::NO_REGISTERS);
|
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(r2);
|
|
||||||
result_saved = false;
|
|
||||||
}
|
|
||||||
for (; array_index < length; array_index++) {
|
|
||||||
Expression* subexpr = subexprs->at(array_index);
|
|
||||||
|
|
||||||
PushOperand(r2);
|
|
||||||
DCHECK(!subexpr->IsSpread());
|
|
||||||
VisitForStackValue(subexpr);
|
|
||||||
CallRuntimeWithOperands(Runtime::kAppendElement);
|
|
||||||
|
|
||||||
PrepareForBailoutForId(expr->GetIdForElement(array_index),
|
|
||||||
BailoutState::NO_REGISTERS);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (result_saved) {
|
if (result_saved) {
|
||||||
context()->PlugTOS();
|
context()->PlugTOS();
|
||||||
} else {
|
} else {
|
||||||
|
@ -1536,8 +1536,7 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
|
|
||||||
// Emit code to evaluate all the non-constant subexpressions and to store
|
// Emit code to evaluate all the non-constant subexpressions and to store
|
||||||
// them into the newly cloned array.
|
// them into the newly cloned array.
|
||||||
int array_index = 0;
|
for (int array_index = 0; array_index < length; array_index++) {
|
||||||
for (; array_index < length; array_index++) {
|
|
||||||
Expression* subexpr = subexprs->at(array_index);
|
Expression* subexpr = subexprs->at(array_index);
|
||||||
DCHECK(!subexpr->IsSpread());
|
DCHECK(!subexpr->IsSpread());
|
||||||
|
|
||||||
@ -1560,27 +1559,6 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
BailoutState::NO_REGISTERS);
|
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(rax);
|
|
||||||
result_saved = false;
|
|
||||||
}
|
|
||||||
for (; array_index < length; array_index++) {
|
|
||||||
Expression* subexpr = subexprs->at(array_index);
|
|
||||||
|
|
||||||
PushOperand(rax);
|
|
||||||
DCHECK(!subexpr->IsSpread());
|
|
||||||
VisitForStackValue(subexpr);
|
|
||||||
CallRuntimeWithOperands(Runtime::kAppendElement);
|
|
||||||
|
|
||||||
PrepareForBailoutForId(expr->GetIdForElement(array_index),
|
|
||||||
BailoutState::NO_REGISTERS);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (result_saved) {
|
if (result_saved) {
|
||||||
context()->PlugTOS();
|
context()->PlugTOS();
|
||||||
} else {
|
} else {
|
||||||
|
@ -1501,8 +1501,7 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
|
|
||||||
// Emit code to evaluate all the non-constant subexpressions and to store
|
// Emit code to evaluate all the non-constant subexpressions and to store
|
||||||
// them into the newly cloned array.
|
// them into the newly cloned array.
|
||||||
int array_index = 0;
|
for (int array_index = 0; array_index < length; array_index++) {
|
||||||
for (; array_index < length; array_index++) {
|
|
||||||
Expression* subexpr = subexprs->at(array_index);
|
Expression* subexpr = subexprs->at(array_index);
|
||||||
DCHECK(!subexpr->IsSpread());
|
DCHECK(!subexpr->IsSpread());
|
||||||
|
|
||||||
@ -1525,27 +1524,6 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
|||||||
BailoutState::NO_REGISTERS);
|
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(eax);
|
|
||||||
result_saved = false;
|
|
||||||
}
|
|
||||||
for (; array_index < length; array_index++) {
|
|
||||||
Expression* subexpr = subexprs->at(array_index);
|
|
||||||
|
|
||||||
PushOperand(eax);
|
|
||||||
DCHECK(!subexpr->IsSpread());
|
|
||||||
VisitForStackValue(subexpr);
|
|
||||||
CallRuntimeWithOperands(Runtime::kAppendElement);
|
|
||||||
|
|
||||||
PrepareForBailoutForId(expr->GetIdForElement(array_index),
|
|
||||||
BailoutState::NO_REGISTERS);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (result_saved) {
|
if (result_saved) {
|
||||||
context()->PlugTOS();
|
context()->PlugTOS();
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user