lex中无法识别的规则

时间:2014-02-17 16:30:22

标签: unix lex

我是lex的新手,我在第36行有一个无法识别的规则 - printf(“%d”,tok); 我不确定如何解决这个错误..有谁看到如何解决这个问题? 三江源

%{
enum yytokentype {
NUMBER = 258,
ADD = 259,
SUB = 260,
MUL = 261,
DIV = 262,
ABS = 263,
EOL = 264
};
int yylval;
%}

%%
"+"
{ return ADD; }
"-"
{ return SUB; }
"*"
{ return MUL; }
"/"
{ return DIV; }
"|"
{ return ABS; }
[0-9]+ { yylval = atoi(yytext); return NUMBER; }
\n
{ return EOL; }
. { printf("Mystery character %c\n", *yytext); }
[ \t] { }
%%
main(int argc, char **argv)
{
int tok;

while(tok = yylex()) {
printf("%d", tok);
if(tok == NUMBER) printf(" = %d\n", yylval);
else printf("\n");
}
}

2 个答案:

答案 0 :(得分:1)

这里有一些问题,但我会通过思考过程与你交谈。

首先,错误表明它认为您的main块是一个lex规则。显然不是。这表明它并不认为你的规则已经结束。

我在你的规则中看到了几个奇怪的东西。在.通配符后,最后有一个“空白”规则。该规则永远不会匹配。它应该是无害的,但你可能想确定为什么要包含它。

接下来,您将模式和代码放在不同的行上。我不认为这是有效的。尝试将代码放在模式的同一行。

答案 1 :(得分:1)

您的代码已更正(发现差异):

%option noyywrap
%{
enum yytokentype {
    NUMBER = 258,
    ADD = 259,
    SUB = 260,
    MUL = 261,
    DIV = 262,
    ABS = 263,
    EOL = 264 
};
int yylval;
%}

%%
"+" { return ADD; }
"-" { return SUB; }
"*" { return MUL; }
"/" { return DIV; }
"|" { return ABS; }
[0-9]+ { yylval = atoi(yytext); return NUMBER; }
\n { return EOL; }
[ \t] { } 
. { printf("Mystery character %c\n", *yytext); }
%%

main(int argc, char **argv)
{
int tok;

while(tok = yylex()) {
printf("%d", tok);
if(tok == NUMBER) printf(" = %d\n", yylval);
else printf("\n");
}