summaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
authorDavid Beazley <dave@dabeaz.com>2013-05-29 15:35:42 -0500
committerDavid Beazley <dave@dabeaz.com>2013-05-29 15:35:42 -0500
commit1b66128ac860a7429f1954a86c4ab8f63a0e8b92 (patch)
tree0bb2da35e3b0cbcb7e689e7abf9144d0e34e9844 /test
parentea655a3a8632824f5e0fb2319f096d5f9579bff7 (diff)
downloadply-1b66128ac860a7429f1954a86c4ab8f63a0e8b92.tar.gz
Fixed from __future__ import unicode_literals bug
Diffstat (limited to 'test')
-rw-r--r--test/testyacc.py8
-rw-r--r--test/yacc_unicode_literals.py70
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()
+
+
+
+