【发布时间】:2018-05-19 11:29:22
【问题描述】:
我正在尝试使用 Bison 编写解析器。 我收到警告:
warning: 5 shift/reduce conflicts [-Wconflicts-sr]
我的规则:
%%
Prog : F {};
F : {};
F : D F {};
D : R ID LP Fr RP LB Ss RB {};
R : T {};
R : VOID {};
Fr : {};
Fr : Fl {};
Fl : Fd COM Fl1 {};
Fl1 : | Fl1 Fd COM {};
Fd : T ID Fd1{};
Fd1 : LB NUM BM RB{};
BM : B | {};
Ss : S | Ss S {};
S : LB Ss RB {};
S : T ID SC {};
S : T ID ASGN E SC {};
S : T ID LB NUM RB SC {};
S : T ID LB NUM B RB SC {};
S : ID ASGN E SC {};
S : ID LB E RB ASGN E SC {};
S : C SC {};
S : RET SC {};
S : RET E SC {};
S : IF LP E RP S {};
S : WHILE LP El RP S {};
S : BREAK SC {};
C : ID LP ElM RP {};
ElM : El | {};
El : E El1{};
El1 : | COM El {};
T : INT | BYTE | BOOL {};
E : LP E RP | ID LB E RP |ID | C | NUM | NUM B | STR | TRUE | FALSE | NOT E | E Op E {};
Op : AND | OR | RLP | BNP {};
%%
我如何知道冲突在哪里?我尝试过组合规则,但冲突的数量从未改变。可能是什么原因?
【问题讨论】:
-
冲突在你的表达式规则中,或者至少其中一些是。我会从那里开始。过度缩写不会使您的代码易于阅读。
标签: compiler-construction bison shift-reduce-conflict