forked from p4lang/p4c
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathnodemap.h
102 lines (89 loc) · 4.15 KB
/
nodemap.h
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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
/*
Copyright 2013-present Barefoot Networks, Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
#ifndef IR_NODEMAP_H_
#define IR_NODEMAP_H_
#include "ir/node.h"
#include "lib/cstring.h"
namespace P4::IR {
template <class KEY, class VALUE,
template <class K, class V, class COMP, class ALLOC> class MAP = std::map,
class COMP = std::less<cstring>,
class ALLOC = std::allocator<std::pair<const KEY *const, const VALUE *>>>
class NodeMap : public Node {
typedef MAP<const KEY *, const VALUE *, COMP, ALLOC> map_t;
map_t symbols;
public:
typedef typename map_t::value_type value_type;
typedef typename map_t::iterator iterator;
typedef typename map_t::const_iterator const_iterator;
typedef typename map_t::reverse_iterator reverse_iterator;
typedef typename map_t::const_reverse_iterator const_reverse_iterator;
private:
struct elem_ref {
NodeMap &self;
const KEY *key;
elem_ref(NodeMap &s, const KEY *k) : self(s), key(k) {}
const VALUE *operator=(const VALUE *v) const { return self.symbols[key] = v; }
operator const VALUE *() const { return self.symbols.at(key); }
};
public:
const_iterator begin() const { return symbols.begin(); }
const_iterator end() const { return symbols.end(); }
iterator begin() { return symbols.begin(); }
iterator end() { return symbols.end(); }
const_reverse_iterator rbegin() const { return symbols.rbegin(); }
const_reverse_iterator rend() const { return symbols.rend(); }
reverse_iterator rbegin() { return symbols.rbegin(); }
reverse_iterator rend() { return symbols.rend(); }
size_t count(cstring name) const { return symbols.count(name); }
size_t size() const { return symbols.size(); }
bool empty() const { return symbols.empty(); }
size_t erase(const KEY *k) { return symbols.erase(k); }
iterator erase(const_iterator p) { return symbols.erase(p); }
iterator erase(const_iterator f, const_iterator l) { return symbols.erase(f, l); }
const_iterator find(const KEY *k) const { return symbols.find(k); }
template <class U>
const U *get(const KEY *k) const {
for (auto it = symbols.find(k); it != symbols.end() && it->first == k; it++)
if (auto rv = it->second->template to<U>()) return rv;
return nullptr;
}
elem_ref operator[](const KEY *k) { return elem_ref(*this, k); }
const VALUE *operator[](const KEY *k) const { return symbols.at(k); }
const VALUE *&at(const KEY *k) { return symbols.at(k); }
const VALUE *const &at(const KEY *k) const { return symbols.at(k); }
IRNODE_SUBCLASS(NodeMap)
bool operator==(const Node &a) const override { return a == *this; }
bool operator==(const NodeMap &a) const { return symbols == a.symbols; }
bool equiv(const Node &a_) const override {
if (static_cast<const Node *>(this) == &a_) return true;
if (this->typeId() != a_.typeId()) return false;
auto &a = static_cast<const NodeMap<KEY, VALUE, MAP, COMP, ALLOC> &>(a_);
if (size() != a.size()) return false;
auto it = a.begin();
for (auto &el : *this)
if (el.first != it->first || !el.second->equiv(*(it++)->second)) return false;
return true;
}
cstring node_type_name() const override {
return "NodeMap<" + KEY::static_type_name() + "," + VALUE::static_type_name() + ">";
}
static cstring static_type_name() {
return "NodeMap<" + KEY::static_type_name() + "," + VALUE::static_type_name() + ">";
}
void visit_children(Visitor &v) override;
void visit_children(Visitor &v) const override;
DECLARE_TYPEINFO(NodeMap, Node);
};
} // namespace P4::IR
#endif /* IR_NODEMAP_H_ */