yacc_rr.py revision 2632
1# ----------------------------------------------------------------------------- 2# yacc_rr.py 3# 4# A grammar with a reduce/reduce conflict 5# ----------------------------------------------------------------------------- 6import sys 7sys.tracebacklimit = 0 8 9from calclex import tokens 10 11# Parsing rules 12precedence = ( 13 ('left','PLUS','MINUS'), 14 ('left','TIMES','DIVIDE'), 15 ('right','UMINUS'), 16 ) 17 18# dictionary of names 19names = { } 20 21def p_statement_assign(t): 22 'statement : NAME EQUALS expression' 23 names[t[1]] = t[3] 24 25def p_statement_assign_2(t): 26 'statement : NAME EQUALS NUMBER' 27 names[t[1]] = t[3] 28 29def p_statement_expr(t): 30 'statement : expression' 31 print t[1] 32 33def p_expression_binop(t): 34 '''expression : expression PLUS expression 35 | expression MINUS expression 36 | expression TIMES expression 37 | expression DIVIDE expression''' 38 if t[2] == '+' : t[0] = t[1] + t[3] 39 elif t[2] == '-': t[0] = t[1] - t[3] 40 elif t[2] == '*': t[0] = t[1] * t[3] 41 elif t[3] == '/': t[0] = t[1] / t[3] 42 43def p_expression_uminus(t): 44 'expression : MINUS expression %prec UMINUS' 45 t[0] = -t[2] 46 47def p_expression_group(t): 48 'expression : LPAREN expression RPAREN' 49 t[0] = t[2] 50 51def p_expression_number(t): 52 'expression : NUMBER' 53 t[0] = t[1] 54 55def p_expression_name(t): 56 'expression : NAME' 57 try: 58 t[0] = names[t[1]] 59 except LookupError: 60 print "Undefined name '%s'" % t[1] 61 t[0] = 0 62 63def p_error(t): 64 print "Syntax error at '%s'" % t.value 65 66import yacc 67yacc.yacc() 68 69 70 71 72