2016-11-15 3 views
4

Я работаю над Flex & Проект Bison. Я получил свой flex & bison отлично работает, но я пытаюсь дать argv как вход (yyin). Поэтому я изменил yyin так, чтобы он взял argv [1], но на самом деле он не работает. Кажется, что он взял argv [1], но потом я получил синтаксическую ошибку, даже если моя строка, я полагаю, работает отлично.Изменить yyin to argv [1] Flex & Bison

Вот мой прогибается:

%{ 
#include "parser.hpp" 
extern int yyparse(); 
%} 

%option noyywrap 


texte [a-zA-z]+ 
entier [0-9]+(\.[0-9])? 

%% 

{entier} { yylval.num = atoi(yytext); return(NUMBER);} 

"pi" return(PI); 
"," return(SEP); 
"(" return(OP); 
")" return(CP); 
"+" return(ADD); 
"-" return(SUB); 
"*" return(MUL); 
"/" return(DIV); 
"%" return (MODULO); 
"sin" return(SIN); 
"cos" return(COS); 
"tan" return(TAN); 
"acos" return(ACOS); 
"asin" return(ASIN); 
"atan" return(ATAN); 
"sqrt" return(ROOT); 
"pow" return(POW); 
"exp" return(EXP); 
"\n" return(END); 
{texte} return(ERROR); 
%% 

Тогда мой бизон (я уже не реализован ПОВ SIN и другие, легче читать):

%defines 
%{ 
#include <iostream> 
#include <math.h> 
using namespace std; 
extern int yylex(); 
extern void yyerror(char const* msg); 
%} 

%union {double num;} 

/* CARACTERES */ 
%token <num> NUMBER PI 
%token OP CP SEP END 

/* TRIGO */ 
%token COS SIN TAN 
%token ACOS ASIN ATAN 
/* CALCUL */ 
%token ADD SUB 
%token MUL DIV 
%token ROOT POW MODULO EXP ABS 

/* CALCUL ORDER */ 
%left ADD SUB 
%left MUL DIV 

/* TRASH */ 
%token ERROR 

%type <num> calclist exp factor term 
%start calclist 
%% 
calclist: /* nothing */ 
| calclist exp END {cout << $2 << endl;} 
; 
exp: factor 
| exp ADD factor { $$ = $1 + $3; } 
| exp SUB factor { $$ = $1 - $3; } 
; 
factor: term 
| factor MUL term { $$ = $1 * $3; } 
| factor DIV term { $$ = $1/$3; } 
; 
term: NUMBER 
| OP exp CP {$$ = $2;} 
; 
%% 



extern void yyerror(char const* msg){ 
    cerr << "Error " << msg << endl; 
} 

Тогда моя главная:

#include <iostream> 
#include "parser.hpp" 
#include <string.h> 
using namespace std; 

extern FILE *yyin; 
extern int yy_scan_string(const char *); 


int main(int argc, char const *argv[]) { 
    /*string buf(argv[1]); 
    buf.append("\0");*/ 
    yy_scan_string(argv[1]); 
    return yyparse(); 
} 

и, наконец, мой файл подкачки:

all: bison flex main.cpp 
    g++ parser.cpp lexer.cpp main.cpp -o parser 
    rm lexer.cpp parser.cpp parser.hpp 
    ./parser "(1+2)" 
bison: parser.y 
    bison -o parser.cpp parser.y 
flex: lexer.l 
    flex -o lexer.cpp lexer.l 

Я пробовал ./parser (1+2) тоже, но я получил больше ошибок. Спасибо за помощь!

ответ

1

С Flex & Bison book (стр 124):

Процедуры yy_scan_bytes и yy_scan_stringсоздать буфер с копией текста, который будет сканироваться.

(Курсив мой)

И

После того, как строка будет создан буфер, используйте yy_switch_to_buffer сказать сканер для чтения из него ...

yy_scan_string только создает буферный объект, который вам нужно явно se:

YY_BUFFER_STATE bp = yy_scan_string(...); // Creates a buffer from the string 
yy_switch_to_buffer(bp);     // Use the buffer 
int ret = yyparse();      // Parse the string 
yy_delete_buffer(bp);      // Free the buffer 
+0

Спасибо большое! Нужно ли включать что-то для YY_BUFFER_STATE? У меня есть ошибка для него и для переключения в буфер тоже! –

+0

@ G.Courmont Я не помню, это было давно, я сам использовал Flex/Bison. Я в основном просто читаю связанную книгу прямо сейчас, и в разделах, которые я читал, ничего не говорится. Вы должны искать автогенерированные файлы заголовков и другие файлы заголовков, связанные с Flex/Bison, установленные в вашей системе. –

+0

Этот ответ неверен. См. Документацию по гибкому интерфейсу. – rici

0

Я наконец нашел ответ. я Juste пришлось изменить немного мой главный:

string str = argv[1]; 
str += '\n'; 
yy_scan_string(str.c_str()); 

Поскольку yyin является 0-расторгнуто. Надеюсь, это поможет другим людям!

Смежные вопросы