| OLD | NEW |
| 1 // Copyright 2015 the V8 project authors. All rights reserved. | 1 // Copyright 2015 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/v8.h" | 5 #include "src/v8.h" |
| 6 | 6 |
| 7 #include "src/compiler.h" | 7 #include "src/compiler.h" |
| 8 #include "src/interpreter/bytecode-array-iterator.h" | 8 #include "src/interpreter/bytecode-array-iterator.h" |
| 9 #include "src/interpreter/bytecode-generator.h" | 9 #include "src/interpreter/bytecode-generator.h" |
| 10 #include "src/interpreter/interpreter.h" | 10 #include "src/interpreter/interpreter.h" |
| (...skipping 406 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 417 TEST(PropertyLoads) { | 417 TEST(PropertyLoads) { |
| 418 InitializedHandleScope handle_scope; | 418 InitializedHandleScope handle_scope; |
| 419 BytecodeGeneratorHelper helper; | 419 BytecodeGeneratorHelper helper; |
| 420 Zone zone; | 420 Zone zone; |
| 421 | 421 |
| 422 FeedbackVectorSpec feedback_spec(&zone); | 422 FeedbackVectorSpec feedback_spec(&zone); |
| 423 FeedbackVectorSlot slot1 = feedback_spec.AddLoadICSlot(); | 423 FeedbackVectorSlot slot1 = feedback_spec.AddLoadICSlot(); |
| 424 FeedbackVectorSlot slot2 = feedback_spec.AddLoadICSlot(); | 424 FeedbackVectorSlot slot2 = feedback_spec.AddLoadICSlot(); |
| 425 | 425 |
| 426 Handle<i::TypeFeedbackVector> vector = | 426 Handle<i::TypeFeedbackVector> vector = |
| 427 i::TypeFeedbackVector::New(helper.isolate(), &feedback_spec); | 427 i::NewTypeFeedbackVector(helper.isolate(), &feedback_spec); |
| 428 | 428 |
| 429 ExpectedSnippet<const char*> snippets[] = { | 429 ExpectedSnippet<const char*> snippets[] = { |
| 430 {"function f(a) { return a.name; }\nf({name : \"test\"})", | 430 {"function f(a) { return a.name; }\nf({name : \"test\"})", |
| 431 1 * kPointerSize, | 431 1 * kPointerSize, |
| 432 2, | 432 2, |
| 433 10, | 433 10, |
| 434 { | 434 { |
| 435 B(Ldar), R(helper.kLastParamIndex), // | 435 B(Ldar), R(helper.kLastParamIndex), // |
| 436 B(Star), R(0), // | 436 B(Star), R(0), // |
| 437 B(LdaConstant), U8(0), // | 437 B(LdaConstant), U8(0), // |
| (...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 507 TEST(PropertyStores) { | 507 TEST(PropertyStores) { |
| 508 InitializedHandleScope handle_scope; | 508 InitializedHandleScope handle_scope; |
| 509 BytecodeGeneratorHelper helper; | 509 BytecodeGeneratorHelper helper; |
| 510 Zone zone; | 510 Zone zone; |
| 511 | 511 |
| 512 FeedbackVectorSpec feedback_spec(&zone); | 512 FeedbackVectorSpec feedback_spec(&zone); |
| 513 FeedbackVectorSlot slot1 = feedback_spec.AddStoreICSlot(); | 513 FeedbackVectorSlot slot1 = feedback_spec.AddStoreICSlot(); |
| 514 FeedbackVectorSlot slot2 = feedback_spec.AddStoreICSlot(); | 514 FeedbackVectorSlot slot2 = feedback_spec.AddStoreICSlot(); |
| 515 | 515 |
| 516 Handle<i::TypeFeedbackVector> vector = | 516 Handle<i::TypeFeedbackVector> vector = |
| 517 i::TypeFeedbackVector::New(helper.isolate(), &feedback_spec); | 517 i::NewTypeFeedbackVector(helper.isolate(), &feedback_spec); |
| 518 | 518 |
| 519 ExpectedSnippet<const char*> snippets[] = { | 519 ExpectedSnippet<const char*> snippets[] = { |
| 520 {"function f(a) { a.name = \"val\"; }\nf({name : \"test\"})", | 520 {"function f(a) { a.name = \"val\"; }\nf({name : \"test\"})", |
| 521 2 * kPointerSize, | 521 2 * kPointerSize, |
| 522 2, | 522 2, |
| 523 16, | 523 16, |
| 524 { | 524 { |
| 525 B(Ldar), R(helper.kLastParamIndex), // | 525 B(Ldar), R(helper.kLastParamIndex), // |
| 526 B(Star), R(0), // | 526 B(Star), R(0), // |
| 527 B(LdaConstant), U8(0), // | 527 B(LdaConstant), U8(0), // |
| (...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 616 InitializedHandleScope handle_scope; | 616 InitializedHandleScope handle_scope; |
| 617 BytecodeGeneratorHelper helper; // | 617 BytecodeGeneratorHelper helper; // |
| 618 Zone zone; | 618 Zone zone; |
| 619 | 619 |
| 620 FeedbackVectorSpec feedback_spec(&zone); | 620 FeedbackVectorSpec feedback_spec(&zone); |
| 621 FeedbackVectorSlot slot1 = feedback_spec.AddLoadICSlot(); | 621 FeedbackVectorSlot slot1 = feedback_spec.AddLoadICSlot(); |
| 622 FeedbackVectorSlot slot2 = feedback_spec.AddLoadICSlot(); | 622 FeedbackVectorSlot slot2 = feedback_spec.AddLoadICSlot(); |
| 623 USE(slot1); | 623 USE(slot1); |
| 624 | 624 |
| 625 Handle<i::TypeFeedbackVector> vector = | 625 Handle<i::TypeFeedbackVector> vector = |
| 626 i::TypeFeedbackVector::New(helper.isolate(), &feedback_spec); | 626 i::NewTypeFeedbackVector(helper.isolate(), &feedback_spec); |
| 627 | 627 |
| 628 ExpectedSnippet<const char*> snippets[] = { | 628 ExpectedSnippet<const char*> snippets[] = { |
| 629 {"function f(a) { return a.func(); }\nf(" FUNC_ARG ")", | 629 {"function f(a) { return a.func(); }\nf(" FUNC_ARG ")", |
| 630 2 * kPointerSize, | 630 2 * kPointerSize, |
| 631 2, | 631 2, |
| 632 16, | 632 16, |
| 633 { | 633 { |
| 634 B(Ldar), R(helper.kLastParamIndex), // | 634 B(Ldar), R(helper.kLastParamIndex), // |
| 635 B(Star), R(1), // | 635 B(Star), R(1), // |
| 636 B(LdaConstant), U8(0), // | 636 B(LdaConstant), U8(0), // |
| (...skipping 619 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1256 for (size_t i = 0; i < arraysize(snippets); i++) { | 1256 for (size_t i = 0; i < arraysize(snippets); i++) { |
| 1257 Handle<BytecodeArray> bytecode_array = | 1257 Handle<BytecodeArray> bytecode_array = |
| 1258 helper.MakeBytecodeForFunctionBody(snippets[i].code_snippet); | 1258 helper.MakeBytecodeForFunctionBody(snippets[i].code_snippet); |
| 1259 CheckBytecodeArrayEqual(snippets[i], bytecode_array); | 1259 CheckBytecodeArrayEqual(snippets[i], bytecode_array); |
| 1260 } | 1260 } |
| 1261 } | 1261 } |
| 1262 | 1262 |
| 1263 } // namespace interpreter | 1263 } // namespace interpreter |
| 1264 } // namespace internal | 1264 } // namespace internal |
| 1265 } // namespace v8 | 1265 } // namespace v8 |
| OLD | NEW |