javascript – 你如何在Jison中匹配零个或多个令牌?
作者:互联网
我正在Jison中编写一个简单的表达式解析器,允许任意数量的换行符跟在表达式中的二元运算符.到目前为止这是我的语法:
{
"operators": [
["left", "+", "-"],
["left", "*", "/", "%"]
],
"bnf": {
"program": [
["statement EOF", "return $1;"]
],
"statement": [
["expression newlines", "$$= $1 + ';';"]
],
"expression": [
["NUMBER", "$$= yytext;"],
["expression + expression", "$$= $1 + ' + ' + $3;"],
["expression - expression", "$$= $1 + ' - ' + $3;"],
["expression * expression", "$$= $1 + ' * ' + $3;"],
["expression / expression", "$$= $1 + ' / ' + $3;"],
["expression % expression", "$$= $1 + ' % ' + $3;"],
["expression + newlines expression", "$$= $1 + ' + ' + $4;"],
["expression - newlines expression", "$$= $1 + ' - ' + $4;"],
["expression * newlines expression", "$$= $1 + ' * ' + $4;"],
["expression / newlines expression", "$$= $1 + ' / ' + $4;"],
["expression % newlines expression", "$$= $1 + ' % ' + $4;"]
],
"newlines": [
["NEWLINE", ""],
["newlines NEWLINE", ""]
]
}
}
正如您所看到的,我正在为每个二元运算符编写两条规则.在我看来,这是多余的.我宁愿生产一个匹配零个或多个NEWLINE标记(Kleene star)而不是一个或多个标记(Kleene plus)的产品.你怎么在Jison做这个?
解决方法:
我使用Jison而忽略了空格(包括换行).
我的%lex中的第一行是:
\s+ /* ignore */
但如果你不愿意,你不必这样做.
尝试这些方面的东西:
"expression": [
["NUMBER", "$$= yytext;"],
["expression + expression", "$$= $1 + ' + ' + $3;"],
["expression - expression", "$$= $1 + ' - ' + $3;"],
["expression * expression", "$$= $1 + ' * ' + $3;"],
["expression / expression", "$$= $1 + ' / ' + $3;"],
["expression % expression", "$$= $1 + ' % ' + $3;"],
["expression newlines", "$$= $1"],
["newlines expression", "$$= $2"]
],
这应该允许任何表达式之前/之后的任何数量的新行.
标签:javascript,parsing,parser-generator,jison,bnf 来源: https://codeday.me/bug/20190709/1410472.html