SlideShare una empresa de Scribd logo
1 de 13
Descargar para leer sin conexión
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

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 GuionesUVM
 
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 LenguajesGrace Laguna
 
Manejo de archivosss
Manejo de archivosssManejo de archivosss
Manejo de archivossstaniarodri
 
Trabajo compiladores ivan bolaños
Trabajo compiladores ivan bolañosTrabajo compiladores ivan bolaños
Trabajo compiladores ivan bolañosIván Bolaños
 
Programacinenshell linux
Programacinenshell linuxProgramacinenshell linux
Programacinenshell linuxusupr2014
 
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 resueltavictdiazm
 
D o s trabajo jueves
D o s trabajo juevesD o s trabajo jueves
D o s trabajo jueveschrifer123
 

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

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 complejosGabriel 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 huffmanGabriel 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íaGabriel 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 entropiaGabriel 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 vegasGabriel 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 virtualizacionGabriel 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 neguentropiaGabriel 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 segmentacionGabriel 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 sistemasGabriel 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ógicosGabriel 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 ejerciciosGabriel 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 realzadoGabriel 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 imagenesGabriel 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 decisionesGabriel 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 juegosGabriel 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 2Gabriel 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 autonomoGabriel 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 matlabGabriel 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 matlabGabriel 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
 

Último

BREEAM ES Urbanismo como herramienta para un planeamiento sostenible - Miguel...
BREEAM ES Urbanismo como herramienta para un planeamiento sostenible - Miguel...BREEAM ES Urbanismo como herramienta para un planeamiento sostenible - Miguel...
BREEAM ES Urbanismo como herramienta para un planeamiento sostenible - Miguel...ITeC Instituto Tecnología Construcción
 
Introducción a Funciones LENGUAJE DART FLUTTER
Introducción a Funciones LENGUAJE DART FLUTTERIntroducción a Funciones LENGUAJE DART FLUTTER
Introducción a Funciones LENGUAJE DART FLUTTEREMMAFLORESCARMONA
 
Caso de éxito de Hervian con el ERP Sage 200
Caso de éxito de Hervian con el ERP Sage 200Caso de éxito de Hervian con el ERP Sage 200
Caso de éxito de Hervian con el ERP Sage 200Opentix
 
Manual de Usuario APPs_AppInventor-2023.pdf
Manual de Usuario APPs_AppInventor-2023.pdfManual de Usuario APPs_AppInventor-2023.pdf
Manual de Usuario APPs_AppInventor-2023.pdfmasogeis
 
Unidad_3_T1_AutomatasFinitos presentacion
Unidad_3_T1_AutomatasFinitos presentacionUnidad_3_T1_AutomatasFinitos presentacion
Unidad_3_T1_AutomatasFinitos presentacionarmando_cardenas
 
Segmentacion Segmantica_Modelos UNET and DEEPLABV3
Segmentacion Segmantica_Modelos UNET and DEEPLABV3Segmentacion Segmantica_Modelos UNET and DEEPLABV3
Segmentacion Segmantica_Modelos UNET and DEEPLABV3AlexysCaytanoMelndez1
 
PARTES DEL TECLADO Y SUS FUNCIONES - EJEMPLO
PARTES DEL TECLADO Y SUS FUNCIONES - EJEMPLOPARTES DEL TECLADO Y SUS FUNCIONES - EJEMPLO
PARTES DEL TECLADO Y SUS FUNCIONES - EJEMPLOSelenaCoronadoHuaman
 

Último (7)

BREEAM ES Urbanismo como herramienta para un planeamiento sostenible - Miguel...
BREEAM ES Urbanismo como herramienta para un planeamiento sostenible - Miguel...BREEAM ES Urbanismo como herramienta para un planeamiento sostenible - Miguel...
BREEAM ES Urbanismo como herramienta para un planeamiento sostenible - Miguel...
 
Introducción a Funciones LENGUAJE DART FLUTTER
Introducción a Funciones LENGUAJE DART FLUTTERIntroducción a Funciones LENGUAJE DART FLUTTER
Introducción a Funciones LENGUAJE DART FLUTTER
 
Caso de éxito de Hervian con el ERP Sage 200
Caso de éxito de Hervian con el ERP Sage 200Caso de éxito de Hervian con el ERP Sage 200
Caso de éxito de Hervian con el ERP Sage 200
 
Manual de Usuario APPs_AppInventor-2023.pdf
Manual de Usuario APPs_AppInventor-2023.pdfManual de Usuario APPs_AppInventor-2023.pdf
Manual de Usuario APPs_AppInventor-2023.pdf
 
Unidad_3_T1_AutomatasFinitos presentacion
Unidad_3_T1_AutomatasFinitos presentacionUnidad_3_T1_AutomatasFinitos presentacion
Unidad_3_T1_AutomatasFinitos presentacion
 
Segmentacion Segmantica_Modelos UNET and DEEPLABV3
Segmentacion Segmantica_Modelos UNET and DEEPLABV3Segmentacion Segmantica_Modelos UNET and DEEPLABV3
Segmentacion Segmantica_Modelos UNET and DEEPLABV3
 
PARTES DEL TECLADO Y SUS FUNCIONES - EJEMPLO
PARTES DEL TECLADO Y SUS FUNCIONES - EJEMPLOPARTES DEL TECLADO Y SUS FUNCIONES - EJEMPLO
PARTES DEL TECLADO Y SUS FUNCIONES - EJEMPLO
 

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) %