| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "src/ast.h" | 5 #include "src/ast.h" |
| 6 | 6 |
| 7 #include <cmath> // For isfinite. | 7 #include <cmath> // For isfinite. |
| 8 #include "src/builtins.h" | 8 #include "src/builtins.h" |
| 9 #include "src/code-stubs.h" | 9 #include "src/code-stubs.h" |
| 10 #include "src/contexts.h" | 10 #include "src/contexts.h" |
| (...skipping 503 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 514 has_elements_ = elements > 0; | 514 has_elements_ = elements > 0; |
| 515 set_is_simple(is_simple); | 515 set_is_simple(is_simple); |
| 516 set_depth(depth_acc); | 516 set_depth(depth_acc); |
| 517 } | 517 } |
| 518 | 518 |
| 519 | 519 |
| 520 void ArrayLiteral::BuildConstantElements(Isolate* isolate) { | 520 void ArrayLiteral::BuildConstantElements(Isolate* isolate) { |
| 521 if (!constant_elements_.is_null()) return; | 521 if (!constant_elements_.is_null()) return; |
| 522 | 522 |
| 523 // Allocate a fixed array to hold all the object literals. | 523 // Allocate a fixed array to hold all the object literals. |
| 524 Handle<JSArray> array = | 524 Handle<JSArray> array = isolate->factory()->NewJSArray( |
| 525 isolate->factory()->NewJSArray(0, FAST_HOLEY_SMI_ELEMENTS); | 525 FAST_HOLEY_SMI_ELEMENTS, values()->length(), values()->length(), |
| 526 JSArray::Expand(array, values()->length()); | 526 Strength::WEAK, INITIALIZE_ARRAY_ELEMENTS_WITH_HOLE); |
| 527 | 527 |
| 528 // Fill in the literals. | 528 // Fill in the literals. |
| 529 bool is_simple = true; | 529 bool is_simple = true; |
| 530 int depth_acc = 1; | 530 int depth_acc = 1; |
| 531 bool is_holey = false; | 531 bool is_holey = false; |
| 532 int array_index = 0; | 532 int array_index = 0; |
| 533 for (int n = values()->length(); array_index < n; array_index++) { | 533 for (int n = values()->length(); array_index < n; array_index++) { |
| 534 Expression* element = values()->at(array_index); | 534 Expression* element = values()->at(array_index); |
| 535 if (element->IsSpread()) break; | 535 if (element->IsSpread()) break; |
| 536 MaterializedLiteral* m_literal = element->AsMaterializedLiteral(); | 536 MaterializedLiteral* m_literal = element->AsMaterializedLiteral(); |
| (...skipping 620 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1157 bool Literal::Match(void* literal1, void* literal2) { | 1157 bool Literal::Match(void* literal1, void* literal2) { |
| 1158 const AstValue* x = static_cast<Literal*>(literal1)->raw_value(); | 1158 const AstValue* x = static_cast<Literal*>(literal1)->raw_value(); |
| 1159 const AstValue* y = static_cast<Literal*>(literal2)->raw_value(); | 1159 const AstValue* y = static_cast<Literal*>(literal2)->raw_value(); |
| 1160 return (x->IsString() && y->IsString() && x->AsString() == y->AsString()) || | 1160 return (x->IsString() && y->IsString() && x->AsString() == y->AsString()) || |
| 1161 (x->IsNumber() && y->IsNumber() && x->AsNumber() == y->AsNumber()); | 1161 (x->IsNumber() && y->IsNumber() && x->AsNumber() == y->AsNumber()); |
| 1162 } | 1162 } |
| 1163 | 1163 |
| 1164 | 1164 |
| 1165 } // namespace internal | 1165 } // namespace internal |
| 1166 } // namespace v8 | 1166 } // namespace v8 |
| OLD | NEW |