gpt4 book ai didi

c - Flex/bison 一直给我语法错误

转载 作者:太空宇宙 更新时间:2023-11-04 07:51:15 25 4
gpt4 key购买 nike

我正在尝试使用 lex 和 yacc 制作一个迷你编译器,但是每次我尝试测试我的解析器时,我都会收到语法错误。

这是我的 lex 文件:

%option noyywrap
%{
#include "y.tab.h"
int line = 1;
int spaceCount = 1;
int sourceLineCount = 1;
%}

IDENTIFIER [_a-zA-Z][_a-zA-Z0-9]*
WHITESPACE [ ]
DIGIT [0-9]
TAB \t
NEXTLINE \n

%%
int return INT;
float return FLOAT;
double return DOUBLE;
char return CHAR;
void return VOID;

static return STATIC;
const return CONST;

struct return STRUCT;
union return UNION;
enum return ENUM;

if return IF;
else return ELSE;
switch return SWITCH;
case return CASE;

break return BREAK;
default return DEFAULT;

^"#include ".+ ;
typedef return TYPEDEF;
extern return EXTERN;

for return FOR;
while return WHILE;
do return DO;


"<" return LT;
">" return GT;
"<=" return LE;
">=" return GE;
"==" return EQ;
"!=" return NE;


"." return DOT;
"," return COMMA;

printf return PRINTF;

return return RETURN;

{DIGIT}+ return NUM;



{NEXTLINE} {
line++;
}
{WHITESPACE} {
spaceCount++;
}
. return yytext[0];
%%

还有我的 yacc/bison 文件:

%{
#include<stdio.h>
extern FILE *fp;
%}

%token INT FLOAT CHAR DOUBLE VOID
%token FOR WHILE DO
%token IF ELSE PRINTF
%token STRUCT ENUM UNION
%token SWITCH CASE BREAK DEFAULT
%token NUM ID
%token INCLUDE
%token DOT COMMA
%token STATIC CONST
%token TYPEDEF EXTERN
%token RETURN
%right '='
%left AND OR
%left '<' '>' LE GE EQ NE LT GT




%%
start: Function
| Declaration
;

/* DECCLARATION */
Declaration: Type Assignment ';'
| Assignment ';'
| FunctionCall ';'
| ArrayUsage ';'
| Type ArrayUsage ';'
| StructStmt ';'
| error
;

/* ASSIGNMENT */
Assignment: ID '=' Assignment
| ID '=' FunctionCall
| ID '=' ArrayUsage
| ArrayUsage '=' Assignment
| ID ',' Assignment
| NUM ',' Assignment
| ID '+' Assignment
| ID '-' Assignment
| ID '*' Assignment
| ID '/' Assignment
| NUM '+' Assignment
| NUM '-' Assignment
| NUM '*' Assignment
| NUM '/' Assignment
| '\'' Assignment '\''
| '(' Assignment ')'
| '-' '(' Assignment ')'
| '-' NUM
| '-' ID
| NUM
| ID
;

/* Function Call*/
FunctionCall : ID'('')'
| ID'('Assignment')'
;
/* Function block */
Function: Type ID '(' ArgListOpt ')' CompoundStmt
;
ArgListOpt: ArgList
|
;
ArgList: ArgList ',' Arg
| Arg
;
Arg: Type ID
;

/* Array Usage */
ArrayUsage : ID'['Assignment']'
;

CompoundStmt: '{' StmtList '}'
;
StmtList: StmtList Stmt
|
;
Stmt: WhileStmt
| Declaration
| ForStmt
| IfStmt
| PrintFunc
| SwitchStmt
| ';'
;

/* Type Identifier block */
Type: INT
| FLOAT
| CHAR
| DOUBLE
| VOID
;

/* Loop Blocks */
WhileStmt: WHILE '(' Expr ')' Stmt
| WHILE '(' Expr ')' CompoundStmt
;

/* For Block */
ForStmt: FOR '(' Expr ';' Expr ';' Expr ')' Stmt
| FOR '(' Expr ';' Expr ';' Expr ')' CompoundStmt
| FOR '(' Expr ')' Stmt
| FOR '(' Expr ')' CompoundStmt
;

/* IfStmt Block */
IfStmt : IF '(' Expr ')'
Stmt
;
/* SwitchStmnt */
SwitchStmt : SWITCH '(' ID ')'
CaseStmt
| SWITCH '(' ID ')'
CompoundStmt
CaseStmt
DefaultStmt
;
/* CaseStmt */
CaseStmt : CASE NUM ':'
Stmt
BREAK ';'
;
/* DefaultStmt */
DefaultStmt : DEFAULT ':'
Stmt
BREAK ';'
/* Struct Statement */
StructStmt : STRUCT ID '{' Type Assignment '}'
;

/* Print Function */
PrintFunc : PRINTF '(' Expr ')' ';'
;
/*Expression Block*/
Expr:
| Expr LE Expr
| Expr GE Expr
| Expr NE Expr
| Expr EQ Expr
| Expr GT Expr
| Expr LT Expr
| Assignment
| ArrayUsage
;


%%
#include"lex.yy.c"
#include<ctype.h>
int count=0;

int main(int argc, char *argv[])
{
yyin = fopen(argv[1], "r");

if(!yyparse())
printf("\nParsing complete\n");
else
printf("\nParsing failed\n");

fclose(yyin);
return 0;
}

yyerror(char *s) {
printf("\n %d: %s avant %s\n\n",line,s, yytext );
}

我尝试使用多个测试文件对其进行测试,但它似乎总是给我一个语法错误,这是我尝试过的示例。

int main()
{
int a;
}

在这种情况下,我在“m”之前遇到错误。

最佳答案

在你的词法扫描仪中你没有任何地方

return ID;

这意味着需要 ID 标记的解析器中的产品永远不会匹配任何东西。我想你只是忘了添加识别标识符的行。请注意,main 应该是一个 ID,这就是您的解析此时失败的原因。

您的语法还有其他问题,包括它只识别单个函数声明 (Function) 或其他语句 (Declaration)。连同您所做的任何其他更改,您应该尝试为您的非终端提供更有意义的名称,以便其他人可以理解您的语法。 (这也可能对您有所帮助。)

关于c - Flex/bison 一直给我语法错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53727673/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com