-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathastree.h
50 lines (39 loc) · 1.24 KB
/
astree.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
// Wai Chun Leung
// wleung11
// Shineng Tang
// stang38
// $Id: astree.h,v 1.10 2016-10-06 16:42:35-07 - - $
#ifndef __ASTREE_H__
#define __ASTREE_H__
#include <string>
#include <vector>
using namespace std;
#include "auxlib.h"
struct location {
size_t filenr;
size_t linenr;
size_t offset;
};
struct astree {
// Fields.
int symbol; // token code
location lloc; // source location
const string* lexinfo; // pointer to lexical information
vector<astree*> children; // children of this n-way node
// Functions.
astree (int symbol, const location&, const char* lexinfo);
~astree();
astree* adopt (astree* child1,
astree* child2 = nullptr,astree* child3 = nullptr);
astree* adopt_sym (astree* child, int symbol);
astree* change_sym(int symbol_);
void dump_node (FILE*);
void dump_tree (FILE*, int depth = 0);
static void dump (FILE* outfile, astree* tree);
static void print (FILE* outfile, astree* tree, int depth = 0);
};
void destroy (astree* tree1, astree* tree2 = nullptr ,
astree* tree3 = nullptr,astree* tree4 = nullptr,
astree* tree5 = nullptr);
void errllocprintf (const location&, const char* format, const char*);
#endif