我正试图掌握吉森的窍门。不过我有点麻烦。下面的解析器总是返回 [],不管你给它什么。
%lex
%%
"data"\s* return 'DATA'
[A-Za-z][A-Za-z0-9_]* return 'IDENTIFIER'
[0-9]+("."[0-9]+)?\b return 'NUMBER'
"=" return 'ASSIGN'
("<-"|"<+-") return 'REACT'
"+" return '+'
"-" return '-'
"*" return '*'
"/" return '/'
"^" return '^'
\n+ return 'NL'
<<EOF>> return 'EOF'
. return 'INVALID'
/lex
%token NL
/* operator associations and precedence */
%left ASSIGN
%left REACT
%left '+' '-'
%left '*' '/'
%left '^'
%left UMINUS
%start program
%% /* language grammar */
program
:
{return [];}
| program statement
{return $1.concat([$2]);}
| program statement EOF
{return $1.concat([$2]);}
;
statement
: assign NL
{return $1;}
;
assign
: IDENTIFIER ASSIGN expression
{return ['assign', $1, $3];}
| IDENTIFIER REACT expression
{return ['react', $1, $2, $3];}
;
expression
: NUMBER
{return +$1;}
| IDENTIFIER
;
问题显然出在我对 non-terminal 的定义中program
。声明它的正确方法是什么?