blob: aaa61d705f92eb3c084ddb1554a8e10bad513bff (
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
|
#ifndef TREE_H_
#define TREE_H_
#include "nodecache.h"
using std::string;
/*!
For now, just an abstraction of the node tree which keeps a dump
cache based on node indices around.
Note that since node trees don't survive a recompilation, the tree cannot either.
*/
class Tree
{
public:
Tree(const AbstractNode *root = NULL) : root_node(root) {}
~Tree() {}
void setRoot(const AbstractNode *root);
const AbstractNode *root() const { return this->root_node; }
const string &getString(const AbstractNode &node) const;
const string &getIdString(const AbstractNode &node) const;
private:
const AbstractNode *root_node;
mutable NodeCache nodecache;
mutable NodeCache nodeidcache;
};
#endif
|