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/interpreter/bytecode-array-builder.h" | 5 #include "src/interpreter/bytecode-array-builder.h" |
6 | 6 |
7 #include "src/globals.h" | 7 #include "src/globals.h" |
8 #include "src/interpreter/bytecode-array-writer.h" | 8 #include "src/interpreter/bytecode-array-writer.h" |
9 #include "src/interpreter/bytecode-dead-code-optimizer.h" | 9 #include "src/interpreter/bytecode-dead-code-optimizer.h" |
10 #include "src/interpreter/bytecode-label.h" | 10 #include "src/interpreter/bytecode-label.h" |
(...skipping 707 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
718 OutputJumpIfUndefined(label, 0); | 718 OutputJumpIfUndefined(label, 0); |
719 return *this; | 719 return *this; |
720 } | 720 } |
721 | 721 |
722 BytecodeArrayBuilder& BytecodeArrayBuilder::JumpIfNotHole( | 722 BytecodeArrayBuilder& BytecodeArrayBuilder::JumpIfNotHole( |
723 BytecodeLabel* label) { | 723 BytecodeLabel* label) { |
724 OutputJumpIfNotHole(label, 0); | 724 OutputJumpIfNotHole(label, 0); |
725 return *this; | 725 return *this; |
726 } | 726 } |
727 | 727 |
| 728 BytecodeArrayBuilder& BytecodeArrayBuilder::JumpIfJSReceiver( |
| 729 BytecodeLabel* label) { |
| 730 OutputJumpIfJSReceiver(label, 0); |
| 731 return *this; |
| 732 } |
| 733 |
728 BytecodeArrayBuilder& BytecodeArrayBuilder::JumpLoop(BytecodeLabel* label, | 734 BytecodeArrayBuilder& BytecodeArrayBuilder::JumpLoop(BytecodeLabel* label, |
729 int loop_depth) { | 735 int loop_depth) { |
730 OutputJumpLoop(label, 0, loop_depth); | 736 OutputJumpLoop(label, 0, loop_depth); |
731 return *this; | 737 return *this; |
732 } | 738 } |
733 | 739 |
734 BytecodeArrayBuilder& BytecodeArrayBuilder::StackCheck(int position) { | 740 BytecodeArrayBuilder& BytecodeArrayBuilder::StackCheck(int position) { |
735 if (position != kNoSourcePosition) { | 741 if (position != kNoSourcePosition) { |
736 // We need to attach a non-breakable source position to a stack | 742 // We need to attach a non-breakable source position to a stack |
737 // check, so we simply add it as expression position. There can be | 743 // check, so we simply add it as expression position. There can be |
(...skipping 282 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1020 RegisterList reg_list) { | 1026 RegisterList reg_list) { |
1021 DCHECK(RegisterListIsValid(reg_list)); | 1027 DCHECK(RegisterListIsValid(reg_list)); |
1022 if (register_optimizer_) | 1028 if (register_optimizer_) |
1023 register_optimizer_->PrepareOutputRegisterList(reg_list); | 1029 register_optimizer_->PrepareOutputRegisterList(reg_list); |
1024 return static_cast<uint32_t>(reg_list.first_register().ToOperand()); | 1030 return static_cast<uint32_t>(reg_list.first_register().ToOperand()); |
1025 } | 1031 } |
1026 | 1032 |
1027 } // namespace interpreter | 1033 } // namespace interpreter |
1028 } // namespace internal | 1034 } // namespace internal |
1029 } // namespace v8 | 1035 } // namespace v8 |
OLD | NEW |