我正在使用Python Parsimonious Parser尝试为我正在设计的简单语言构建解释器.我看了这个tutorial video非常有帮助,现在我正在慢慢修改代码以符合我自己的规则.我坚持最初定义为:
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库中得到了这个错误:
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).
我对解析/ lexing很新,并不完全确定我是否正确定义了规则.希望有更多解析/ lexing经验的人可以帮助我正确定义规则并解释我出错的地方.也许或许向我解释Parsimonious错误?
解决方法:
当我试图解析SET a,7时,我的左值规则没有考虑SET和左值a之间的空白.这是因为我将左值规则定义为’lvalue =〜“[A-Za-z]”_’,它没有考虑名称前的空格.我按照以下方式重新定义了我的分配规则,以便考虑GET和名称之间的空格:
'setvar = "SETVAR" _ lvalue _ "," _ expr'
Parsimonious似乎更喜欢那样.