yacc_notok.py revision 2632
12632Sstever@eecs.umich.edu# ----------------------------------------------------------------------------- 22632Sstever@eecs.umich.edu# yacc_notok.py 32632Sstever@eecs.umich.edu# 42632Sstever@eecs.umich.edu# A grammar, but we forgot to import the tokens list 52632Sstever@eecs.umich.edu# ----------------------------------------------------------------------------- 62632Sstever@eecs.umich.edu 72632Sstever@eecs.umich.eduimport sys 82632Sstever@eecs.umich.edusys.tracebacklimit = 0 92632Sstever@eecs.umich.edu 102632Sstever@eecs.umich.edu# Parsing rules 112632Sstever@eecs.umich.eduprecedence = ( 122632Sstever@eecs.umich.edu ('left','PLUS','MINUS'), 132632Sstever@eecs.umich.edu ('left','TIMES','DIVIDE'), 142632Sstever@eecs.umich.edu ('right','UMINUS'), 152632Sstever@eecs.umich.edu ) 162632Sstever@eecs.umich.edu 172632Sstever@eecs.umich.edu# dictionary of names 182632Sstever@eecs.umich.edunames = { } 192632Sstever@eecs.umich.edu 202632Sstever@eecs.umich.edudef p_statement_assign(t): 212632Sstever@eecs.umich.edu 'statement : NAME EQUALS expression' 222632Sstever@eecs.umich.edu names[t[1]] = t[3] 232632Sstever@eecs.umich.edu 242632Sstever@eecs.umich.edudef p_statement_expr(t): 252632Sstever@eecs.umich.edu 'statement : expression' 262632Sstever@eecs.umich.edu print t[1] 272632Sstever@eecs.umich.edu 282632Sstever@eecs.umich.edudef p_expression_binop(t): 292632Sstever@eecs.umich.edu '''expression : expression PLUS expression 302632Sstever@eecs.umich.edu | expression MINUS expression 312632Sstever@eecs.umich.edu | expression TIMES expression 322632Sstever@eecs.umich.edu | expression DIVIDE expression''' 332632Sstever@eecs.umich.edu if t[2] == '+' : t[0] = t[1] + t[3] 342632Sstever@eecs.umich.edu elif t[2] == '-': t[0] = t[1] - t[3] 352632Sstever@eecs.umich.edu elif t[2] == '*': t[0] = t[1] * t[3] 362632Sstever@eecs.umich.edu elif t[3] == '/': t[0] = t[1] / t[3] 372632Sstever@eecs.umich.edu 382632Sstever@eecs.umich.edudef p_expression_uminus(t): 392632Sstever@eecs.umich.edu 'expression : MINUS expression %prec UMINUS' 402632Sstever@eecs.umich.edu t[0] = -t[2] 412632Sstever@eecs.umich.edu 422632Sstever@eecs.umich.edudef p_expression_group(t): 432632Sstever@eecs.umich.edu 'expression : LPAREN expression RPAREN' 442632Sstever@eecs.umich.edu t[0] = t[2] 452632Sstever@eecs.umich.edu 462632Sstever@eecs.umich.edudef p_expression_number(t): 472632Sstever@eecs.umich.edu 'expression : NUMBER' 482632Sstever@eecs.umich.edu t[0] = t[1] 492632Sstever@eecs.umich.edu 502632Sstever@eecs.umich.edudef p_expression_name(t): 512632Sstever@eecs.umich.edu 'expression : NAME' 522632Sstever@eecs.umich.edu try: 532632Sstever@eecs.umich.edu t[0] = names[t[1]] 542632Sstever@eecs.umich.edu except LookupError: 552632Sstever@eecs.umich.edu print "Undefined name '%s'" % t[1] 562632Sstever@eecs.umich.edu t[0] = 0 572632Sstever@eecs.umich.edu 582632Sstever@eecs.umich.edudef p_error(t): 592632Sstever@eecs.umich.edu print "Syntax error at '%s'" % t.value 602632Sstever@eecs.umich.edu 612632Sstever@eecs.umich.eduimport yacc 622632Sstever@eecs.umich.eduyacc.yacc() 632632Sstever@eecs.umich.edu 642632Sstever@eecs.umich.edu 652632Sstever@eecs.umich.edu 662632Sstever@eecs.umich.edu 67