我正在使用Python吝啬分析器来尝试为我正在设计的一种简单语言构建一个解释器。我看了这个非常有用的教程视频,现在我正在慢慢地修改代码以符合我自己的规则。我被困在一条最初定义为:
def assignment(self, node, children):
'assignment = lvalue "=" expr'
lvalue, _, expr = children
self.env[lvalue] = expr
return expr我用以下语法稍微修改了规则:
def assignment(self, node, children):
'assignment = "SET" lvalue "," expr'
_, lvalue, _, expr = children
self.env[lvalue] = expr
return expr我希望解析器计算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).我对解析/词法非常陌生,也不完全确定我是否正确地定义了规则。希望有更多解析/词法经验的人能帮助我正确地定义规则,并解释我哪里出了问题。或许还能向我解释一下这种吝啬的错误?
发布于 2013-09-23 21:14:00
当我试图解析SET a, 7时,我的lvalue规则没有考虑到SET和lvalue a之间的空格。这是因为我将我的lvalue规则定义为'lvalue = ~"[A-Za-z]+" _',它在名称之前不考虑空格。我将我的分配规则重新定义如下,以说明GET和名称之间的空格:
'setvar = "SETVAR" _ lvalue _ "," _ expr'吝啬的人似乎更喜欢这样。
https://stackoverflow.com/questions/18966779
复制相似问题