我正在使用Python Parsimonious Parser为我正在设计的一种简单语言构建一个解释器。我看了这个tutorial video,这很有帮助,现在我正在慢慢修改代码以符合我自己的规则。我被一个最初定义为:
def assignment(self, node, children):
'assignment = lvalue "=" expr'
lvalue, _, expr = children
self.env[lvalue] = expr
return expr
我用以下语法稍微修改了一下规则:
^{pr2}$例如,我希望解析器计算SET a, 7
,与a = 7
相同,并将值7
绑定到名称a
。但是,当我试图解析它时,我从简约库中得到以下错误:
parsimonious.exceptions.IncompleteParseError: Rule 'program' matched in its
entirety, but it didn't consume all the text. The non-matching portion of
the text begins with 'SET a, 7' (line 1, column 1).
我对解析/词法分析相当陌生,不完全确定是否正确定义了规则。希望有更多解析/词法分析经验的人能帮助我正确定义规则并解释我哪里出错了。或许还向我解释一下节俭的错误?在
当我试图解析
SET a, 7
时,我的lvalue
规则没有考虑SET
和左值a
之间的空白。这是因为我将lvalue
规则定义为'lvalue = ~"[A-Za-z]+" _'
,它不考虑名称前的空格。我将赋值规则重新定义如下,以考虑GET
和名称之间的空白:吝啬似乎更喜欢这样。在
相关问题 更多 >
编程相关推荐