-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathyacc_compile.c
27 lines (26 loc) · 1.01 KB
/
yacc_compile.c
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
#include <stdio.h>
#include "yacc_compile.h"
#include "y.tab.h"
int ex(nodeType *p) {
if (!p) return 0;
switch(p->type) {
case typeCon: return p->con.value;
case typeId: return sym[p->id.i];
case typeOpr:
switch(p->opr.oper) {
case WHILE: while(ex(p->opr.op[0])) ex(p->opr.op[1]); return 0;
case IF: if (ex(p->opr.op[0]))
ex(p->opr.op[1]);
ex(p->opr.op[2]);
return 0;
case PRINT: printf("%d\n\n", ex(p->opr.op[0])); return 0;
case ';': ex(p->opr.op[0]); ex(p->opr.op[1]); return 0;
case '=': return sym[p->opr.op[0]->id.i] = ex(p->opr.op[1]);
case '+': return ex(p->opr.op[0]) + ex(p->opr.op[1]);
case '*': return ex(p->opr.op[0]) * ex(p->opr.op[1]);
case '<': return ex(p->opr.op[0]) < ex(p->opr.op[1]);
case EQ: return ex(p->opr.op[0]) == ex(p->opr.op[1]);
}
}
return 0;
}