summaryrefslogtreecommitdiff
path: root/ext/ply/example/ansic
diff options
context:
space:
mode:
Diffstat (limited to 'ext/ply/example/ansic')
-rw-r--r--ext/ply/example/ansic/clex.py11
-rw-r--r--ext/ply/example/ansic/cparse.py8
2 files changed, 13 insertions, 6 deletions
diff --git a/ext/ply/example/ansic/clex.py b/ext/ply/example/ansic/clex.py
index afd995208..12441a60b 100644
--- a/ext/ply/example/ansic/clex.py
+++ b/ext/ply/example/ansic/clex.py
@@ -4,7 +4,10 @@
# A lexer for ANSI C.
# ----------------------------------------------------------------------
-import lex
+import sys
+sys.path.insert(0,"../..")
+
+import ply.lex as lex
# Reserved words
reserved = (
@@ -53,7 +56,7 @@ t_ignore = ' \t\x0c'
# Newlines
def t_NEWLINE(t):
r'\n+'
- t.lineno += t.value.count("\n")
+ t.lexer.lineno += t.value.count("\n")
# Operators
t_PLUS = r'\+'
@@ -64,7 +67,7 @@ t_MOD = r'%'
t_OR = r'\|'
t_AND = r'&'
t_NOT = r'~'
-t_XOR = r'^'
+t_XOR = r'\^'
t_LSHIFT = r'<<'
t_RSHIFT = r'>>'
t_LOR = r'\|\|'
@@ -149,7 +152,7 @@ def t_preprocessor(t):
def t_error(t):
print "Illegal character %s" % repr(t.value[0])
- t.skip(1)
+ t.lexer.skip(1)
lexer = lex.lex(optimize=1)
if __name__ == "__main__":
diff --git a/ext/ply/example/ansic/cparse.py b/ext/ply/example/ansic/cparse.py
index ddfd5c72b..d474378c8 100644
--- a/ext/ply/example/ansic/cparse.py
+++ b/ext/ply/example/ansic/cparse.py
@@ -4,8 +4,9 @@
# Simple parser for ANSI C. Based on the grammar in K&R, 2nd Ed.
# -----------------------------------------------------------------------------
-import yacc
+import sys
import clex
+import ply.yacc as yacc
# Get the token map
tokens = clex.tokens
@@ -852,7 +853,10 @@ def p_error(t):
import profile
# Build the grammar
-profile.run("yacc.yacc()")
+
+yacc.yacc(method='LALR')
+
+#profile.run("yacc.yacc(method='LALR')")