forked from mayankgupta022/compiler
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathparserDef.h
67 lines (53 loc) · 1.05 KB
/
parserDef.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
/*
-=-=-=-=-=-=-=-=-=-=-=-=-=
BATCH 26
-=-=-=-=-=-=-=-=-=-=-=-=-=
AAYUSH AHUJA 2010A7PS023P
MAYANK GUPTA 2010A7PS022P
-=-=-=-=-=-=-=-=-=-=-=-=-=
parserDef.h
-=-=-=-=-=-=-=-=-=-=-=-=-=
*/
#ifndef PARSERDEF_H_INCLUDED
#define PARSERDEF_H_INCLUDED
typedef struct
{
symbol nt;
symbol first[60];
int firstno;
int followno;
symbol follow[60];
bool ft[60];
bool fw[60];
bool eps;
} sets;
typedef struct
{
symbol nt;
int ruleNumber;
symbol list[20];
int listno;
} grammar;
typedef int Table;
struct parsetree
{
tokenInfo t;
int ruleno;//used by AST to know which grammar rule was applied for the non-terminal,for terminals it is -1
int lineno;
struct parsetree* parent;
bool visited;
int pull;
struct parsetree* next[20];//assuming length of RHS of rules is bounded by 20
};
typedef struct parsetree* parseTree;
struct stackNode
{
parseTree tree;//to Parse Tree
struct stackNode* next;
};
typedef struct
{
struct stackNode* top;
int size;
}Stack;
#endif // PARSERDEF_H_INCLUDED