120 likes | 312 Vues
Lex. Linguagem (e compilador) para especificar analisadores léxicos. Organização. Programa fonte lex.l. Compilador lex ( lex ou flex). lex.yy.c. C compiler*. lex.yy.c. a.out. a.out. Entrada. Sequencia de tokens. *: “cc lex.yy.c – ll ” ou “cc lex.yy.c ”.
E N D
Lex • Linguagem (e compilador) para especificar analisadores léxicos.
Organização Programa fontelex.l Compiladorlex (lexou flex) lex.yy.c C compiler* lex.yy.c a.out a.out Entrada Sequencia de tokens *: “cc lex.yy.c –ll” ou “cc lex.yy.c”
Programas Lex - estrutura Declarações – variáveis, constantes, defs.regulares %%regras de tradução – expr.regulares e ações em C Padrão { Ação } %%procedimentos auxiliares
Lex - exemplo %{ /* definição de constantes LT, LE, EQ, NE,…*/ %} delim [ \t\n] ws {delim}+ letter [A-Za-z] digit [0-9] id {letter}({letter}|{digit})* number {digit}+(\.{digit}+)? (E[+\-]?{digit}+)? %% …
Lex – exemplo (cont.) … {ws} {/* no action and no return */} if {return(IF);} then {return(THEN);} else {return(ELSE);} {id} {yylval=install_id();return(ID);} {number} {yylval=install_num(); return(NUMBER);} “<“ {yylval = LT; return(RELOP);} “<=“ {yylval = LE; return(RELOP);} %% …
Lex – exemplo (cont.) … int install_id() { Copia lexema para a tabela de símbolos. Primeiro caracter do lexema é apontado pela variável yytext e o comprimento é definido pela variável yyleng. } Int install_num() { … }
Yacc • Linguagem (e compilador) para especificar analisadores sintáticos.
Organização Programa fonteparser.l Compilador yacc (yacc ou bison -d) y.tab.cy.tab.h C compiler* y.tab.clex.yy.c a.out a.out Entrada Resultadodaexecução do parser *: “cc y.tab.clex.yy.c –ly” ou “cc y.tab.clex.yy.c”
Programas Yacc - estrutura Declarações – variáveis, constantes, definições%%regras de tradução – gramática e ações em C Padrão { Ação }%%procedimentos auxiliares
Yacc - exemplo %{ #include <ctype.h> %} %token DIGIT %% …
Yacc – exemplo (cont.) line : expr '\n' { printf("\n%d\n", $1); } expr : expr '+' term { $$ = $1 + $3; } | expr '-' expr { $$ = $1 - $3; } | term ; term : term '*' factor {$$ = $1 * $3; } | factor ; factor :'(' expr ')' { $$ = $2; } | DIGIT ; %% …
Yacc – exemplo (cont.) main() { yyparse (); } yylex () { int c; c = getchar(); if (isdigit(c)) { yylval = c – ’0’; return DIGIT; } return c; }