我希望这是这个问题的正确位置。我正在写作 一个简单的启用JIT的解释器。但是,我遇到了一个奇怪的错误 谈到翻译。我复制了JavaScript示例 解析器几乎是逐字逐句,但这是我的问题:
首先,这里的解析器(几乎100%喜欢JS示例):
from pypy.rlib.parsing.ebnfparse import parse_ebnf, make_parse_function
from pypy.rlib.parsing.parsing import ParseError, Rule
import py
import sys
GFILE = py.magic.autopath().dirpath().join("grammar.txt")
try:
t = GFILE.read(mode="U")
regexs, rules, ToAST = parse_ebnf(t)
except ParseError, e:
print e.nice_error_message(filename=str(GFILE), source=t)
raise
parsef = make_parse_function(regexs, rules, eof=True)
def parse(code):
t = parsef(code)
return ToAST().transform(t)
和我的语法:
STRING: "\\"[^\\\\"]*\\"";
SYMBOL: "[A-Za-z+-_*<>]+";
KEYWORD: ":[A-Za-z+-_*<>]+";
INTEGER: "\-?([0-9]+)";
DECIMAL: "\-?(0|[1-9][0-9]*)(\.[0-9]+)?([eE][\+\-]?[0-9]+)?";
IGNORE: " |\n|\t|,";
value: <KEYWORD> | <SYMBOL> | <STRING> | <DECIMAL> | <INTEGER> |
<hash> | <vector> | <sexps>;
hash: ["{"] (entry [","])* entry ["}"];
vector: ["["] value* ["]"];
entry: STRING [":"] value;
sexps: ["("] value+ [")"];
我正在执行以下操作将代码编译为c:
import parse
t = Translation(parse.parse)
t.annotate([str])
t.rtype()
t.compile_c()
>>>
<---snip---->
File "/home/tbaldridge/pypy/pypy/translator/c/genc.py", line 339, in
getentrypointptr
self._wrapper = new_wrapper(self.entrypoint, self.translator)
File "/home/tbaldridge/pypy/pypy/translator/llsupport/wrapper.py",
line 57, in new_wrapper
r_to = pyobj_repr)
File "/home/tbaldridge/pypy/pypy/rpython/rtyper.py", line 931, in convertvar
(r_from, r_to))
pypy.rpython.error.TyperError: don't know how to convert from
<InstanceRepr for pypy.rlib.parsing.tree.Node> to <PyObjRepr *
PyObject>
我错过了什么?这看起来很直接......
答案 0 :(得分:3)
这是一个非常具体的与pypy相关的问题,你更有可能在irc.freenode.net上的#pypy上找到答案,或者在pypy-dev上询问。
那就是说,你不应该使用交互式翻译(除此之外它还有疯狂的默认值)。相反,你应该编写一个目标(查看translator / goal / targetnopstandalone.py作为示例)并使用translate.py进行编译。
答案 1 :(得分:3)
您的函数返回一个RPython级别的AST节点,它是一个转换后的C结构。翻译器不知道如何在Python解释器中表示它,以便在调用函数时返回结果。
在C中,main()函数只能返回一个整数。在pypy中,交互式翻译器可以传递和返回字符串,整数,浮点数和元组。 您应该处理ast节点并返回基本类型。