-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmyparser.py
69 lines (56 loc) · 1.23 KB
/
myparser.py
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
from mylexer import MyLexer, tokens
import ply.yacc as yacc
lexer = MyLexer()
def MyParser():
def p_E(p):
'''E : E PLUS T
| E MINUS T
'''
if p[2] == '+':
p[0] = p[1] + p[3]
elif p[2] == '-':
p[0] = p[1] - p[3]
def p_E_T(p):
'E : T'
p[0] = p[1]
def p_T(p):
'''T : T MUL F
| T DIV F
'''
if p[2] == '*':
p[0] = p[1] * p[3]
elif p[2] == '/':
try:
p[0] = p[1] / p[3]
except ZeroDivisionError:
print("NO ZEROOOOO!!!!")
def p_T_F(p):
'T : F'
p[0] = p[1]
def p_F(p):
'''F : G POWER F
| MINUS G
'''
if p[1] == '-':
p[0] = -p[2]
elif p[2] == 'p':
p[0] = p[1] ** p[3]
def p_F_G(p):
'F : G'
p[0] = p[1]
def p_G(p):
'''G : NUM
| LEFTPAR E RIGHTPAR
'''
if p[1] == '(':
p[0] = p[2]
else:
p[0] = p[1]
def p_NUM(p):
'''NUM : INT
| FLOAT
'''
p[0] = p[1]
def p_error(p):
print("syntax error!")
return yacc.yacc()