0

使用以下代码flex和代码,我可以在输入命令时bison打印文本:helloprint "Hello"

flex file:

%{
#include <iostream>
using namespace std;
#define YY_DECL extern "C" int yylex()
#include "gbison.tab.h"
%}
%%
[ \t\n]            ;
[a-zA-Z0-9]+       { yylval.sval = strdup(yytext); return STRING; }
\"(\\.|[^"])*\"    { yylval.sval = strdup(yytext); return QUOTED_STRING; }
%%

bison file:

%{
#include <cstdio> 
#include <cstring>
#include <iostream>
using namespace std;

extern "C" int yylex();
extern "C" int yyparse();
extern "C" FILE* yyin;

void yyerror (const char* s);
%}

%union {
  char* sval;
}

%token <sval> STRING
%token <sval> QUOTED_STRING
%%

str:
    STRING QUOTED_STRING
    {
       if (strcmp($1, "print") == 0)
       {
           cout << $2 << flush;
       }
       if (strcmp($1, "println") == 0)
       {
           cout << $3 << endl; 
       }
    }
    ;
%%

main(int argc, char* argv[])
{
   FILE* input = fopen(argv[1], "r");
   if (!input)
   {
      cout << "Bad input. Nonexistant file" << endl; 
      return -1;
   } 

   yyin = input;

   do 
   {
       yyparse();
   } while (!feof(yyin));

}
void yyerror(const char* s)
{
   cout << "Error. " << s << endl; 
   exit(-1);   
}

如果有多个 print 或 println 命令,我将如何更改Bison grammar它以使其不会出现语法错误?

4

1 回答 1

1

在第一%%行之前添加语法:

%start list

%%并在第一行之后添加到语法:

list:
        /* Nothing */
    |   list str
    ;

这表示完整的语法由一个列表组成,一个列表什么都不是(空输入)或一个列表后跟一个“str”。

就目前而言,您的语法说有效输入仅包含一次出现的“str”,因此当您开始重复自己时出现语法错误。

于 2013-09-29T23:08:03.523 回答