我使用flex和bison写了一个小的汇编程序,它在我的机器上构建并运行正常(ubuntu 10.10)。其他人现在正试图在arch linux上构建它,并且他们的flex的安装产生了一个不同的lex.yy.c,这是不匹配的规则。两个版本都报告了相同的lex 2.5.35
版本,但我已经看到我和Mac OSX上的另一个flex之间存在差异,这些差异并没有模仿(?i
模式,因此我不太相信该版本字符串。
我无法访问远程计算机,因此我正在查看远程用户生成的一些lex --debug输出。
我的汇编程序的完整源代码是on github here。
以下是我的规则摘录:
letter [A-Za-z]
digit [0-9]
hexdigit [0-9a-fA-F]
symbolchar {letter}|[\.$_]
symbol {symbolchar}({symbolchar}|{digit})*
gpreg [ABCXYZIJabcxyzij]
xreg SP|PC|EX|POP|PEEK|PUSH|PICK|sp|pc|ex|pop|peek|push|pick
op2 SET|ADD|SUB|MUL|MLI|DIV|DVI|MOD|MDI|AND|[BX]OR|SH[LR]|ASR|IF[BCENGALU]|ADX|SBX|ST[ID]
op2_lc set|add|sub|mul|mli|div|dvi|mod|mdi|and|[bx]or|sh[lr]|asr|if[bcengalu]|adx|sbx|st[id]
op1 JSR|HCF|INT|RFI|IA[GSQ]|HW[NQI]
op1_lc jsr|hcf|int|rfi|ia[gsq]|hw[nqi]
%%
\.set|\.equ return EQU;
:{symbol} { yylval.string = yytext + 1; return LABEL; }
{symbol}: {
yylval.string = yytext;
yytext[strlen(yytext) - 1] = 0;
return LABEL;
}
0x{hexdigit}+ return get_constant();
{digit}+ return get_constant();
{gpreg}|{xreg} { yylval.integer = str2reg(yytext); return REG; }
{op2}|{op2_lc} { yylval.integer = str2opcode(yytext); return OP2; }
{op1}|{op1_lc} { yylval.integer = str2opcode(yytext); return OP1; }
DAT|dat { return DAT; }
{symbol} { yylval.string = yytext; return SYMBOL; }
这是一个示例输入行:
SET A, 0x30 ; 7c01 0030
远程词法分析器匹配规则{symbol}:
代替A {gpreg}|{xreg}
。这可能是因为我在*
的定义中有一个通配符symbol
吗?为什么这适用于我的flex而不是远程的?
我本地(好)构建的--debug输出:
--accepting rule at line 52 (" ")
--accepting rule at line 42 ("SET")
--accepting rule at line 52 (" ")
--accepting rule at line 41 ("A")
--accepting rule at line 50 (",")
--accepting rule at line 52 (" ")
--accepting rule at line 39 ("0x30")
--accepting rule at line 52 (" ")
--accepting rule at line 53 ("; 7c01 0030")
--accepting rule at line 50 ("
")
来自违规远程构建的调试输出(包括yacc投诉)。 请注意与“A”匹配的不同规则:
--accepting rule at line 52 (" ")
--accepting rule at line 42 ("SET")
--accepting rule at line 52 (" ")
--accepting rule at line 34 ("A")
line 4: syntax error
line 3: parse error: bad instruction
line 3: parse error: bad instruction
--accepting rule at line 50 (",")
line 3: parse error: bad instruction
--accepting rule at line 52 (" ")
--accepting rule at line 39 ("0x30")
line 3: parse error: bad instruction
--accepting rule at line 52 (" ")
--accepting rule at line 53 ("; 7c01 0030")
--accepting rule at line 50 ("
")
我应该如何解决这个问题,是否有任何类似的问题我可以期待不同的灵活版本?