Adding lists to the lexable things

This commit is contained in:
Paul Tagliamonte 2012-12-15 18:20:15 -05:00
parent ec06d6af88
commit 5975f2c8d6
3 changed files with 52 additions and 6 deletions

3
hy/lang/list.py Normal file
View File

@ -0,0 +1,3 @@
class HYList(list):
def __init__(self, nodes):
self += nodes

View File

@ -1,6 +1,7 @@
from hy.lang.expression import HYExpression from hy.lang.expression import HYExpression
from hy.lex.errors import LexException from hy.lex.errors import LexException
from hy.lex.machine import Machine from hy.lex.machine import Machine
from hy.lang.list import HYList
class State(object): class State(object):
@ -14,6 +15,9 @@ class State(object):
def exit(self): def exit(self):
pass pass
def sub(self, machine):
self.sub_machine = Machine(machine)
def process(self, x): def process(self, x):
if self.sub_machine: if self.sub_machine:
self.sub_machine.process(x) self.sub_machine.process(x)
@ -48,7 +52,6 @@ class Expression(State):
def enter(self): def enter(self):
self.nodes = HYExpression([]) self.nodes = HYExpression([])
self.bulk = "" self.bulk = ""
self.sub_machine = None
def exit(self): def exit(self):
if self.bulk: if self.bulk:
@ -64,19 +67,51 @@ class Expression(State):
def p(self, x): def p(self, x):
if x == ")": if x == ")":
return Idle return Idle
if x == " ": if x == " ":
self.commit() self.commit()
return return
if x == "\"": if x == "\"":
self.sub_machine = Machine(String) self.sub(String)
return return
if x == "(": if x == "(":
self.sub_machine = Machine(Expression) self.sub(Expression)
return return
if x == "[":
self.sub(List)
return
self.bulk += x
class List(State):
def enter(self):
self.nodes = HYList([])
self.bulk = ""
def exit(self):
if self.bulk:
self.nodes.append(self.bulk)
self.machine.nodes.append(self.nodes)
def commit(self):
if self.bulk.strip() != "":
self.nodes.append(self.bulk)
self.bulk = ""
def p(self, x):
if x == "]":
return Idle
if x == " ":
self.commit()
return
if x == "\"":
self.sub(String)
return
if x == "[":
self.sub(List)
return
if x == "(":
self.sub(Expression)
return
self.bulk += x self.bulk += x

View File

@ -0,0 +1,8 @@
from hy.lex.tokenize import tokenize
def test_list_lex():
fn = tokenize("(fn [1 2 3 4])")[0]
assert fn == [
"fn", ["1", "2", "3", "4"]
]