//レックスファイル:for.l指定されたコードの競合を修正していますか? "25シフト/競合を減らす[-Wconflicts-SR]"
alpha [A-Za-z]
digit [0-9]
%%
[\t \n]
for return FOR;
{digit}+ return NUM;
{alpha}({alpha}|{digit})* return ID;
"<=" return LE;
">=" return GE;
"==" return EQ;
"!=" return NE;
"||" return OR;
"&&" return AND;
. return yytext[0];
%%
// Yaccのファイル:
%{
#include<stdio.h>
#include<stdlib.h>
%}
%token ID NUM FOR LE GE EQ NE OR AND
%right "="
%left OR AND
%left '>' '<' LE GE EQ NE
%left '+' '-'
%left '*' '/'
%right UMINUS
%left '!'
%%
S : ST {printf("Input accepted\n"); exit(0);}
ST : FOR '(' E ';' E2 ';' E ')' DEF
;
DEF : '{' BODY '}'
| E';'
| ST
|
;
BODY : BODY BODY
| E ';'
| ST
|
;
E : ID '=' E
| E '+' E
| E '-' E
| E '*' E
| E '/' E
| E '<' E
| E '>' E
| E LE E
| E GE E
| E EQ E
| E NE E
| E OR E
| E AND E
| E '+' '+'
| E '-' '-'
| ID
| NUM
;
E2 : E'<'E
| E'>'E
| E LE E
| E GE E
| E EQ E
| E NE E
| E OR E
| E AND E
;
%%
#include "lex.yy.c"
main()
{
printf("Enter the expression:\n");
yyparse();
}
for.y私はそれを実行し、表示:
warning: 25 shift/reduce conflicts [-Wconflicts-sr]
warning: 4 reduce/reduce conflicts [-Wconflicts-rr]
どうすれば修正できますか?
のコンパイル方法:
$ lex c.l
$ yacc c.y
コードを編集して問題の詳細を特定してください。お手数ではありがとうございます。 – Clay
これらの競合を解決してください。 –
このSOの投稿を見てください:http://stackoverflow.com/questions/26968665/bison-shift-reduce-conflict-tiger-compiler – Clay