OLD | NEW |
| (Empty) |
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 | |
3 // found in the LICENSE file. | |
4 | |
5 #include "src/interpreter/bytecode-array-reverse-iterator.h" | |
6 #include "src/objects-inl.h" | |
7 | |
8 namespace v8 { | |
9 namespace internal { | |
10 namespace interpreter { | |
11 | |
12 BytecodeArrayReverseIterator::BytecodeArrayReverseIterator( | |
13 Handle<BytecodeArray> bytecode_array, Zone* zone) | |
14 : BytecodeArrayAccessor(bytecode_array, 0), offsets_(zone) { | |
15 // Run forwards through the bytecode array to determine the offset of each | |
16 // bytecode. | |
17 while (current_offset() < bytecode_array->length()) { | |
18 offsets_.push_back(current_offset()); | |
19 SetOffset(current_offset() + current_bytecode_size()); | |
20 } | |
21 Reset(); | |
22 } | |
23 | |
24 void BytecodeArrayReverseIterator::Advance() { | |
25 it_offsets_++; | |
26 UpdateOffsetFromIterator(); | |
27 } | |
28 | |
29 void BytecodeArrayReverseIterator::Reset() { | |
30 it_offsets_ = offsets_.rbegin(); | |
31 UpdateOffsetFromIterator(); | |
32 } | |
33 | |
34 bool BytecodeArrayReverseIterator::done() const { | |
35 return it_offsets_ == offsets_.rend(); | |
36 } | |
37 | |
38 void BytecodeArrayReverseIterator::UpdateOffsetFromIterator() { | |
39 if (it_offsets_ != offsets_.rend()) { | |
40 SetOffset(*it_offsets_); | |
41 } | |
42 } | |
43 | |
44 } // namespace interpreter | |
45 } // namespace internal | |
46 } // namespace v8 | |
OLD | NEW |