LEX和YACC - 表达式中的空格

4 c regex yacc lex

我正在阅读一个文件,由于某种原因,当我尝试一个表达式时,我得到一个语法错误5+5,如果我这样做,5 + 5它工作得很好.我很困惑为什么会这样做?

这是我的lex文件(我将遗漏读取文件的主文件):

%{

 #include "y.tab.h"
 #include "stdio.h"
 #include <stdlib.h>

%}
%%
(\/\*([^*]|(\*+([^*/]|[\r\n])))*\*+\/)+ {}
\/\/[^\n]*\n          {}
fd                    { return FD; }
[\r\t\n]+             {}
[ ]*                  {}
bk                    { return BK;}
setc                  {return SETC;}
[-+]?[0-9]+           { yylval = atoi(yytext); return NUMBER;}
fd[0-9]+              { }
rt                    {return RT;}
pink                  {return COLOR_TYPE;}
magenta               {return COLOR_TYPE; }
if                    {return IF; }
ifelse                {return IFELSE; }
\[                    {return LBRACKET; }
\]                    {return RBRACKET; }
\<                    {return LESS_THAN; }
\>                    {return GREATER_THAN; }
\+                    {return PLUS; }
\-                    {return MINUS; }
\/                    {return DIVIDE; }
\*                    {return MULT; }
\(                    {return LPAREN;}
\)                    {return RPAREN;}
\=                    {return EQ;}

%%
Run Code Online (Sandbox Code Playgroud)

这是我的yacc文件的一部分,处理表达式:

expr    : NUMBER     { printf("EXPR-->NUMBER: %d\n", $1);}
   |expr PLUS expr   {$$ = $1 + $3; printf("EXPR-->expression PLUS expression: %d\n", $$);}
   |expr DIVIDE expr {$$ = $1 / $3; printf("EXPR-->expression DIVIDE expression %d\n", $$);}
   |expr MULT expr   {$$ = $1 * $3; printf("EXPR-->expression MULTIPLY expression %d\n", $$);}
   |expr MINUS expr  {$$ = $1 - $3; printf("EXPR-->expression MINUS expression %d\n", $$);}
   |COLOR_TYPE       {printf("EXPR-->COLOR\n");}
   ;
Run Code Online (Sandbox Code Playgroud)

问题出在lex文件中吗?

Lin*_*een 6

tokenizer(lexer)将这两个返回给解析器:5+5.你的语法(和逻辑上)是无效的.

我想,你最好改变你的词法分析器并改变运营商的规则.(这意味着至少在规则返回之上NUMBER).

编辑:经过一番思考(编辑#2:以及Jerry Coffin的有用评论),我建议将词法规则NUMBER改为[0-9]+.为了使解析器仍然接受像"+123"或"-123"这样的输入,你应该将它添加到你的语法中:

%left PLUS MINUS ...
%right UNARY

%%

expr   : number
       | expr PLUS expr
      ...
       ;

number : PLUS NUMBER %prec UNARY {$$ = $2}
       | MINUS NUMBER %prec UNARY {$$ = -$2}
       | NUMBER 
       ;
Run Code Online (Sandbox Code Playgroud)

这将允许一元+-在任何数字之前,同时仍然给予运营商+-更高的优先权.