我正在尝试将这个“计算器”Jison 示例修改为表达式解析器而不是表达式解释器。我想输出一个描述表达式的 JSON 对象,而不是立即评估它。
- 我试图修改演示以返回带有运算符和操作数作为元素的 javascript 数组。
- 当我解析时
1 + 2
,我希望得到一个字符串化为的 JSON 数组['+', 1, 2]
。相反,我得到1
. - 这似乎与 NUMBER 动作直接相关——无论我告诉什么返回就是我得到的全部。
- 但是,如果我尝试解析“1 2 + 3”,它确实会出现语法错误。
(我不关心我是否在一个有用的AST模型中表示表达式,我只是想学习Jison)
/* description: Parses mathematical expressions. */
/* lexical grammar */
%lex
%%
\s+ /* skip whitespace */
[0-9]+("."[0-9]+)?\b return 'NUMBER'
"*" return '*'
"/" return '/'
"-" return '-'
"+" return '+'
"^" return '^'
"(" return '('
")" return ')'
"PI" return 'PI'
"E" return 'E'
<<EOF>> return 'EOF'
. return 'INVALID'
/lex
/* operator associations and precedence */
%left '+' '-'
%left '*' '/'
%left '^'
%left UMINUS
%start expressions
%% /* language grammar */
expressions
: e EOF
{ return $e; }
;
e
: e '+' e
{ return ['+', $e1, $e2]; }
| e '-' e
{ return ['-', $e1, $e2]; }
| e '*' e
{ return ['*', $e1, $e2]; }
| e '/' e
{ return ['/', $e1, $e2]; }
| e '^' e
{ return ['^', $e1, $e2]; }
| '-' e %prec UMINUS
{ return ['-', $e]; }
| '(' e ')'
{ return ['G', $e ]; }
| NUMBER
{ return Number($NUMBER); }
| E
{ return Math.E; }
| PI
{ return Math.PI; }
;