summaryrefslogtreecommitdiff
path: root/ext/ply/test/lex_closure.py
diff options
context:
space:
mode:
authorPolina Dudnik <pdudnik@gmail.com>2009-08-17 11:33:32 -0500
committerPolina Dudnik <pdudnik@gmail.com>2009-08-17 11:33:32 -0500
commitc438b2e431066d9324238e1c678ef68a3b721f33 (patch)
treeb79e72b3074441ce01d5c95207f96f71d16bed35 /ext/ply/test/lex_closure.py
parent6654fe02daf6285cb43aa1c6e0e35f6c9c8786f1 (diff)
parenta43ae579dd3128a0ced2238532f26d99db197361 (diff)
downloadgem5-c438b2e431066d9324238e1c678ef68a3b721f33.tar.xz
Branch Merge
Diffstat (limited to 'ext/ply/test/lex_closure.py')
-rw-r--r--ext/ply/test/lex_closure.py54
1 files changed, 54 insertions, 0 deletions
diff --git a/ext/ply/test/lex_closure.py b/ext/ply/test/lex_closure.py
new file mode 100644
index 000000000..30ee67912
--- /dev/null
+++ b/ext/ply/test/lex_closure.py
@@ -0,0 +1,54 @@
+# -----------------------------------------------------------------------------
+# lex_closure.py
+# -----------------------------------------------------------------------------
+import sys
+
+if ".." not in sys.path: sys.path.insert(0,"..")
+import ply.lex as lex
+
+tokens = (
+ 'NAME','NUMBER',
+ 'PLUS','MINUS','TIMES','DIVIDE','EQUALS',
+ 'LPAREN','RPAREN',
+ )
+
+def make_calc():
+
+ # Tokens
+
+ t_PLUS = r'\+'
+ t_MINUS = r'-'
+ t_TIMES = r'\*'
+ t_DIVIDE = r'/'
+ t_EQUALS = r'='
+ t_LPAREN = r'\('
+ t_RPAREN = r'\)'
+ t_NAME = r'[a-zA-Z_][a-zA-Z0-9_]*'
+
+ def t_NUMBER(t):
+ r'\d+'
+ try:
+ t.value = int(t.value)
+ except ValueError:
+ print("Integer value too large %s" % t.value)
+ t.value = 0
+ return t
+
+ t_ignore = " \t"
+
+ def t_newline(t):
+ r'\n+'
+ t.lineno += t.value.count("\n")
+
+ def t_error(t):
+ print("Illegal character '%s'" % t.value[0])
+ t.lexer.skip(1)
+
+ # Build the lexer
+ return lex.lex()
+
+make_calc()
+lex.runmain(data="3+4")
+
+
+