blob: afc84e0451c024cba0cf8e21067eb9e5a77518c4 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
* vim: set ts=8 sts=2 et sw=2 tw=80:
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef vm_BytecodeIterator_h
#define vm_BytecodeIterator_h
#include "vm/BytecodeLocation.h"
namespace js {
class BytecodeIterator {
BytecodeLocation current_;
public:
inline explicit BytecodeIterator(const JSScript* script);
explicit BytecodeIterator(BytecodeLocation loc) : current_(loc) {}
BytecodeIterator& operator=(const BytecodeIterator&) = default;
bool operator==(const BytecodeIterator& other) const {
return other.current_ == current_;
}
bool operator!=(const BytecodeIterator& other) const {
return !(other.current_ == current_);
}
const BytecodeLocation& operator*() const { return current_; }
const BytecodeLocation* operator->() const { return ¤t_; }
// Pre-increment
BytecodeIterator& operator++() {
current_ = current_.next();
return *this;
}
// Post-increment
BytecodeIterator operator++(int) {
BytecodeIterator previous(*this);
current_ = current_.next();
return previous;
}
};
// Given a JSScript, allow the construction of a range based for-loop
// that will visit all script locations in that script.
class AllBytecodesIterable {
const JSScript* script_;
public:
explicit AllBytecodesIterable(const JSScript* script) : script_(script) {}
BytecodeIterator begin();
BytecodeIterator end();
};
// Construct a range based iterator that will visit all bytecode locations
// between two given bytecode locations.
// `beginLoc_` is the bytecode location where the iterator will start, and
// `endLoc_` is the bytecode location where the iterator will end.
class BytecodeLocationRange {
BytecodeLocation beginLoc_;
BytecodeLocation endLoc_;
public:
explicit BytecodeLocationRange(BytecodeLocation beginLoc,
BytecodeLocation endLoc)
: beginLoc_(beginLoc), endLoc_(endLoc) {
#ifdef DEBUG
MOZ_ASSERT(beginLoc.hasSameScript(endLoc));
#endif
}
BytecodeIterator begin();
BytecodeIterator end();
};
} // namespace js
#endif
|