我一直在处理一个样本问题,为一个表达式构造一个三地址代码。但是令我惊讶的是,YACC似乎跳过了我的第一个输入符号。我将在输出中附加图片以使其清晰。
规则并不太复杂,所以我似乎不太了解问题所在。
这是我的lex文件:
%{
#include"y.tab.h"
%}
%%
[a-zA-Z]+ return ID;
[0-9]+ return NUM;
. return yytext[0];
%%
int yywrap(){return 1;}
这是我的yacc文件:
%{
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
char st[50][50];
extern char * yytext;
int top=-1;char t[5]="0";char temp[5];
void push();
void code();
%}
%token NUM ID
%left '+' '-'
%left '*' '/'
%%
S:' 'E
|' 'A'='E
;
A:ID{push();printf("yytext is %s\n",yytext);}
;
E:E'+'{push();}T{code();}
|E'-'{push();}T{code();}
|T
;
T:T'*'{push();}F{code();}
|T'/'{push();}F{code();}
|F
;
F:ID{push();}
|NUM{push();}
;
%%
void push(){strcpy(st[++top],yytext);}
void code(){
strcpy(temp,"t");
strcat(temp,t);
t[0]++;
printf("%s = %s %s %s \n",temp,st[top-2],st[top-1],st[top]);
top=top-2;
strcpy(st[top],temp);
}
int main(){yyparse();}
int yyerror(){exit(0);}
我希望A:ID生成中的打印内容可以打印输入的ID,但是它将打印'='。 这是我的输出: my output
答案 0 :(得分:0)
为了确保看到A
,yacc必须前进(向前看)才能看到=
。这会覆盖yytext中的第一个令牌。