SlideShare una empresa de Scribd logo
PONTIFICIA UNIVERSIDAD CATÓLICA DEL ECUADOR
SEDE IBARRA
1. DATOS INFORMATIVOS
1.1 Nombre: Gabriel Solano
1.2 Carrera: Sistemas
1.3 Nivel: 5to
1.4 Tema: Compiladores
1.5 Fecha: 21/06/2017
2. DESCRIPCION
1) Herramientas para la construcción de procesadores de lenguaje.
A continuación, se muestran algunas de las herramientas disponibles que pueden utilizarse para
la construcción de Procesadores de Lenguaje.
Aplicación de los lenguajes:
2) Reseña Histórica
1940’s:
– Primeros ordenadores.
– Programación directa en código máquina.
– Nace el ensamblador (traducido manualmente)
– Se automatiza la etapa de ensamblado
1950’s
– (1950) John Backus dirige en IBM un proyecto de lenguaje algebraico
– (1954-1958) Nace el FORTRAN (FORmulae TRANslator)
– Primer compilador de FORTRAN para IBM modelo 704
1950’s (finales):
– F.L. Bauer (Univ. Munich) dirige un proyecto de lenguaje formal
– Se crea un comité conjunto con la Association for Computing Machinery en el que
participa Backus
– Se define IAL (International Algebraic Language)
– Posteriormente se denomina ALGOL 58 (ALGOrithmic Language)
Características de ALGOL 58
– Definición de la notación BNF (Backus-Naur Form)
– Declaración de tipos de variables
– Estructura modular
– Funciones recursivas
– Paso de parámetros por valor o por nombre
– Precursor de Pascal, Ada o Modula
1970’s:
– Se estudian las gramáticas LR
– Se definen los métodos de análisis ascendente SLR y LALR
– Se crean numerosas herramientas de ayuda al diseño de compiladores
– A mediados de la década aparecen las herramientas lex y yacc que se convierten en
estándares de facto al distribuirse con UNIX.
– La Free Software Fundation distribuye estas herramientas bajo los nombres de flex y
bison
Generación de código:
– Inicialmente la gestión de la memoria era estática
– Cuando aparecen las funciones recursivas se desarrolla la pila como forma de
gestionar la memoria
– La gestión de memoria dinámica conduce a la definición del montículo (heap) como
zona de gestión de esta memoria
– Surgen nuevos problemas como las referencias pérdidas o la recogida de basura
Últimos avances:
– Optimización de código
– Máquinas virtuales y auge de los lenguajes interpretados
3) Diseño y construcción de un compilador
Análisis léxico
Objetivo:
– Leer caracteres e identificar componentes léxicos (tokens)
– Filtrar comentarios
– Detectar errores léxicos
Ejemplo:
Análisis Sintáctico
Objetivo:
– Verificar estructuras gramaticales
– Detectar errores de sintaxis
Especificación:
– Gramáticas libres de contexto
Ejemplo:
Análisis Semántico
Objetivo:
– Verificar restricciones semánticas (predefinición de variables, consistencia de tipos,
llamadas a funciones)
– Generar un Árbol de Sintaxis Abstracta
Especificación:
– Gramáticas atribuidas
Ejemplo:
Las herramientas Flex y Bison
4) Que es flex y Bison
Flex es un una herramienta que permite generar analizadores léxicos. A partir de un conjunto de
expresiones regulares, Flex busca concordancias en un fichero de entrada y ejecuta acciones
asociadas a estas expresiones. Es compatible casi al 100% con Lex, una herramienta clásica de
Unix para la generación de analizadores léxicos, pero es un desarrollo diferente realizado por
GNU bajo licencia GPL.
Bison es un generador de analizadores sintácticos de propósito general que convierte una
descripción para una gramática independiente del contexto (en realidad de una subclase de
éstas, las LALR) en un programa en C que analiza esa gramática. Es compatible al 100% con
Yacc, una herramienta clásica de Unix para la generación de analizadores léxicos, pero es un
desarrollo diferente realizado por GNU bajo licencia GPL. Todas la gramáticas escritas
apropiadamente para Yacc deberían funcionar con Bison sin ningún cambio. Usándolo junto a
Flex esta herramienta permite construir compiladores de lenguajes.
5) Como se instala Flex y Bison
1) Es necesario obtener el software descargando la versión que necesitamos de las
páginas oficiales
http://gnuwin32.sourceforge.net/packages/flex.htm
2) Instalar el software en la unidad C: (para explicar a partir del punto 4 se tendrá como
hecho que flex y bison han sido instalados en la ruta: C:GnuWin32 donde contiene
una subcarpeta llamada bin donde se encuentran los programas respectivos)
3) Flex y bison son aplicaciones de consola, por lo que se deberá entrar al Símbolo del
sistema y tipear líneas de comando para ejecutar Flex.
4) 4. Si deseas que flex y bison se integren al conjunto de variables del entorno (esto
te va a permitir llamar a flex/bison desde cualquier ubicación en la línea de
comandos) debes hacer lo siguiente:
a. Clic derecho en “Mi PC”.
b. Selecciona “Propiedades”
c. Clic en la pestaña “Opciones Avanzadas”
d. Presiona el botón “Variables de entorno”
e. En la ventana de variables de entorno, ubicarse en la sección “Variables del
sistema”
f. luego haz clic en PATH y luego en el botón “Modificar” (si no está hacer clic
en
“Nueva” y agregar PATH)
g. En la nueva ventana, escribir la ruta completa al directorio “bin” de la
aplicación
flex/bison. Si existe otro valor, separarlos con comas.
h. Aceptar los cambios y luego reiniciar el sistema operativo.
6) Como se compila con Flex y Bison
Luego de escribir las especificaciones de flex y bison realizar lo siguiente.
• Si se desea invocar a flex:
o Por ejemplo, si se tiene un archivo de especificación de Flex llamado prueba.l
dentro de una carpeta “archivos” tipear lo siguiente C:archivos>flex prueba.l
o Luego presionar ENTER
o Se habrá generado un archivo de nombre lex.yy.c dentro de la carpeta donde se
encuentra el archivo prueba.l
• Para invocar a Bison en conjunción con flex realizar lo siguiente:
o Por ejemplo, si se tiene un archivo de especificación de Bison y Flex llamado
prueba.y y prueba.l respectivamente dentro de una carpeta “archivos” tipear lo
siguiente
o C:archivos>bison –d prueba.y
o C:archivos>flex prueba.l
o Luego al presionar ENTER se generarán tres archivos para su
posteriorcompilación: prueba.tab.h, prueba.tab.c y lex.yy.c.
Para compilar los archivos generados.
Luego de haber generado los archivos .c tipear lo siguiente:
• C:gcc –o pruebaej lex.yy.c
• Con esto generará se un archivo llamado “pruebaej.exe”
• El argumento –o permite crear el archivo ejecutable
7) 2 Ejemplos de la creación de un compilador utilizando Flex y Bison.
Ejemplo1:
Vamos a realizar un ejemplo de una calculadora sencilla que reconocerá las principales
operaciones aritmética (+,-,* y /).
Abrimos un editor de texto y pegamos el siguiente código que será nuestro scanner
/*****************
Definiciones
Se colocan las cabeceras, variables y expresiones regulares
********************/
%{
#include <stdio.h>
#include <stdlib.h>
#include "sintactico.tab.h"
int linea=0;
%}
/*
Creamos todas las expresiones regulares
Creamos la definición llamada DIGITO, podemos acceder esta definición
usando {DIGITO}*/
DIGITO [0-9]
NUMERO {DIGITO}+("."{DIGITO}+)?
%%
/***************
Reglas
*****************/
/* Creamos las reglas que reconocerán las cadenas que acepte
Nuestro scanner y retornaremos el token a bison con la
funcion return. */
{NUMERO} {yylval.real=atof(yytext); return(NUMERO);}
"=" {return(IGUAL);}
"+" {return(MAS);}
"-" {return(MENOS);}
";" {return(PTOCOMA);}
"*" {return(POR);}
"/" {return(DIV);}
"(" {return(PAA);}
")" {return(PAC);}
"n" {linea++;}
[trf] {}
" " {}
/* Si en nuestra entrada tiene algún caracter que no pertenece a
las reglas anteriores, se genera un error léxico */
. {printf("Error lexico en linea %d",linea);}
%%
/*
Código de Usuario
Aquí podemos realizar otras funciones, como por ejemplo ingresar
símbolos a nuestra tabal de símbolos o cualquier otra accione
del usuario.
Todo lo que el usuario coloque en esta sección se copiara al
archvi lex.yy.c tal y como esta.
*/
Guardamos el archivo como lexico.l. Luego creamos un nuevo archivo y colocamos el
siguiente código.
%{
/********************
Declaraciones en C
**********************/
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
extern int yylex(void);
extern char *yytext;
extern int linea;
extern FILE *yyin;
void yyerror(char *s);
%}
/************************
Declaraciones de Bison
*************************/
/* Especifica la coleccion completa de tipos de datos para poder usar
varios tipos de datos en los terminales y no terminales*/
%union
{
float real;
}
/* Indica la produccion con la que inicia nuestra gramatica*/
%start Exp_l
/* Especificacion de termines, podemos especificar tambien su tipo */
%token <real> NUMERO
%token MAS
%token MENOS
%token IGUAL
%token PTOCOMA
%token POR
%token DIV
%token PAA
%token PAC
/* No Terminales, que tambien podemos especificar su tipo */
%type <real> Exp
%type <real> Calc
%type <real> Exp_l
/* Definimos las precedencias de menor a mayor */
%left MAS MENOS
%left POR DIV
%%
/**********************
Reglas Gramaticales
***********************/
Exp_l: Exp_l Calc
|Calc
;
Calc : Exp PTOCOMA {printf ("%4.1fn",$1)}
;
/* con el símbolo de $$ asignamos el valor semántico de toda
la acción de la derecha y se la asignamos al no terminal de
la izquierda, en la siguiente regla, se la asigna a Exp.
Para poder acceder al valor de los terminales y no terminales del lado
derecho usamos el símbolo $ y le concatenamos un numero que representa
la posición en la que se encuentra es decir si tenemos
A --> B NUMERO C
Si queremos usar le valor que tiene el no terminal B usamos $1, si queremos
usar el valor que tiene NUMERO usamos $2 y así sucesivamente.
*/
Exp : NUMERO {$$=$1;}
|Exp MAS Exp {$$=$1+$3;}
|Exp MENOS Exp {$$=$1-$3;}
|Exp POR Exp {$$=$1*$3;}
|Exp DIV Exp {$$=$1/$3;}
|PAA Exp PAC {$$=$2;}
;
%%
/********************
Codigo C Adicional
**********************/
void yyerror(char *s)
{
printf("Error sintactico %s",s);
}
int main(int argc,char **argv)
{
if (argc>1)
yyin=fopen(argv[1],"rt");
else
yyin=stdin;
yyparse();
return 0;
}
Guardamos este archivo con el nombre sintáctico.y y con eso ya tenemos nuestro scanner y
nuestro parser terminado. Para compilar estos archivos usamos los comandos
Compilando sintactico.y
~> bison -d sintactico.y
El parámetro –d, crea el fichero t.tab.h, que contiene los identificadores de los tokens de bison
usados por flex
Compilando lexico.l
~> flex lexico.l
Compilando arhivos generados y crear ejecutable
~> cc lex.yy.c sintactico.tab.c -o analizador -lfl -lm
Esto nos genera un ejecutable llamado analizador.
Muchas veces necesitamos modificar nuestro archivo sintáctico.y o lexico.l y tenemos que
compilar todo cada vez que hacemos un cambio, para no estar escribiendo los comandos cada
vez que realizamos un cambio, crearemos un script, que al ejecutarlo realizara todos los
comandos de compilación. Para eso creamos un nuevo archivo en blanco y escribimos
#!/bin/bash
bison -d sintactico.y
flex lexico.l
cc lex.yy.c sintactico.tab.c -o analizador -lfl –lm
Guardamos este archivo con cualquier nombre, por ejemplo compilar.sh. Ahora cambiaremos
las propiedades de este archivo para poder ejecutar. Le damos clic derecho sobre este archivo
y en la pestaña permisos elegimos la opción de “Permitir ejecutar el archivo como un
programa”, cerramos esa ventana.
Para poder compilar, desde consola nos ubicamos donde se encuentra este archivo .sh y
escribimos
./compilar.sh
Esto nos genera nuestro ejecutable que podemos correr para poder probar nuestra
calculadora. Para ejecutar este ejemplo usamos el comando
./analizador
Ingresamos algunas
expresiones y el
resultado que obtenemos
es:
Ejemplo2:
Ante la siguiente entrada a =12+2*cos(3.14)
La salida debe ser:
El valor del identificador a es 10.LABORATORIO DE PROCESADORES DE LENGUAJE CURSO2010-
11
Fichero léxico_solo.l
%
{ /* Ejemplo para una pequeña calculadora que permite trabajar con numeros enteros y reales
con las operaciones básicas de suma, resta, producto, division y trigonometricas como el seno
y el coseno*/
#include <stdio.h>
#include <stdlib.h> int nlines=0; %} DIGITO [0-9] ID [a-zA-Z][a-zA-Z0-9_]*
%% {DIGITO}+ {printf("Encontrado TKN_NUM_ENTERO:%d",atoi(yytext));}
{DIGITO}+"."{DIGITO}+ {printf("Encontrado TKN_NUM_REAL:%f",atof(yytext));} "="
{printf("Encontrado TKN_ASIGN: %s",yytext);} ";"
{printf("Encontrado TKN_PTOCOMA: %s",yytext);} "*" {printf("Encontrado TKN_MULT:
%s",yytext);} "/" {printf("Encontrado TKN_DIV: %s",yytext);} "+" {printf("Encontrado TKN_MAS:
%s",yytext);} "-" {printf("Encontrado TKN_MENOS: %s",yytext);} "(" {printf("Encontrado
TKN_PAA: %s",yytext);} ")" {printf("Encontrado TKN_PAC: %s",yytext);} "cos"
{printf("Encontrado TKN_COS: %s",yytext);} "sen" {printf("Encontrado TKN_SEN:%s",yytext);}
{ID} {printf("Encontrado TKN_ID: %s",yytext);} "n" {nlines++;} .LABORATORIO DE
PROCESADORES DE LENGUAJE CURSO 2010-11 %% void main(int argc,char **argv) { if (argc>1)
yyin=fopen(argv[1],"rt"); else yyin=stdin; yylex(); printf("nNumero lineas analizadas: %dn",
nlines);
} /* para compilar flex lexico.l cc lex.yy.c -o milex -lfl -lm */LABORATORIO DE PROCESADORES
DE LENGUAJE CURSO 2010-11 Fichero léxico.l (versión a enlazar con Bison) %{ /* Ejemplo para
una pequeña calculadora que permite trabajar con las operaciones básicas de suma, resta,
producto, divisiony trigonometricas como el seno y el coseno */ #include <stdio.h> #include
<stdlib.h> #include "sintactico.tab.h" int nlines=0; %} DIGITO [0-9] ID [a-zA-Z][a-zA-Z0-9_]* %%
{DIGITO}+("."{DIGITO}+)? {//printf("Encontrado TKN_NUM: %fn",atof(yytext));
yylval.real=atof(yytext); return(TKN_NUM);} "=" {//printf("Encontrado TKN_ASIGN:
%sn",yytext); return(TKN_ASIGN);} ";" {//printf("Encontrado TKN_PTOCOMA: %sn",yytext);
return(TKN_PTOCOMA);} "*" {//printf("Encontrado TKN_MULT: %sn",yytext);
return(TKN_MULT);} "/" {//printf("Encontrado TKN_DIV: %sn",yytext); return(TKN_DIV);} "+"
{//printf("Encontrado TKN_MAS: %sn",yytext); return(TKN_MAS);} "-" {//printf("Encontrado
TKN_MENOS: %sn",yytext);LABORATORIO DE PROCESADORES DELENGUAJE CURSO 2010-11
return(TKN_MENOS);} "(" {//printf("Encontrado TKN_PAA: %sn",yytext); return(TKN_PAA);} ")"
{//printf("Encontrado TKN_PAC: %sn",yytext); return(TKN_PAC);} "cos" {//printf("Encontrado
TKN_COS: %sn",yytext); return(TKN_COS);} "sen" {//printf("Encontrado TKN_SEN:
%sn",yytext); return(TKN_SEN);} {ID} {//printf("Encontrado TKN_ID: %sn",yytext);
return(TKN_ID);} "n" {nlines++;} . %% /********
Para el lexico solo void main(int argc,char **argv) { if (argc>1) yyin=fopen(argv[1],"rt"); else
yyin=stdin; yylex(); printf("nNumero lineas analizadas: %dn", nlines); } *******/ /* para
compilar flex lexico.l cc lex.yy.c -o milex -lfl -lm */LABORATORIO DE PROCESADORES DE
LENGUAJE CURSO 2010-11 Fichero sintactico.y (Bison)
%

Más contenido relacionado

La actualidad más candente

Flex y Bison
Flex y BisonFlex y Bison
Flex y Bison
Bryant Arellano
 
FLEX Y BISON
FLEX Y BISONFLEX Y BISON
FLEX Y BISON
Anthony Benalcazar
 
INTRODUCCION A FLEX Y BISON
INTRODUCCION A FLEX Y BISONINTRODUCCION A FLEX Y BISON
INTRODUCCION A FLEX Y BISON
Guissela Guerrero
 
Flex y bison
Flex y bisonFlex y bison
Flex y bison
Zulay Limaico
 
4 3 Archivos Por Lotes Y Guiones
4 3 Archivos Por Lotes Y Guiones4 3 Archivos Por Lotes Y Guiones
4 3 Archivos Por Lotes Y Guiones
UVM
 
Conceptos Básicos acerca de Procesadores de Lenguajes
Conceptos Básicos acerca de Procesadores de LenguajesConceptos Básicos acerca de Procesadores de Lenguajes
Conceptos Básicos acerca de Procesadores de Lenguajes
Grace Laguna
 
Unidad 9:
Unidad 9: Unidad 9:
Unidad 9:
carmenrico14
 
Fyb
FybFyb
EL SHELL Y COMANDOS BASICOS DE LINUX
EL SHELL Y COMANDOS BASICOS DE LINUXEL SHELL Y COMANDOS BASICOS DE LINUX
EL SHELL Y COMANDOS BASICOS DE LINUX
Gabriel Herrera Garzon
 
COMPILADORES
COMPILADORESCOMPILADORES
COMPILADORES
marcos ruales
 
Archivos de datos en C
Archivos de datos en CArchivos de datos en C
Archivos de datos en C
José Ricardo Tillero Giménez
 
Manejo de archivosss
Manejo de archivosssManejo de archivosss
Manejo de archivosss
taniarodri
 
Trabajo compiladores ivan bolaños
Trabajo compiladores ivan bolañosTrabajo compiladores ivan bolaños
Trabajo compiladores ivan bolaños
Iván Bolaños
 
Taller de flex y bison
Taller de flex y bisonTaller de flex y bison
Taller de flex y bison
Fabricio Galárraga
 
Programacinenshell linux
Programacinenshell linuxProgramacinenshell linux
Programacinenshell linux
usupr2014
 
Semana 9 standard io and pipes guia de ejercicios resuelta
Semana 9   standard io and pipes  guia de ejercicios resueltaSemana 9   standard io and pipes  guia de ejercicios resuelta
Semana 9 standard io and pipes guia de ejercicios resuelta
victdiazm
 
D o s trabajo jueves
D o s trabajo juevesD o s trabajo jueves
D o s trabajo jueves
chrifer123
 
Compiladores
CompiladoresCompiladores
Compiladores
Urban Lovers InC
 
Ficheros de cabecera
Ficheros de cabecera Ficheros de cabecera
Ficheros de cabecera
cecibelencalada
 

La actualidad más candente (19)

Flex y Bison
Flex y BisonFlex y Bison
Flex y Bison
 
FLEX Y BISON
FLEX Y BISONFLEX Y BISON
FLEX Y BISON
 
INTRODUCCION A FLEX Y BISON
INTRODUCCION A FLEX Y BISONINTRODUCCION A FLEX Y BISON
INTRODUCCION A FLEX Y BISON
 
Flex y bison
Flex y bisonFlex y bison
Flex y bison
 
4 3 Archivos Por Lotes Y Guiones
4 3 Archivos Por Lotes Y Guiones4 3 Archivos Por Lotes Y Guiones
4 3 Archivos Por Lotes Y Guiones
 
Conceptos Básicos acerca de Procesadores de Lenguajes
Conceptos Básicos acerca de Procesadores de LenguajesConceptos Básicos acerca de Procesadores de Lenguajes
Conceptos Básicos acerca de Procesadores de Lenguajes
 
Unidad 9:
Unidad 9: Unidad 9:
Unidad 9:
 
Fyb
FybFyb
Fyb
 
EL SHELL Y COMANDOS BASICOS DE LINUX
EL SHELL Y COMANDOS BASICOS DE LINUXEL SHELL Y COMANDOS BASICOS DE LINUX
EL SHELL Y COMANDOS BASICOS DE LINUX
 
COMPILADORES
COMPILADORESCOMPILADORES
COMPILADORES
 
Archivos de datos en C
Archivos de datos en CArchivos de datos en C
Archivos de datos en C
 
Manejo de archivosss
Manejo de archivosssManejo de archivosss
Manejo de archivosss
 
Trabajo compiladores ivan bolaños
Trabajo compiladores ivan bolañosTrabajo compiladores ivan bolaños
Trabajo compiladores ivan bolaños
 
Taller de flex y bison
Taller de flex y bisonTaller de flex y bison
Taller de flex y bison
 
Programacinenshell linux
Programacinenshell linuxProgramacinenshell linux
Programacinenshell linux
 
Semana 9 standard io and pipes guia de ejercicios resuelta
Semana 9   standard io and pipes  guia de ejercicios resueltaSemana 9   standard io and pipes  guia de ejercicios resuelta
Semana 9 standard io and pipes guia de ejercicios resuelta
 
D o s trabajo jueves
D o s trabajo juevesD o s trabajo jueves
D o s trabajo jueves
 
Compiladores
CompiladoresCompiladores
Compiladores
 
Ficheros de cabecera
Ficheros de cabecera Ficheros de cabecera
Ficheros de cabecera
 

Similar a Pontificia universidad católica del ecuador flex y bison

Flex y Bison
Flex y BisonFlex y Bison
Flex y Bison
Henry Cordova
 
Flex y bison
Flex y bisonFlex y bison
Flex y bison
Carlos Rivadeneira
 
Taller
TallerTaller
Flex bison
Flex bisonFlex bison
Flex bison
Jose Ibadango
 
Flex y bison
Flex y  bisonFlex y  bison
Flex y bison
Lenin Andrango
 
Flex bison
Flex bisonFlex bison
Flex bison
Carlos Brusil
 
Flex ybison
Flex ybisonFlex ybison
Flex ybison
Carlos Brusil
 
Herramientas flex y bison
Herramientas  flex y bisonHerramientas  flex y bison
Herramientas flex y bison
Carlos Yepez
 
Flex y-bison
Flex y-bisonFlex y-bison
Flex y-bison
JOSSELINEMARIBEL
 
TALLER FLEX Y BISON
TALLER FLEX Y BISONTALLER FLEX Y BISON
TALLER FLEX Y BISON
Anthony Benalcazar
 
Herramientas flex y bison
Herramientas flex y bisonHerramientas flex y bison
Herramientas flex y bison
alexisdario
 
Flex y Bison
Flex y BisonFlex y Bison
Flex y Bison
Guiru Xd
 
Flex y bison
Flex y bisonFlex y bison
Flex y bison
Mario Granja Alvear
 
Taller flex y bison
Taller flex y bisonTaller flex y bison
Taller flex y bison
danilopuente
 
Taller 21 de junio
Taller 21 de junioTaller 21 de junio
Taller 21 de junio
Alex Ortiz
 
Bison y flex
Bison y flexBison y flex
Bison y flex
Christian Morales
 
Flex y bison
Flex y bisonFlex y bison
Flex y bison
AndresDvila
 
Flex y bison
Flex y bisonFlex y bison
Flex y bison
Andres Pozo
 
Taller
TallerTaller
Taller
alexisdario
 
Flex y bison
Flex y bisonFlex y bison
Flex y bison
Alvaro Cedeño
 

Similar a Pontificia universidad católica del ecuador flex y bison (20)

Flex y Bison
Flex y BisonFlex y Bison
Flex y Bison
 
Flex y bison
Flex y bisonFlex y bison
Flex y bison
 
Taller
TallerTaller
Taller
 
Flex bison
Flex bisonFlex bison
Flex bison
 
Flex y bison
Flex y  bisonFlex y  bison
Flex y bison
 
Flex bison
Flex bisonFlex bison
Flex bison
 
Flex ybison
Flex ybisonFlex ybison
Flex ybison
 
Herramientas flex y bison
Herramientas  flex y bisonHerramientas  flex y bison
Herramientas flex y bison
 
Flex y-bison
Flex y-bisonFlex y-bison
Flex y-bison
 
TALLER FLEX Y BISON
TALLER FLEX Y BISONTALLER FLEX Y BISON
TALLER FLEX Y BISON
 
Herramientas flex y bison
Herramientas flex y bisonHerramientas flex y bison
Herramientas flex y bison
 
Flex y Bison
Flex y BisonFlex y Bison
Flex y Bison
 
Flex y bison
Flex y bisonFlex y bison
Flex y bison
 
Taller flex y bison
Taller flex y bisonTaller flex y bison
Taller flex y bison
 
Taller 21 de junio
Taller 21 de junioTaller 21 de junio
Taller 21 de junio
 
Bison y flex
Bison y flexBison y flex
Bison y flex
 
Flex y bison
Flex y bisonFlex y bison
Flex y bison
 
Flex y bison
Flex y bisonFlex y bison
Flex y bison
 
Taller
TallerTaller
Taller
 
Flex y bison
Flex y bisonFlex y bison
Flex y bison
 

Más de Gabriel Solano

Pontificia universidad católica del ecuador sistemas complejos
Pontificia universidad católica del ecuador sistemas complejosPontificia universidad católica del ecuador sistemas complejos
Pontificia universidad católica del ecuador sistemas complejos
Gabriel Solano
 
Pontificia universidad católica del ecuador algoritmo huffman
Pontificia universidad católica del ecuador algoritmo huffmanPontificia universidad católica del ecuador algoritmo huffman
Pontificia universidad católica del ecuador algoritmo huffman
Gabriel Solano
 
Pontificia universidad católica del ecuador calculo de la entropía
Pontificia universidad católica del ecuador calculo de la entropíaPontificia universidad católica del ecuador calculo de la entropía
Pontificia universidad católica del ecuador calculo de la entropía
Gabriel Solano
 
Pontificia universidad católica del ecuador ley de la entropia
Pontificia universidad católica del ecuador ley de la entropiaPontificia universidad católica del ecuador ley de la entropia
Pontificia universidad católica del ecuador ley de la entropia
Gabriel Solano
 
Pontificia universidad católica del ecuador tutorial de vegas
Pontificia universidad católica del ecuador tutorial de vegasPontificia universidad católica del ecuador tutorial de vegas
Pontificia universidad católica del ecuador tutorial de vegas
Gabriel Solano
 
Pontificia universidad católica del ecuador virtualizacion
Pontificia universidad católica del ecuador virtualizacionPontificia universidad católica del ecuador virtualizacion
Pontificia universidad católica del ecuador virtualizacion
Gabriel Solano
 
Pontificia universidad católica del ecuador entropia y neguentropia
Pontificia universidad católica del ecuador entropia y neguentropiaPontificia universidad católica del ecuador entropia y neguentropia
Pontificia universidad católica del ecuador entropia y neguentropia
Gabriel Solano
 
Pontificia universidad católica del ecuador segmentacion
Pontificia universidad católica del ecuador segmentacionPontificia universidad católica del ecuador segmentacion
Pontificia universidad católica del ecuador segmentacion
Gabriel Solano
 
Pontificia universidad católica del ecuador ingenieria en sistemas
Pontificia universidad católica del ecuador ingenieria en sistemasPontificia universidad católica del ecuador ingenieria en sistemas
Pontificia universidad católica del ecuador ingenieria en sistemas
Gabriel Solano
 
Pontificia universidad católica del ecuador matlab operadores morfológicos
Pontificia universidad católica del ecuador matlab operadores morfológicosPontificia universidad católica del ecuador matlab operadores morfológicos
Pontificia universidad católica del ecuador matlab operadores morfológicos
Gabriel Solano
 
Pontificia universidad católica del ecuador teoria de juegos ejercicios
Pontificia universidad católica del ecuador teoria de juegos ejerciciosPontificia universidad católica del ecuador teoria de juegos ejercicios
Pontificia universidad católica del ecuador teoria de juegos ejercicios
Gabriel Solano
 
Pontificia universidad católica del ecuador filtrado y realzado
Pontificia universidad católica del ecuador filtrado y realzadoPontificia universidad católica del ecuador filtrado y realzado
Pontificia universidad católica del ecuador filtrado y realzado
Gabriel Solano
 
Pontificia universidad católica del ecuador matlab imagenes
Pontificia universidad católica del ecuador matlab imagenesPontificia universidad católica del ecuador matlab imagenes
Pontificia universidad católica del ecuador matlab imagenes
Gabriel Solano
 
Pontificia universidad católica del ecuador toma de decisiones
Pontificia universidad católica del ecuador toma de decisionesPontificia universidad católica del ecuador toma de decisiones
Pontificia universidad católica del ecuador toma de decisiones
Gabriel Solano
 
Pontificia universidad católica del ecuador teoria de juegos
Pontificia universidad católica del ecuador teoria de juegosPontificia universidad católica del ecuador teoria de juegos
Pontificia universidad católica del ecuador teoria de juegos
Gabriel Solano
 
Pontificia universidad católica del ecuador matlab 2
Pontificia universidad católica del ecuador matlab 2Pontificia universidad católica del ecuador matlab 2
Pontificia universidad católica del ecuador matlab 2
Gabriel Solano
 
Matrices manual
Matrices manualMatrices manual
Matrices manual
Gabriel Solano
 
Pontificia universidad católica del ecuador trabajo autonomo
Pontificia universidad católica del ecuador trabajo autonomoPontificia universidad católica del ecuador trabajo autonomo
Pontificia universidad católica del ecuador trabajo autonomo
Gabriel Solano
 
Pontificia universidad católica del ecuador matlab
Pontificia universidad católica del ecuador matlabPontificia universidad católica del ecuador matlab
Pontificia universidad católica del ecuador matlab
Gabriel Solano
 
Pontificia universidad católica del ecuador manual matlab
Pontificia universidad católica del ecuador manual matlabPontificia universidad católica del ecuador manual matlab
Pontificia universidad católica del ecuador manual matlab
Gabriel Solano
 

Más de Gabriel Solano (20)

Pontificia universidad católica del ecuador sistemas complejos
Pontificia universidad católica del ecuador sistemas complejosPontificia universidad católica del ecuador sistemas complejos
Pontificia universidad católica del ecuador sistemas complejos
 
Pontificia universidad católica del ecuador algoritmo huffman
Pontificia universidad católica del ecuador algoritmo huffmanPontificia universidad católica del ecuador algoritmo huffman
Pontificia universidad católica del ecuador algoritmo huffman
 
Pontificia universidad católica del ecuador calculo de la entropía
Pontificia universidad católica del ecuador calculo de la entropíaPontificia universidad católica del ecuador calculo de la entropía
Pontificia universidad católica del ecuador calculo de la entropía
 
Pontificia universidad católica del ecuador ley de la entropia
Pontificia universidad católica del ecuador ley de la entropiaPontificia universidad católica del ecuador ley de la entropia
Pontificia universidad católica del ecuador ley de la entropia
 
Pontificia universidad católica del ecuador tutorial de vegas
Pontificia universidad católica del ecuador tutorial de vegasPontificia universidad católica del ecuador tutorial de vegas
Pontificia universidad católica del ecuador tutorial de vegas
 
Pontificia universidad católica del ecuador virtualizacion
Pontificia universidad católica del ecuador virtualizacionPontificia universidad católica del ecuador virtualizacion
Pontificia universidad católica del ecuador virtualizacion
 
Pontificia universidad católica del ecuador entropia y neguentropia
Pontificia universidad católica del ecuador entropia y neguentropiaPontificia universidad católica del ecuador entropia y neguentropia
Pontificia universidad católica del ecuador entropia y neguentropia
 
Pontificia universidad católica del ecuador segmentacion
Pontificia universidad católica del ecuador segmentacionPontificia universidad católica del ecuador segmentacion
Pontificia universidad católica del ecuador segmentacion
 
Pontificia universidad católica del ecuador ingenieria en sistemas
Pontificia universidad católica del ecuador ingenieria en sistemasPontificia universidad católica del ecuador ingenieria en sistemas
Pontificia universidad católica del ecuador ingenieria en sistemas
 
Pontificia universidad católica del ecuador matlab operadores morfológicos
Pontificia universidad católica del ecuador matlab operadores morfológicosPontificia universidad católica del ecuador matlab operadores morfológicos
Pontificia universidad católica del ecuador matlab operadores morfológicos
 
Pontificia universidad católica del ecuador teoria de juegos ejercicios
Pontificia universidad católica del ecuador teoria de juegos ejerciciosPontificia universidad católica del ecuador teoria de juegos ejercicios
Pontificia universidad católica del ecuador teoria de juegos ejercicios
 
Pontificia universidad católica del ecuador filtrado y realzado
Pontificia universidad católica del ecuador filtrado y realzadoPontificia universidad católica del ecuador filtrado y realzado
Pontificia universidad católica del ecuador filtrado y realzado
 
Pontificia universidad católica del ecuador matlab imagenes
Pontificia universidad católica del ecuador matlab imagenesPontificia universidad católica del ecuador matlab imagenes
Pontificia universidad católica del ecuador matlab imagenes
 
Pontificia universidad católica del ecuador toma de decisiones
Pontificia universidad católica del ecuador toma de decisionesPontificia universidad católica del ecuador toma de decisiones
Pontificia universidad católica del ecuador toma de decisiones
 
Pontificia universidad católica del ecuador teoria de juegos
Pontificia universidad católica del ecuador teoria de juegosPontificia universidad católica del ecuador teoria de juegos
Pontificia universidad católica del ecuador teoria de juegos
 
Pontificia universidad católica del ecuador matlab 2
Pontificia universidad católica del ecuador matlab 2Pontificia universidad católica del ecuador matlab 2
Pontificia universidad católica del ecuador matlab 2
 
Matrices manual
Matrices manualMatrices manual
Matrices manual
 
Pontificia universidad católica del ecuador trabajo autonomo
Pontificia universidad católica del ecuador trabajo autonomoPontificia universidad católica del ecuador trabajo autonomo
Pontificia universidad católica del ecuador trabajo autonomo
 
Pontificia universidad católica del ecuador matlab
Pontificia universidad católica del ecuador matlabPontificia universidad católica del ecuador matlab
Pontificia universidad católica del ecuador matlab
 
Pontificia universidad católica del ecuador manual matlab
Pontificia universidad católica del ecuador manual matlabPontificia universidad católica del ecuador manual matlab
Pontificia universidad católica del ecuador manual matlab
 

Pontificia universidad católica del ecuador flex y bison

  • 1. PONTIFICIA UNIVERSIDAD CATÓLICA DEL ECUADOR SEDE IBARRA 1. DATOS INFORMATIVOS 1.1 Nombre: Gabriel Solano 1.2 Carrera: Sistemas 1.3 Nivel: 5to 1.4 Tema: Compiladores 1.5 Fecha: 21/06/2017 2. DESCRIPCION 1) Herramientas para la construcción de procesadores de lenguaje. A continuación, se muestran algunas de las herramientas disponibles que pueden utilizarse para la construcción de Procesadores de Lenguaje.
  • 2. Aplicación de los lenguajes: 2) Reseña Histórica 1940’s: – Primeros ordenadores. – Programación directa en código máquina. – Nace el ensamblador (traducido manualmente) – Se automatiza la etapa de ensamblado 1950’s – (1950) John Backus dirige en IBM un proyecto de lenguaje algebraico – (1954-1958) Nace el FORTRAN (FORmulae TRANslator) – Primer compilador de FORTRAN para IBM modelo 704 1950’s (finales): – F.L. Bauer (Univ. Munich) dirige un proyecto de lenguaje formal – Se crea un comité conjunto con la Association for Computing Machinery en el que participa Backus – Se define IAL (International Algebraic Language) – Posteriormente se denomina ALGOL 58 (ALGOrithmic Language) Características de ALGOL 58 – Definición de la notación BNF (Backus-Naur Form) – Declaración de tipos de variables – Estructura modular – Funciones recursivas – Paso de parámetros por valor o por nombre – Precursor de Pascal, Ada o Modula
  • 3. 1970’s: – Se estudian las gramáticas LR – Se definen los métodos de análisis ascendente SLR y LALR – Se crean numerosas herramientas de ayuda al diseño de compiladores – A mediados de la década aparecen las herramientas lex y yacc que se convierten en estándares de facto al distribuirse con UNIX. – La Free Software Fundation distribuye estas herramientas bajo los nombres de flex y bison Generación de código: – Inicialmente la gestión de la memoria era estática – Cuando aparecen las funciones recursivas se desarrolla la pila como forma de gestionar la memoria – La gestión de memoria dinámica conduce a la definición del montículo (heap) como zona de gestión de esta memoria – Surgen nuevos problemas como las referencias pérdidas o la recogida de basura Últimos avances: – Optimización de código – Máquinas virtuales y auge de los lenguajes interpretados
  • 4. 3) Diseño y construcción de un compilador Análisis léxico Objetivo: – Leer caracteres e identificar componentes léxicos (tokens) – Filtrar comentarios – Detectar errores léxicos Ejemplo: Análisis Sintáctico Objetivo: – Verificar estructuras gramaticales – Detectar errores de sintaxis Especificación: – Gramáticas libres de contexto
  • 5. Ejemplo: Análisis Semántico Objetivo: – Verificar restricciones semánticas (predefinición de variables, consistencia de tipos, llamadas a funciones) – Generar un Árbol de Sintaxis Abstracta Especificación: – Gramáticas atribuidas Ejemplo:
  • 6. Las herramientas Flex y Bison 4) Que es flex y Bison Flex es un una herramienta que permite generar analizadores léxicos. A partir de un conjunto de expresiones regulares, Flex busca concordancias en un fichero de entrada y ejecuta acciones asociadas a estas expresiones. Es compatible casi al 100% con Lex, una herramienta clásica de Unix para la generación de analizadores léxicos, pero es un desarrollo diferente realizado por GNU bajo licencia GPL. Bison es un generador de analizadores sintácticos de propósito general que convierte una descripción para una gramática independiente del contexto (en realidad de una subclase de éstas, las LALR) en un programa en C que analiza esa gramática. Es compatible al 100% con Yacc, una herramienta clásica de Unix para la generación de analizadores léxicos, pero es un desarrollo diferente realizado por GNU bajo licencia GPL. Todas la gramáticas escritas apropiadamente para Yacc deberían funcionar con Bison sin ningún cambio. Usándolo junto a Flex esta herramienta permite construir compiladores de lenguajes. 5) Como se instala Flex y Bison 1) Es necesario obtener el software descargando la versión que necesitamos de las páginas oficiales http://gnuwin32.sourceforge.net/packages/flex.htm 2) Instalar el software en la unidad C: (para explicar a partir del punto 4 se tendrá como hecho que flex y bison han sido instalados en la ruta: C:GnuWin32 donde contiene una subcarpeta llamada bin donde se encuentran los programas respectivos) 3) Flex y bison son aplicaciones de consola, por lo que se deberá entrar al Símbolo del sistema y tipear líneas de comando para ejecutar Flex. 4) 4. Si deseas que flex y bison se integren al conjunto de variables del entorno (esto te va a permitir llamar a flex/bison desde cualquier ubicación en la línea de comandos) debes hacer lo siguiente: a. Clic derecho en “Mi PC”. b. Selecciona “Propiedades” c. Clic en la pestaña “Opciones Avanzadas” d. Presiona el botón “Variables de entorno” e. En la ventana de variables de entorno, ubicarse en la sección “Variables del sistema” f. luego haz clic en PATH y luego en el botón “Modificar” (si no está hacer clic en “Nueva” y agregar PATH)
  • 7. g. En la nueva ventana, escribir la ruta completa al directorio “bin” de la aplicación flex/bison. Si existe otro valor, separarlos con comas. h. Aceptar los cambios y luego reiniciar el sistema operativo. 6) Como se compila con Flex y Bison Luego de escribir las especificaciones de flex y bison realizar lo siguiente. • Si se desea invocar a flex: o Por ejemplo, si se tiene un archivo de especificación de Flex llamado prueba.l dentro de una carpeta “archivos” tipear lo siguiente C:archivos>flex prueba.l o Luego presionar ENTER o Se habrá generado un archivo de nombre lex.yy.c dentro de la carpeta donde se encuentra el archivo prueba.l • Para invocar a Bison en conjunción con flex realizar lo siguiente: o Por ejemplo, si se tiene un archivo de especificación de Bison y Flex llamado prueba.y y prueba.l respectivamente dentro de una carpeta “archivos” tipear lo siguiente o C:archivos>bison –d prueba.y o C:archivos>flex prueba.l o Luego al presionar ENTER se generarán tres archivos para su posteriorcompilación: prueba.tab.h, prueba.tab.c y lex.yy.c. Para compilar los archivos generados. Luego de haber generado los archivos .c tipear lo siguiente: • C:gcc –o pruebaej lex.yy.c • Con esto generará se un archivo llamado “pruebaej.exe” • El argumento –o permite crear el archivo ejecutable 7) 2 Ejemplos de la creación de un compilador utilizando Flex y Bison. Ejemplo1: Vamos a realizar un ejemplo de una calculadora sencilla que reconocerá las principales operaciones aritmética (+,-,* y /). Abrimos un editor de texto y pegamos el siguiente código que será nuestro scanner /***************** Definiciones Se colocan las cabeceras, variables y expresiones regulares
  • 8. ********************/ %{ #include <stdio.h> #include <stdlib.h> #include "sintactico.tab.h" int linea=0; %} /* Creamos todas las expresiones regulares Creamos la definición llamada DIGITO, podemos acceder esta definición usando {DIGITO}*/ DIGITO [0-9] NUMERO {DIGITO}+("."{DIGITO}+)? %% /*************** Reglas *****************/ /* Creamos las reglas que reconocerán las cadenas que acepte Nuestro scanner y retornaremos el token a bison con la funcion return. */ {NUMERO} {yylval.real=atof(yytext); return(NUMERO);} "=" {return(IGUAL);} "+" {return(MAS);} "-" {return(MENOS);} ";" {return(PTOCOMA);} "*" {return(POR);} "/" {return(DIV);} "(" {return(PAA);} ")" {return(PAC);} "n" {linea++;} [trf] {} " " {} /* Si en nuestra entrada tiene algún caracter que no pertenece a las reglas anteriores, se genera un error léxico */ . {printf("Error lexico en linea %d",linea);} %% /* Código de Usuario Aquí podemos realizar otras funciones, como por ejemplo ingresar símbolos a nuestra tabal de símbolos o cualquier otra accione del usuario. Todo lo que el usuario coloque en esta sección se copiara al archvi lex.yy.c tal y como esta. */
  • 9. Guardamos el archivo como lexico.l. Luego creamos un nuevo archivo y colocamos el siguiente código. %{ /******************** Declaraciones en C **********************/ #include <stdio.h> #include <stdlib.h> #include <math.h> extern int yylex(void); extern char *yytext; extern int linea; extern FILE *yyin; void yyerror(char *s); %} /************************ Declaraciones de Bison *************************/ /* Especifica la coleccion completa de tipos de datos para poder usar varios tipos de datos en los terminales y no terminales*/ %union { float real; } /* Indica la produccion con la que inicia nuestra gramatica*/ %start Exp_l /* Especificacion de termines, podemos especificar tambien su tipo */ %token <real> NUMERO %token MAS %token MENOS %token IGUAL %token PTOCOMA %token POR %token DIV %token PAA %token PAC /* No Terminales, que tambien podemos especificar su tipo */ %type <real> Exp %type <real> Calc %type <real> Exp_l /* Definimos las precedencias de menor a mayor */ %left MAS MENOS
  • 10. %left POR DIV %% /********************** Reglas Gramaticales ***********************/ Exp_l: Exp_l Calc |Calc ; Calc : Exp PTOCOMA {printf ("%4.1fn",$1)} ; /* con el símbolo de $$ asignamos el valor semántico de toda la acción de la derecha y se la asignamos al no terminal de la izquierda, en la siguiente regla, se la asigna a Exp. Para poder acceder al valor de los terminales y no terminales del lado derecho usamos el símbolo $ y le concatenamos un numero que representa la posición en la que se encuentra es decir si tenemos A --> B NUMERO C Si queremos usar le valor que tiene el no terminal B usamos $1, si queremos usar el valor que tiene NUMERO usamos $2 y así sucesivamente. */ Exp : NUMERO {$$=$1;} |Exp MAS Exp {$$=$1+$3;} |Exp MENOS Exp {$$=$1-$3;} |Exp POR Exp {$$=$1*$3;} |Exp DIV Exp {$$=$1/$3;} |PAA Exp PAC {$$=$2;} ; %% /******************** Codigo C Adicional **********************/ void yyerror(char *s) { printf("Error sintactico %s",s); } int main(int argc,char **argv) { if (argc>1) yyin=fopen(argv[1],"rt"); else yyin=stdin; yyparse(); return 0;
  • 11. } Guardamos este archivo con el nombre sintáctico.y y con eso ya tenemos nuestro scanner y nuestro parser terminado. Para compilar estos archivos usamos los comandos Compilando sintactico.y ~> bison -d sintactico.y El parámetro –d, crea el fichero t.tab.h, que contiene los identificadores de los tokens de bison usados por flex Compilando lexico.l ~> flex lexico.l Compilando arhivos generados y crear ejecutable ~> cc lex.yy.c sintactico.tab.c -o analizador -lfl -lm Esto nos genera un ejecutable llamado analizador. Muchas veces necesitamos modificar nuestro archivo sintáctico.y o lexico.l y tenemos que compilar todo cada vez que hacemos un cambio, para no estar escribiendo los comandos cada vez que realizamos un cambio, crearemos un script, que al ejecutarlo realizara todos los comandos de compilación. Para eso creamos un nuevo archivo en blanco y escribimos #!/bin/bash bison -d sintactico.y flex lexico.l cc lex.yy.c sintactico.tab.c -o analizador -lfl –lm Guardamos este archivo con cualquier nombre, por ejemplo compilar.sh. Ahora cambiaremos las propiedades de este archivo para poder ejecutar. Le damos clic derecho sobre este archivo y en la pestaña permisos elegimos la opción de “Permitir ejecutar el archivo como un programa”, cerramos esa ventana. Para poder compilar, desde consola nos ubicamos donde se encuentra este archivo .sh y escribimos ./compilar.sh Esto nos genera nuestro ejecutable que podemos correr para poder probar nuestra calculadora. Para ejecutar este ejemplo usamos el comando
  • 12. ./analizador Ingresamos algunas expresiones y el resultado que obtenemos es: Ejemplo2: Ante la siguiente entrada a =12+2*cos(3.14) La salida debe ser: El valor del identificador a es 10.LABORATORIO DE PROCESADORES DE LENGUAJE CURSO2010- 11 Fichero léxico_solo.l % { /* Ejemplo para una pequeña calculadora que permite trabajar con numeros enteros y reales con las operaciones básicas de suma, resta, producto, division y trigonometricas como el seno y el coseno*/ #include <stdio.h> #include <stdlib.h> int nlines=0; %} DIGITO [0-9] ID [a-zA-Z][a-zA-Z0-9_]* %% {DIGITO}+ {printf("Encontrado TKN_NUM_ENTERO:%d",atoi(yytext));} {DIGITO}+"."{DIGITO}+ {printf("Encontrado TKN_NUM_REAL:%f",atof(yytext));} "=" {printf("Encontrado TKN_ASIGN: %s",yytext);} ";" {printf("Encontrado TKN_PTOCOMA: %s",yytext);} "*" {printf("Encontrado TKN_MULT: %s",yytext);} "/" {printf("Encontrado TKN_DIV: %s",yytext);} "+" {printf("Encontrado TKN_MAS: %s",yytext);} "-" {printf("Encontrado TKN_MENOS: %s",yytext);} "(" {printf("Encontrado TKN_PAA: %s",yytext);} ")" {printf("Encontrado TKN_PAC: %s",yytext);} "cos" {printf("Encontrado TKN_COS: %s",yytext);} "sen" {printf("Encontrado TKN_SEN:%s",yytext);} {ID} {printf("Encontrado TKN_ID: %s",yytext);} "n" {nlines++;} .LABORATORIO DE PROCESADORES DE LENGUAJE CURSO 2010-11 %% void main(int argc,char **argv) { if (argc>1)
  • 13. yyin=fopen(argv[1],"rt"); else yyin=stdin; yylex(); printf("nNumero lineas analizadas: %dn", nlines); } /* para compilar flex lexico.l cc lex.yy.c -o milex -lfl -lm */LABORATORIO DE PROCESADORES DE LENGUAJE CURSO 2010-11 Fichero léxico.l (versión a enlazar con Bison) %{ /* Ejemplo para una pequeña calculadora que permite trabajar con las operaciones básicas de suma, resta, producto, divisiony trigonometricas como el seno y el coseno */ #include <stdio.h> #include <stdlib.h> #include "sintactico.tab.h" int nlines=0; %} DIGITO [0-9] ID [a-zA-Z][a-zA-Z0-9_]* %% {DIGITO}+("."{DIGITO}+)? {//printf("Encontrado TKN_NUM: %fn",atof(yytext)); yylval.real=atof(yytext); return(TKN_NUM);} "=" {//printf("Encontrado TKN_ASIGN: %sn",yytext); return(TKN_ASIGN);} ";" {//printf("Encontrado TKN_PTOCOMA: %sn",yytext); return(TKN_PTOCOMA);} "*" {//printf("Encontrado TKN_MULT: %sn",yytext); return(TKN_MULT);} "/" {//printf("Encontrado TKN_DIV: %sn",yytext); return(TKN_DIV);} "+" {//printf("Encontrado TKN_MAS: %sn",yytext); return(TKN_MAS);} "-" {//printf("Encontrado TKN_MENOS: %sn",yytext);LABORATORIO DE PROCESADORES DELENGUAJE CURSO 2010-11 return(TKN_MENOS);} "(" {//printf("Encontrado TKN_PAA: %sn",yytext); return(TKN_PAA);} ")" {//printf("Encontrado TKN_PAC: %sn",yytext); return(TKN_PAC);} "cos" {//printf("Encontrado TKN_COS: %sn",yytext); return(TKN_COS);} "sen" {//printf("Encontrado TKN_SEN: %sn",yytext); return(TKN_SEN);} {ID} {//printf("Encontrado TKN_ID: %sn",yytext); return(TKN_ID);} "n" {nlines++;} . %% /******** Para el lexico solo void main(int argc,char **argv) { if (argc>1) yyin=fopen(argv[1],"rt"); else yyin=stdin; yylex(); printf("nNumero lineas analizadas: %dn", nlines); } *******/ /* para compilar flex lexico.l cc lex.yy.c -o milex -lfl -lm */LABORATORIO DE PROCESADORES DE LENGUAJE CURSO 2010-11 Fichero sintactico.y (Bison) %