From 4d32dac9ad7e6ae155ae936157e7ee0ead726681 Mon Sep 17 00:00:00 2001 From: "Paul R. Tagliamonte" Date: Mon, 4 Mar 2013 20:40:23 -0500 Subject: [PATCH] Moving the compiler stuff around. --- hy/compiler.py | 89 ++++++++++++++++++++++++++++- hy/compilers/__init__.py | 29 ---------- hy/compilers/pyast.py | 110 ------------------------------------ tests/compilers/test_ast.py | 3 +- 4 files changed, 89 insertions(+), 142 deletions(-) delete mode 100644 hy/compilers/__init__.py delete mode 100644 hy/compilers/pyast.py diff --git a/hy/compiler.py b/hy/compiler.py index db8c2cd..7a041d5 100644 --- a/hy/compiler.py +++ b/hy/compiler.py @@ -18,5 +18,92 @@ # FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER # DEALINGS IN THE SOFTWARE. +from hy.errors import HyError -from hy.compilers.pyast import hy_compile # NOQA +from hy.models.expression import HyExpression +from hy.models.symbol import HySymbol +from hy.models.string import HyString + +import ast + + +class HyCompileError(HyError): + pass + + +_compile_table = {} + + +def builds(_type): + def _dec(fn): + _compile_table[_type] = fn + + def shim(*args, **kwargs): + return fn(*args, **kwargs) + return shim + return _dec + + +class HyASTCompiler(object): + + def __init__(self): + self.returnable = False + + def compile(self, tree): + for _type in _compile_table: + if type(tree) == _type: + return _compile_table[_type](self, tree) + + raise HyCompileError("Unknown type - `%s'" % (str(type(tree)))) + + def _mangle_branch(self, tree): + ret = [] + tree.reverse() + + if self.returnable: + el = tree.pop() + if not isinstance(el, ast.stmt): + ret.append(ast.Return(value=el, + lineno=el.lineno, + col_offset=el.col_offset)) + ret += [ + ast.Expr(value=el, + lineno=el.lineno, + col_offset=el.col_offset) + if not isinstance(el, ast.stmt) else el for el in tree # NOQA + ] # for some stupid reason, flake8 thinks i'm redefining. ^^^^ + + ret.reverse() + return ret + + @builds(list) + def compile_raw_list(self, entries): + return [self.compile(x) for x in entries] + + @builds(HyExpression) + def compile_expression(self, expression): + return ast.Call(func=self.compile_symbol(expression[0]), + args=[self.compile(x) for x in expression[1:]], + keywords=[], + starargs=None, + kwargs=None, + lineno=expression.start_line, + col_offset=expression.start_column) + + @builds(HySymbol) + def compile_symbol(self, symbol): + return ast.Name(id=str(symbol), ctx=ast.Load(), + lineno=symbol.start_line, + col_offset=symbol.start_column) + + @builds(HyString) + def compile_string(self, string): + return ast.Str(s=str(string), lineno=string.start_line, + col_offset=string.start_column) + + +def hy_compile(tree): + " Compile a HyObject tree into a Python AST tree. " + compiler = HyASTCompiler() + ret = ast.Module(body=compiler._mangle_branch(compiler.compile(tree))) + return ret diff --git a/hy/compilers/__init__.py b/hy/compilers/__init__.py deleted file mode 100644 index 1102ece..0000000 --- a/hy/compilers/__init__.py +++ /dev/null @@ -1,29 +0,0 @@ -# Copyright (c) 2012 Paul Tagliamonte -# -# Permission is hereby granted, free of charge, to any person obtaining a -# copy of this software and associated documentation files (the "Software"), -# to deal in the Software without restriction, including without limitation -# the rights to use, copy, modify, merge, publish, distribute, sublicense, -# and/or sell copies of the Software, and to permit persons to whom the -# Software is furnished to do so, subject to the following conditions: -# -# The above copyright notice and this permission notice shall be included in -# all copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL -# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING -# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER -# DEALINGS IN THE SOFTWARE. - -from abc import ABCMeta, abstractmethod - - -class HyCompiler(object): - __metaclass__ = ABCMeta - - @abstractmethod - def compile(self, tree): - pass diff --git a/hy/compilers/pyast.py b/hy/compilers/pyast.py deleted file mode 100644 index 8419e67..0000000 --- a/hy/compilers/pyast.py +++ /dev/null @@ -1,110 +0,0 @@ -# Copyright (c) 2012 Paul Tagliamonte -# -# Permission is hereby granted, free of charge, to any person obtaining a -# copy of this software and associated documentation files (the "Software"), -# to deal in the Software without restriction, including without limitation -# the rights to use, copy, modify, merge, publish, distribute, sublicense, -# and/or sell copies of the Software, and to permit persons to whom the -# Software is furnished to do so, subject to the following conditions: -# -# The above copyright notice and this permission notice shall be included in -# all copies or substantial portions of the Software. -# -# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL -# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER -# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING -# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER -# DEALINGS IN THE SOFTWARE. - -from hy.compilers import HyCompiler -from hy.errors import HyError - -from hy.models.expression import HyExpression -from hy.models.symbol import HySymbol -from hy.models.string import HyString - -import ast - - -class HyCompileError(HyError): - pass - - -_compile_table = {} - - -def builds(_type): - def _dec(fn): - _compile_table[_type] = fn - - def shim(*args, **kwargs): - return fn(*args, **kwargs) - return shim - return _dec - - -class HyASTCompiler(HyCompiler): - - def __init__(self): - self.returnable = False - - def compile(self, tree): - for _type in _compile_table: - if type(tree) == _type: - return _compile_table[_type](self, tree) - - raise HyCompileError("Unknown type - `%s'" % (str(type(tree)))) - - def _mangle_branch(self, tree): - ret = [] - tree.reverse() - - if self.returnable: - el = tree.pop() - if not isinstance(el, ast.stmt): - ret.append(ast.Return(value=el, - lineno=el.lineno, - col_offset=el.col_offset)) - ret += [ - ast.Expr(value=el, - lineno=el.lineno, - col_offset=el.col_offset) - if not isinstance(el, ast.stmt) else el for el in tree # NOQA - ] # for some stupid reason, flake8 thinks i'm redefining. ^^^^ - - ret.reverse() - return ret - - @builds(list) - def compile_raw_list(self, entries): - return [self.compile(x) for x in entries] - - @builds(HyExpression) - def compile_expression(self, expression): - return ast.Call(func=self.compile_symbol(expression[0]), - args=[self.compile(x) for x in expression[1:]], - keywords=[], - starargs=None, - kwargs=None, - lineno=expression.start_line, - col_offset=expression.start_column) - - @builds(HySymbol) - def compile_symbol(self, symbol): - return ast.Name(id=str(symbol), ctx=ast.Load(), - lineno=symbol.start_line, - col_offset=symbol.start_column) - - @builds(HyString) - def compile_string(self, string): - return ast.Str(s=str(string), lineno=string.start_line, - col_offset=string.start_column) - - -def hy_compile(tree): - " Compile a HyObject tree into a Python AST tree. " - compiler = HyASTCompiler() - ret = ast.Module(body=compiler._mangle_branch(compiler.compile(tree))) - return ret diff --git a/tests/compilers/test_ast.py b/tests/compilers/test_ast.py index aa03325..f9f7d6c 100644 --- a/tests/compilers/test_ast.py +++ b/tests/compilers/test_ast.py @@ -18,8 +18,7 @@ # FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER # DEALINGS IN THE SOFTWARE. -from hy.compilers.pyast import HyCompileError -from hy.compiler import hy_compile +from hy.compiler import hy_compile, HyCompileError from hy.lex import tokenize import ast