Adding in some prototype bits for quoted forms.

This commit is contained in:
Paul R. Tagliamonte 2013-04-08 20:18:15 -04:00
parent efb8addc6f
commit f27378e57a
3 changed files with 19 additions and 0 deletions

View File

@ -160,6 +160,22 @@ class HyASTCompiler(object):
def compile_raw_list(self, entries): def compile_raw_list(self, entries):
return [self.compile(x) for x in entries] return [self.compile(x) for x in entries]
def _render_quoted_form(self, form):
name = form.__class__.__name__
if isinstance(form, HyList):
return HyExpression(
[HySymbol(name),
HyList([self._render_quoted_form(x) for x in form])]
).replace(form)
elif isinstance(form, HySymbol):
return HyExpression([HySymbol(name), HyString(form)]).replace(form)
return HyExpression([HySymbol(name), form]).replace(form)
@builds("quote")
@checkargs(min=1, max=2)
def compile_quote(self, entries):
return self.compile(self._render_quoted_form(entries[1]))
@builds("do") @builds("do")
@builds("progn") @builds("progn")
def compile_do_expression(self, expr): def compile_do_expression(self, expr):

View File

@ -34,3 +34,5 @@ class HyObject(object):
setattr(self, attr, getattr(other, attr)) setattr(self, attr, getattr(other, attr))
else: else:
raise TypeError("Can't replace a non Hy object with a Hy object") raise TypeError("Can't replace a non Hy object with a Hy object")
return self

View File

@ -31,6 +31,7 @@ class HyList(HyObject, list):
x.replace(other) x.replace(other)
HyObject.replace(self, other) HyObject.replace(self, other)
return self
def __repr__(self): def __repr__(self):
return "[%s]" % (" ".join([str(x) for x in self])) return "[%s]" % (" ".join([str(x) for x in self]))