using ast rather then native now
This commit is contained in:
parent
952ba5811e
commit
81820abace
@ -1,5 +1,6 @@
|
|||||||
# output ast for cpython 2.7
|
# output ast for cpython 2.7
|
||||||
import ast
|
import ast
|
||||||
|
import imp
|
||||||
|
|
||||||
from hy.lang.expression import HYExpression
|
from hy.lang.expression import HYExpression
|
||||||
from hy.lang.number import HYNumber
|
from hy.lang.number import HYNumber
|
||||||
@ -40,11 +41,6 @@ def _ast_binop(node, children, obj):
|
|||||||
|
|
||||||
|
|
||||||
def _ast_cmp(node, children, obj):
|
def _ast_cmp(node, children, obj):
|
||||||
# Compare(left=Num(n=1), ops=[LtE()], comparators=[Num(n=2)])
|
|
||||||
# Compare(left=Num(n=1), ops=[Gt(), Gt()],
|
|
||||||
# comparators=[Num(n=2), Num(n=3)])
|
|
||||||
|
|
||||||
# opscmpop = Eq | NotEq | Lt | LtE | Gt | GtE | Is | IsNot | In | NotIn
|
|
||||||
inv = node.get_invocation()
|
inv = node.get_invocation()
|
||||||
ops = {
|
ops = {
|
||||||
"==": ast.Eq, "<=": ast.LtE, ">=": ast.GtE, ">": ast.Gt, "<": ast.Lt,
|
"==": ast.Eq, "<=": ast.LtE, ">=": ast.GtE, ">": ast.Gt, "<": ast.Lt,
|
||||||
@ -297,3 +293,11 @@ def forge_ast(name, forest):
|
|||||||
statements.append(ret)
|
statements.append(ret)
|
||||||
|
|
||||||
return ast.fix_missing_locations(ast.Module(body=statements))
|
return ast.fix_missing_locations(ast.Module(body=statements))
|
||||||
|
|
||||||
|
|
||||||
|
def forge_module(name, fpath, forest):
|
||||||
|
mod = imp.new_module(name)
|
||||||
|
mod.__file__ = fpath
|
||||||
|
ast = forge_ast(name, forest)
|
||||||
|
eval(compile(ast, fpath, "exec"), mod.__dict__)
|
||||||
|
return mod
|
||||||
|
@ -1,4 +1,6 @@
|
|||||||
from hy.compiler.modfaker import forge_module
|
# from hy.compiler.modfaker import forge_module
|
||||||
|
from hy.compiler.ast27 import forge_module
|
||||||
|
|
||||||
from hy.lex.tokenize import tokenize
|
from hy.lex.tokenize import tokenize
|
||||||
import sys
|
import sys
|
||||||
import imp
|
import imp
|
||||||
|
Loading…
x
Reference in New Issue
Block a user