diff options
author | David Beazley <dave@dabeaz.com> | 2013-05-29 15:35:42 -0500 |
---|---|---|
committer | David Beazley <dave@dabeaz.com> | 2013-05-29 15:35:42 -0500 |
commit | 1b66128ac860a7429f1954a86c4ab8f63a0e8b92 (patch) | |
tree | 0bb2da35e3b0cbcb7e689e7abf9144d0e34e9844 /test | |
parent | ea655a3a8632824f5e0fb2319f096d5f9579bff7 (diff) | |
download | ply-1b66128ac860a7429f1954a86c4ab8f63a0e8b92.tar.gz |
Fixed from __future__ import unicode_literals bug
Diffstat (limited to 'test')
-rw-r--r-- | test/testyacc.py | 8 | ||||
-rw-r--r-- | test/yacc_unicode_literals.py | 70 |
2 files changed, 78 insertions, 0 deletions
diff --git a/test/testyacc.py b/test/testyacc.py index c284444..aa87779 100644 --- a/test/testyacc.py +++ b/test/testyacc.py @@ -339,6 +339,7 @@ class YaccErrorWarningTests(unittest.TestCase): self.assert_(check_expected(result, "Generating LALR tables\n" )) + def test_yacc_sr(self): run_import("yacc_sr") result = sys.stderr.getvalue() @@ -354,6 +355,13 @@ class YaccErrorWarningTests(unittest.TestCase): "yacc_term1.py:24: Illegal rule name 'NUMBER'. Already defined as a token\n" )) + def test_yacc_unicode_literals(self): + run_import("yacc_unicode_literals") + result = sys.stderr.getvalue() + self.assert_(check_expected(result, + "Generating LALR tables\n" + )) + def test_yacc_unused(self): self.assertRaises(ply.yacc.YaccError,run_import,"yacc_unused") result = sys.stderr.getvalue() diff --git a/test/yacc_unicode_literals.py b/test/yacc_unicode_literals.py new file mode 100644 index 0000000..5ae4f5b --- /dev/null +++ b/test/yacc_unicode_literals.py @@ -0,0 +1,70 @@ +# ----------------------------------------------------------------------------- +# yacc_unicode_literals +# +# Test for unicode literals on Python 2.x +# ----------------------------------------------------------------------------- +from __future__ import unicode_literals + +import sys + +if ".." not in sys.path: sys.path.insert(0,"..") +import ply.yacc as yacc + +from calclex import tokens + +# Parsing rules +precedence = ( + ('left','PLUS','MINUS'), + ('left','TIMES','DIVIDE'), + ('right','UMINUS'), + ) + +# dictionary of names +names = { } + +def p_statement_assign(t): + 'statement : NAME EQUALS expression' + names[t[1]] = t[3] + +def p_statement_expr(t): + 'statement : expression' + print(t[1]) + +def p_expression_binop(t): + '''expression : expression PLUS expression + | expression MINUS expression + | expression TIMES expression + | expression DIVIDE expression''' + if t[2] == '+' : t[0] = t[1] + t[3] + elif t[2] == '-': t[0] = t[1] - t[3] + elif t[2] == '*': t[0] = t[1] * t[3] + elif t[2] == '/': t[0] = t[1] / t[3] + +def p_expression_uminus(t): + 'expression : MINUS expression %prec UMINUS' + t[0] = -t[2] + +def p_expression_group(t): + 'expression : LPAREN expression RPAREN' + t[0] = t[2] + +def p_expression_number(t): + 'expression : NUMBER' + t[0] = t[1] + +def p_expression_name(t): + 'expression : NAME' + try: + t[0] = names[t[1]] + except LookupError: + print("Undefined name '%s'" % t[1]) + t[0] = 0 + +def p_error(t): + print("Syntax error at '%s'" % t.value) + +yacc.yacc() + + + + |