bison - 获取 : warning, 规则无法匹配

标签 bison yacc lex flex-lexer

我正在构建一个词法和语法分析器。当我尝试将 flex 与我的 .l 文件一起使用时,我收到以下警告。

littleDuck.l:26: warning, rule cannot be matched

规则 26 是以 {cteI} 开头的规则,我的规则部分如下:
[ \t\n]     ;
{RW}        {return RESERVED;}
{id}        {return ID;}
{ops}       {return OPERATOR;}
{seps}      {return SEPARATOR;}
{cteI}      {yylval.ival = atoi(yytext); return INT;}
{cteF}      {yylval.fval = atof(yytext); return FLOAT;}
{ctestring} {yylval.sval = strdup(yytext); return STRING;}
.       ;

另外,我的定义部分是这样的:
RW      program|var|int|float|print|else|if
id      ([a-z]|[A-Z)([a-z]|[A-Z]|[0-9])*
ops     "="|"<"|">"|"<>"|"+"|"-"|"/"|"*"
seps    ":"|","|";"|"{"|"}"|"("|")"
cteI    [0-9]+
cteF    {cteI}(\.{cteI}((e|E)("+"|"-")?{cteI})?)?
ctestring   (\".*\")

为什么会出现此警告,以及如何修改我的文件使其不出现?

最佳答案

警告告诉您可能与 {cteI} 匹配的任何内容将始终与某些较早的规则匹配。在您的情况下,它表明规则与您期望的不匹配,可能是由于拼写错误。在您的情况下,它是 {id}规则,您将其定义为:

([a-z]|[A-Z)([a-z]|[A-Z]|[0-9])*

注意圆括号和方括号的嵌套。为清楚起见添加空格,这是
( [a-z] | [A-Z)([a-z] | [A-Z] | [0-9] )*

这将匹配任何字母、数字或字符序列 ( )[ .你可能的意思是:
([a-z]|[A-Z])([a-z]|[A-Z]|[0-9])*

可以更清楚地写成
[a-zA-Z][a-zA-Z0-9]*

关于bison - 获取 : warning, 规则无法匹配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15057399/

相关文章:

parsing - 将 Lemon 解析器与自定义标记值一起使用

gcc - Bison 解析器总是打印 "syntax error"

grammar - 无法弄清楚如何解决减少/减少冲突

c - 从 flex/bison 中释放在 strdup() 中分配的字符串

flex-lexer - 如何使用 Flex(快速词法分析器)解词?

grammar - 具有reduce-reduce冲突的简单歧义语法

c++ - 将 float 与参数内的字符串连接起来

c - 匹配单个问号的简单 Lex/Yacc 语法错误?

parsing - 使脚本在 DrRacket 和 (x)repl 中工作

c - JACK 语言的 Lexer 中的段错误