Merge remote-tracking branch 'paultag/feature/native-macros' into feature/native-macros

Conflicts:
	hy/compiler.py
	tests/__init__.py
This commit is contained in:
Nicolas Dandrimont 2013-05-11 20:18:40 +02:00
commit 31c14e4167
2 changed files with 14 additions and 13 deletions

View File

@ -94,6 +94,14 @@ def ast_str(foobar):
def builds(_type):
unpythonic_chars = ["-"]
really_ok = ["-"]
if True in (x in str_type(_type) for x in unpythonic_chars):
if _type not in really_ok:
raise TypeError("`build' needs to be *post* translated strings, "
"Mr. / Mrs. Hypser. -- `%s' sucks." % (_type))
def _dec(fn):
_compile_table[_type] = fn
return fn
@ -570,7 +578,7 @@ class HyASTCompiler(object):
return ret
@builds("unquote")
@builds("unquote-splicing")
@builds("unquote_splicing")
def compile_unquote(self, expr):
raise HyTypeError(expr,
"`%s' can't be used at the top-level" % expr[0])
@ -1596,9 +1604,8 @@ class HyASTCompiler(object):
expression.pop(0)
name = expression.pop(0)
if not isinstance(name, HySymbol):
raise HyTypeError(name,
("received a `%s' instead of a symbol "
"for macro name" % type(name).__name__))
raise HyTypeError(name, ("received a `%s' instead of a symbol "
"for macro name" % type(name).__name__))
name = HyString(name).replace(name)
new_expression = HyExpression([
HySymbol("do"),
@ -1608,17 +1615,11 @@ class HyASTCompiler(object):
]),
HyExpression([
HySymbol("with_decorator"),
HyExpression([
HySymbol("hy.macros.macro"),
name,
]),
HyExpression([HySymbol("fn")] +
expression),
HyExpression([HySymbol("hy.macros.macro"), name]),
HyExpression([HySymbol("fn")] + expression),
]),
]).replace(expression)
hy.importer.hy_eval(new_expression, {})
return self.compile(new_expression)
@builds(HyInteger)

View File

@ -4,7 +4,7 @@
import hy # noqa
from .native_tests.defclass import * # noqa
from .native_tests.math import * # noqa
from .native_tests.native_macros import *
from .native_tests.native_macros import * # noqa
from .native_tests.quote import * # noqa
from .native_tests.language import * # noqa
from .native_tests.unless import * # noqa