SlideShare una empresa de Scribd logo
1 de 11
Descargar para leer sin conexión
INTRODUCCION A FLEX Y BISON
ACTIVIDAD SOBRE FLEX Y BISON

Herramientas para la construcción de procesadores de lenguaje.
Estas son algunas de las herramientas disponibles que pueden utilizarse para la construcción de los Procesadores
de Lenguajes. Todas estas herramientas funcionan bajo Windows, aunque se puede utilizar, si se desea, cualquier
otra herramienta.
Suelen usarse herramientas de desarrollo de software convencionales ( control de traza, puntos de ruptura,
depuradores, etc..). Sin embargo se pueden añadir a estas herramientas otras más especializadas que se han
denominado con diferentes nombres : compilador de compiladores, generadores de compiladores, sistemas de
escritura de traductores:
 Generadores de analizadores léxicos: basada en el uso de expresiones regulares, generan automáticamente el
código fuente para el análisis léxico a partir de una especificación de los tokens. El generador es un autómata
finito. La más usada es lex, incorporada en el sistema operativo UNÍX. Existen versiones para PC. 
 Generadores de analizadores sintácticos: Construyen el código fuente del analizador sintáctico a partir de la
especificación de la gramática del lenguaje fuente. La más usada yacc incluida en UNÍX. Tambien existen
versiones para PC. 

 Analizadores de gramáticas: dada una gramática especificada formalmente, verifican si es de un determinado
tipo o no. Normalmente se utilizan para verificar las gramáticas LL(k) y LR(k). 
 Máquinas de traducción dirigida por sintaxis: Producen un conjunto de rutinas que recorren el árbol sintáctico
y generan código intermedio. Asocian una o más traducciones a cada nodo sintáctico. 
 Generadores automáticos de código: Trabajan con un conjunto de reglas que permiten la traducción del código
en lenguaje intermedio al lenguaje objeto. Las reglas suelen remplazar instrucciones de código intermedio por
patrones que contienen las instrucciones equivalentes de la máquina objeto. 
 Analizadores de flujo: Suministran la información necesaria para realizar las optimizaciones de código. 

Aplicación de los lenguajes
Las técnicas empleadas en la construcción de traductores, compiladores e intérpretes pueden aplicarse en la
construcción de otras herramientas:
 Editores sensibles al contexto : Avisan al programador de posibles errores sintácticos cuando está escribiendo
un programa fuente. Actualmente es muy común editores con sintaxis resaltada con colores, 
 Conversores de formato: Utilizan las técnicas de los traductores para convertir una descripción de ficheros en
otra. 
 Preprocesadores: Toman como entrada un conjunto de instrucciones y generan código en un lenguaje de alto o
medio nivel. 
 Formateadores de código fuente: Toman como entrada un código fuente y obtienen a la salida el mismo
mostrado de manera que se pueda seguir la estructura del programa. 
 Generadores de código: Permiten desarrollar aplicaciones a partir de unas especificaciones muy compactas,
que pueden ser tratadas como un lenguaje de aplicación. Un caso particular son los generadores de pantallas. 
 Verificación estática de programas: Leen el código fuente y lo analizan para descubrir errores potenciales sin
ejecutar dicho programa. 
 Formateadores de texto: reciben como entrada un texto con indicaciones de cómo se desea la salida y generan
dicho texto formateado en un fichero, o para una determinada impresora. Pueden estar especializados para
fórmulas matemáticas, químicas, música, etc. 
 Intérpretes de comandos de un sistema operativo: reciben órdenes del sistema operativo, las analizan y las
ejecutan ( Ej.: COMMAND.COM de MS-DOS). 
 Construcción de entornos operativos: Caso particular del anterior en el cual las órdenes suelen recibirse de
forma gráfica ( Ej. WINDOWS). 
 Intérpretes para consultar base de datos: reciben las consultas, las analizan y las ejecutan (EJ.: SQL). 
 Compiladores de silicio: Utilizan las mismas técnicas de construcción de compiladores e intérpretes pero
implantadas en hardware. 
 Procesamiento de lenguajes naturales: Aplican las técnicas de construcción de traductores a los lenguajes
naturales, permitiendo el análisis comprensión y traducción. 
 Reconocimiento del habla: Se realiza un análisis de los sonidos para construir palabras 

Reseña Histórica

Diseño y construcción de un compilador.

Las herramientas Flex y Bison.
Estos nos ofrecen una gran cantidad de herramientas utilizando variables, operadores y librerías propias, como se
detallan algunas en la siguiente descripción.

Que es Flex y Bison
Flex y Bison, un generador de analizadores léxicos el primero y un generador de analizadores gramaticales el segundo,
son dos herramientas útiles para crear programas que reaccionen a una entrada de datos con una estructura y un
lenguaje predeterminado, como por ejemplo, podemos crear compiladores, interpretes y analizadores de linea de
comando.
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. Uno
de los usos principales de Flex es como acompañante del analizador de gramáticas Bison (o de Yacc).
Los analizadores Bison necesitan una función llamda ‘yylex()’ para devolverles el siguiente token de la entrada. Esa
función devuelve el tipo del próximo token y además puede poner cualquier valor asociado en la variable global
yylval. Para usar Flex con Bison, normalmente se especifica la opción –d de Bison para que genera el fichero
‘y.tab.h’ que contiene las definiciones de todos los ‘%tokens’ que aparecen el fuente Bison.

Como se instala Flex y Bison
Primero se descarga el archivo .rar .
Creamos una carpeta en C que se llame DJGPP y descomprimimos los archivos contenidos en DJGPP ahí.
Luego debemos crear una carpeta en la unidad C:que se llame PRUEBAS.
En esta carpeta cargaremos todos nuestros proyectos de Flex y Bison.
El siguiente paso es configurar las rutas de Flex y Bison, esto lo hacemos entrando al Cmd
Colocándonos en la carpeta de pruebas con los comandos
Cd
Cd pruebas
Y escribimos estos comandos
cd PRUEBAS
set djgpp=c:djgppdjgpp.env
set path=c:djgppbin
Con esto ya tendremos configurados Flex y Bison para que el Cmd los reconozca como comandos validos (cabe destacar
que esta acción se tiene que repetir cada vez que se abre una nueva instancia del Cmd).
Esto es la parte de configuración, ahora lo que se tiene que hacer es cargar los archivos léxicos y sintácticos creados
en el bloc de notas.
Por lo que se ejecutan los comandos Flex "nombre_de_archivo.l"
Y Bison -dy "nombre_de_archivo.y"
Se crean los archivos lexyy.c, y.tab.c, y.tab.h

Como se compila con Flex y Bison
Para compilar se realizan los siguientes pasos:
Escogemos una aplicación de consola y que sea un proyecto en c
Agregamos los archivos creados por el Flex y bison
Y compilamos
Se crea el ejecutable con el nombre del proyecto en este caso "pruebita.exe"
Y ejecutamos nuestro programa

2 Ejemplos de la creación de un compilador utilizando Flex y Bison.
IDENTIFICADOR
CALCULADORA

Más contenido relacionado

La actualidad más candente

La actualidad más candente (17)

Flex y bison
Flex y bisonFlex y bison
Flex y bison
 
Procedimiento Para Utilizar Flex Y Bison
Procedimiento Para Utilizar Flex Y Bison Procedimiento Para Utilizar Flex Y Bison
Procedimiento Para Utilizar Flex Y Bison
 
Trabajo compiladores ivan bolaños
Trabajo compiladores ivan bolañosTrabajo compiladores ivan bolaños
Trabajo compiladores ivan bolaños
 
Flex bison
Flex bisonFlex bison
Flex bison
 
Compiladores - Flex y Bison
Compiladores - Flex y BisonCompiladores - Flex y Bison
Compiladores - Flex y Bison
 
TALLER FLEX Y BISON
TALLER FLEX Y BISONTALLER FLEX Y BISON
TALLER FLEX Y BISON
 
Flexybison
FlexybisonFlexybison
Flexybison
 
INTRODUCCION A FLEX Y BISON
INTRODUCCION A FLEX Y BISONINTRODUCCION A FLEX Y BISON
INTRODUCCION A FLEX Y BISON
 
Clase 03
Clase 03Clase 03
Clase 03
 
Clase 01
Clase 01Clase 01
Clase 01
 
Flex ybison
Flex ybisonFlex ybison
Flex ybison
 
Usando flex en Windows
Usando flex en WindowsUsando flex en Windows
Usando flex en Windows
 
Flex y bison
Flex y bisonFlex y bison
Flex y bison
 
COMPILADORES
COMPILADORESCOMPILADORES
COMPILADORES
 
Taller compiladores conceptos
Taller compiladores conceptosTaller compiladores conceptos
Taller compiladores conceptos
 
Flex y bison
Flex y bisonFlex y bison
Flex y bison
 
C:\fakepath\el software libre
C:\fakepath\el software libreC:\fakepath\el software libre
C:\fakepath\el software libre
 

Destacado (9)

Flex y bison
Flex y bisonFlex y bison
Flex y bison
 
Capacidad, localización y distribución en planta
Capacidad, localización y distribución en plantaCapacidad, localización y distribución en planta
Capacidad, localización y distribución en planta
 
Localización de almacenes
Localización de almacenesLocalización de almacenes
Localización de almacenes
 
Métodos de localización de instalaciones de producción y servicios
Métodos de localización de instalaciones de producción y serviciosMétodos de localización de instalaciones de producción y servicios
Métodos de localización de instalaciones de producción y servicios
 
4 distribucion en planta
4 distribucion en planta4 distribucion en planta
4 distribucion en planta
 
Distribución de planta.
Distribución de planta.Distribución de planta.
Distribución de planta.
 
Localización y distribución de plantas
Localización y distribución de plantas  Localización y distribución de plantas
Localización y distribución de plantas
 
distribución de equipo en la planta
distribución de equipo en la plantadistribución de equipo en la planta
distribución de equipo en la planta
 
guia de Interpretación De Estados Financieros
guia  de Interpretación  De Estados Financierosguia  de Interpretación  De Estados Financieros
guia de Interpretación De Estados Financieros
 

Similar a Trabajo flex byson

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
 
Conceptos De Compilador
Conceptos De CompiladorConceptos De Compilador
Conceptos De CompiladorJoel Soto
 
Conceptos de compilador
Conceptos de compiladorConceptos de compilador
Conceptos de compiladorJoel Soto
 
Grupo 1 proceso de lenguajes i
Grupo 1 proceso de lenguajes iGrupo 1 proceso de lenguajes i
Grupo 1 proceso de lenguajes iRossana Sosa
 
Traductores de lenguajes de programación
Traductores de lenguajes de programaciónTraductores de lenguajes de programación
Traductores de lenguajes de programaciónDaniela Brignolo
 
C:\fakepath\el software libre
C:\fakepath\el software libreC:\fakepath\el software libre
C:\fakepath\el software libreDanielita Lopez
 
C:\fakepath\el software libre
C:\fakepath\el software libreC:\fakepath\el software libre
C:\fakepath\el software libreDanielita Lopez
 
C:\fakepath\el software libre
C:\fakepath\el software libreC:\fakepath\el software libre
C:\fakepath\el software libreDLACGP
 
C:\fakepath\compilador
C:\fakepath\compiladorC:\fakepath\compilador
C:\fakepath\compiladorDLACGP
 
C:\fakepath\el software libre
C:\fakepath\el software libreC:\fakepath\el software libre
C:\fakepath\el software libreDanielita Lopez
 
C:\fakepath\compiladores
C:\fakepath\compiladoresC:\fakepath\compiladores
C:\fakepath\compiladorespaulina8
 
C:\documents and settings\clientea\mis documentos\compiladores
C:\documents and settings\clientea\mis documentos\compiladoresC:\documents and settings\clientea\mis documentos\compiladores
C:\documents and settings\clientea\mis documentos\compiladoresNancyandRegina317
 
Flex y bison héctor espinosa
Flex y bison   héctor espinosaFlex y bison   héctor espinosa
Flex y bison héctor espinosaHector Espinosa
 
Compilador Funcionamiento
Compilador FuncionamientoCompilador Funcionamiento
Compilador FuncionamientoKriz Kozlov
 
Materia unidad compiladores
Materia unidad compiladoresMateria unidad compiladores
Materia unidad compiladoresbachispasaca
 

Similar a Trabajo flex byson (20)

Bison y flex
Bison y flexBison y flex
Bison y flex
 
Flex y Bison
Flex y BisonFlex y Bison
Flex y Bison
 
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
 
Conceptos De Compilador
Conceptos De CompiladorConceptos De Compilador
Conceptos De Compilador
 
Conceptos de compilador
Conceptos de compiladorConceptos de compilador
Conceptos de compilador
 
Grupo 1 proceso de lenguajes i
Grupo 1 proceso de lenguajes iGrupo 1 proceso de lenguajes i
Grupo 1 proceso de lenguajes i
 
Traductores de lenguajes de programación
Traductores de lenguajes de programaciónTraductores de lenguajes de programación
Traductores de lenguajes de programación
 
H:\compiladores
H:\compiladoresH:\compiladores
H:\compiladores
 
C:\fakepath\el software libre
C:\fakepath\el software libreC:\fakepath\el software libre
C:\fakepath\el software libre
 
C:\fakepath\el software libre
C:\fakepath\el software libreC:\fakepath\el software libre
C:\fakepath\el software libre
 
C:\fakepath\el software libre
C:\fakepath\el software libreC:\fakepath\el software libre
C:\fakepath\el software libre
 
C:\fakepath\compilador
C:\fakepath\compiladorC:\fakepath\compilador
C:\fakepath\compilador
 
C:\fakepath\el software libre
C:\fakepath\el software libreC:\fakepath\el software libre
C:\fakepath\el software libre
 
C:\fakepath\compiladores
C:\fakepath\compiladoresC:\fakepath\compiladores
C:\fakepath\compiladores
 
Resumencap1 carmen vargas_jeremycamacho
Resumencap1 carmen vargas_jeremycamachoResumencap1 carmen vargas_jeremycamacho
Resumencap1 carmen vargas_jeremycamacho
 
C:\documents and settings\clientea\mis documentos\compiladores
C:\documents and settings\clientea\mis documentos\compiladoresC:\documents and settings\clientea\mis documentos\compiladores
C:\documents and settings\clientea\mis documentos\compiladores
 
Flex y bison héctor espinosa
Flex y bison   héctor espinosaFlex y bison   héctor espinosa
Flex y bison héctor espinosa
 
Compilador Funcionamiento
Compilador FuncionamientoCompilador Funcionamiento
Compilador Funcionamiento
 
Compiladores
CompiladoresCompiladores
Compiladores
 
Materia unidad compiladores
Materia unidad compiladoresMateria unidad compiladores
Materia unidad compiladores
 

Más de Jhon Alexito

Más de Jhon Alexito (12)

Web host ntp
Web host ntpWeb host ntp
Web host ntp
 
Historia de usuario proyecto ntp
Historia de usuario proyecto ntpHistoria de usuario proyecto ntp
Historia de usuario proyecto ntp
 
Análisis sintáctico ascendente descendente
Análisis sintáctico ascendente   descendenteAnálisis sintáctico ascendente   descendente
Análisis sintáctico ascendente descendente
 
Python compiladores
Python compiladoresPython compiladores
Python compiladores
 
Emulador de ensamblador EMU8086
Emulador de ensamblador EMU8086Emulador de ensamblador EMU8086
Emulador de ensamblador EMU8086
 
Decompiladores
DecompiladoresDecompiladores
Decompiladores
 
Mapa compiladores
Mapa compiladoresMapa compiladores
Mapa compiladores
 
Doc1
Doc1Doc1
Doc1
 
Doc1
Doc1Doc1
Doc1
 
Doc1
Doc1Doc1
Doc1
 
Doc1
Doc1Doc1
Doc1
 
INTRODUCCIÓN COMPILADORES
INTRODUCCIÓN COMPILADORESINTRODUCCIÓN COMPILADORES
INTRODUCCIÓN COMPILADORES
 

Último

Heinsohn Privacidad y Ciberseguridad para el sector educativo
Heinsohn Privacidad y Ciberseguridad para el sector educativoHeinsohn Privacidad y Ciberseguridad para el sector educativo
Heinsohn Privacidad y Ciberseguridad para el sector educativoFundación YOD YOD
 
Neurociencias para Educadores NE24 Ccesa007.pdf
Neurociencias para Educadores  NE24  Ccesa007.pdfNeurociencias para Educadores  NE24  Ccesa007.pdf
Neurociencias para Educadores NE24 Ccesa007.pdfDemetrio Ccesa Rayme
 
ACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptx
ACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptxACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptx
ACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptxzulyvero07
 
Manual - ABAS II completo 263 hojas .pdf
Manual - ABAS II completo 263 hojas .pdfManual - ABAS II completo 263 hojas .pdf
Manual - ABAS II completo 263 hojas .pdfMaryRotonda1
 
cortes de luz abril 2024 en la provincia de tungurahua
cortes de luz abril 2024 en la provincia de tungurahuacortes de luz abril 2024 en la provincia de tungurahua
cortes de luz abril 2024 en la provincia de tungurahuaDANNYISAACCARVAJALGA
 
PRIMER SEMESTRE 2024 ASAMBLEA DEPARTAMENTAL.pptx
PRIMER SEMESTRE 2024 ASAMBLEA DEPARTAMENTAL.pptxPRIMER SEMESTRE 2024 ASAMBLEA DEPARTAMENTAL.pptx
PRIMER SEMESTRE 2024 ASAMBLEA DEPARTAMENTAL.pptxinformacionasapespu
 
La Función tecnológica del tutor.pptx
La  Función  tecnológica  del tutor.pptxLa  Función  tecnológica  del tutor.pptx
La Función tecnológica del tutor.pptxJunkotantik
 
Lecciones 04 Esc. Sabática. Defendamos la verdad
Lecciones 04 Esc. Sabática. Defendamos la verdadLecciones 04 Esc. Sabática. Defendamos la verdad
Lecciones 04 Esc. Sabática. Defendamos la verdadAlejandrino Halire Ccahuana
 
30-de-abril-plebiscito-1902_240420_104511.pdf
30-de-abril-plebiscito-1902_240420_104511.pdf30-de-abril-plebiscito-1902_240420_104511.pdf
30-de-abril-plebiscito-1902_240420_104511.pdfgimenanahuel
 
EXPECTATIVAS vs PERSPECTIVA en la vida.
EXPECTATIVAS vs PERSPECTIVA  en la vida.EXPECTATIVAS vs PERSPECTIVA  en la vida.
EXPECTATIVAS vs PERSPECTIVA en la vida.DaluiMonasterio
 
GLOSAS Y PALABRAS ACTO 2 DE ABRIL 2024.docx
GLOSAS  Y PALABRAS ACTO 2 DE ABRIL 2024.docxGLOSAS  Y PALABRAS ACTO 2 DE ABRIL 2024.docx
GLOSAS Y PALABRAS ACTO 2 DE ABRIL 2024.docxAleParedes11
 
DE LAS OLIMPIADAS GRIEGAS A LAS DEL MUNDO MODERNO.ppt
DE LAS OLIMPIADAS GRIEGAS A LAS DEL MUNDO MODERNO.pptDE LAS OLIMPIADAS GRIEGAS A LAS DEL MUNDO MODERNO.ppt
DE LAS OLIMPIADAS GRIEGAS A LAS DEL MUNDO MODERNO.pptELENA GALLARDO PAÚLS
 
Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...
Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...
Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...Carlos Muñoz
 
Identificación de componentes Hardware del PC
Identificación de componentes Hardware del PCIdentificación de componentes Hardware del PC
Identificación de componentes Hardware del PCCesarFernandez937857
 
texto argumentativo, ejemplos y ejercicios prácticos
texto argumentativo, ejemplos y ejercicios prácticostexto argumentativo, ejemplos y ejercicios prácticos
texto argumentativo, ejemplos y ejercicios prácticosisabeltrejoros
 
Planificacion Anual 4to Grado Educacion Primaria 2024 Ccesa007.pdf
Planificacion Anual 4to Grado Educacion Primaria   2024   Ccesa007.pdfPlanificacion Anual 4to Grado Educacion Primaria   2024   Ccesa007.pdf
Planificacion Anual 4to Grado Educacion Primaria 2024 Ccesa007.pdfDemetrio Ccesa Rayme
 
programa dia de las madres 10 de mayo para evento
programa dia de las madres 10 de mayo  para eventoprograma dia de las madres 10 de mayo  para evento
programa dia de las madres 10 de mayo para eventoDiegoMtsS
 
SINTAXIS DE LA ORACIÓN SIMPLE 2023-2024.pptx
SINTAXIS DE LA ORACIÓN SIMPLE 2023-2024.pptxSINTAXIS DE LA ORACIÓN SIMPLE 2023-2024.pptx
SINTAXIS DE LA ORACIÓN SIMPLE 2023-2024.pptxlclcarmen
 
codigos HTML para blogs y paginas web Karina
codigos HTML para blogs y paginas web Karinacodigos HTML para blogs y paginas web Karina
codigos HTML para blogs y paginas web Karinavergarakarina022
 

Último (20)

Heinsohn Privacidad y Ciberseguridad para el sector educativo
Heinsohn Privacidad y Ciberseguridad para el sector educativoHeinsohn Privacidad y Ciberseguridad para el sector educativo
Heinsohn Privacidad y Ciberseguridad para el sector educativo
 
Neurociencias para Educadores NE24 Ccesa007.pdf
Neurociencias para Educadores  NE24  Ccesa007.pdfNeurociencias para Educadores  NE24  Ccesa007.pdf
Neurociencias para Educadores NE24 Ccesa007.pdf
 
ACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptx
ACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptxACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptx
ACUERDO MINISTERIAL 078-ORGANISMOS ESCOLARES..pptx
 
Manual - ABAS II completo 263 hojas .pdf
Manual - ABAS II completo 263 hojas .pdfManual - ABAS II completo 263 hojas .pdf
Manual - ABAS II completo 263 hojas .pdf
 
cortes de luz abril 2024 en la provincia de tungurahua
cortes de luz abril 2024 en la provincia de tungurahuacortes de luz abril 2024 en la provincia de tungurahua
cortes de luz abril 2024 en la provincia de tungurahua
 
PRIMER SEMESTRE 2024 ASAMBLEA DEPARTAMENTAL.pptx
PRIMER SEMESTRE 2024 ASAMBLEA DEPARTAMENTAL.pptxPRIMER SEMESTRE 2024 ASAMBLEA DEPARTAMENTAL.pptx
PRIMER SEMESTRE 2024 ASAMBLEA DEPARTAMENTAL.pptx
 
La Función tecnológica del tutor.pptx
La  Función  tecnológica  del tutor.pptxLa  Función  tecnológica  del tutor.pptx
La Función tecnológica del tutor.pptx
 
Lecciones 04 Esc. Sabática. Defendamos la verdad
Lecciones 04 Esc. Sabática. Defendamos la verdadLecciones 04 Esc. Sabática. Defendamos la verdad
Lecciones 04 Esc. Sabática. Defendamos la verdad
 
30-de-abril-plebiscito-1902_240420_104511.pdf
30-de-abril-plebiscito-1902_240420_104511.pdf30-de-abril-plebiscito-1902_240420_104511.pdf
30-de-abril-plebiscito-1902_240420_104511.pdf
 
La Trampa De La Felicidad. Russ-Harris.pdf
La Trampa De La Felicidad. Russ-Harris.pdfLa Trampa De La Felicidad. Russ-Harris.pdf
La Trampa De La Felicidad. Russ-Harris.pdf
 
EXPECTATIVAS vs PERSPECTIVA en la vida.
EXPECTATIVAS vs PERSPECTIVA  en la vida.EXPECTATIVAS vs PERSPECTIVA  en la vida.
EXPECTATIVAS vs PERSPECTIVA en la vida.
 
GLOSAS Y PALABRAS ACTO 2 DE ABRIL 2024.docx
GLOSAS  Y PALABRAS ACTO 2 DE ABRIL 2024.docxGLOSAS  Y PALABRAS ACTO 2 DE ABRIL 2024.docx
GLOSAS Y PALABRAS ACTO 2 DE ABRIL 2024.docx
 
DE LAS OLIMPIADAS GRIEGAS A LAS DEL MUNDO MODERNO.ppt
DE LAS OLIMPIADAS GRIEGAS A LAS DEL MUNDO MODERNO.pptDE LAS OLIMPIADAS GRIEGAS A LAS DEL MUNDO MODERNO.ppt
DE LAS OLIMPIADAS GRIEGAS A LAS DEL MUNDO MODERNO.ppt
 
Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...
Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...
Plan Refuerzo Escolar 2024 para estudiantes con necesidades de Aprendizaje en...
 
Identificación de componentes Hardware del PC
Identificación de componentes Hardware del PCIdentificación de componentes Hardware del PC
Identificación de componentes Hardware del PC
 
texto argumentativo, ejemplos y ejercicios prácticos
texto argumentativo, ejemplos y ejercicios prácticostexto argumentativo, ejemplos y ejercicios prácticos
texto argumentativo, ejemplos y ejercicios prácticos
 
Planificacion Anual 4to Grado Educacion Primaria 2024 Ccesa007.pdf
Planificacion Anual 4to Grado Educacion Primaria   2024   Ccesa007.pdfPlanificacion Anual 4to Grado Educacion Primaria   2024   Ccesa007.pdf
Planificacion Anual 4to Grado Educacion Primaria 2024 Ccesa007.pdf
 
programa dia de las madres 10 de mayo para evento
programa dia de las madres 10 de mayo  para eventoprograma dia de las madres 10 de mayo  para evento
programa dia de las madres 10 de mayo para evento
 
SINTAXIS DE LA ORACIÓN SIMPLE 2023-2024.pptx
SINTAXIS DE LA ORACIÓN SIMPLE 2023-2024.pptxSINTAXIS DE LA ORACIÓN SIMPLE 2023-2024.pptx
SINTAXIS DE LA ORACIÓN SIMPLE 2023-2024.pptx
 
codigos HTML para blogs y paginas web Karina
codigos HTML para blogs y paginas web Karinacodigos HTML para blogs y paginas web Karina
codigos HTML para blogs y paginas web Karina
 

Trabajo flex byson

  • 1. INTRODUCCION A FLEX Y BISON ACTIVIDAD SOBRE FLEX Y BISON  Herramientas para la construcción de procesadores de lenguaje. Estas son algunas de las herramientas disponibles que pueden utilizarse para la construcción de los Procesadores de Lenguajes. Todas estas herramientas funcionan bajo Windows, aunque se puede utilizar, si se desea, cualquier otra herramienta. Suelen usarse herramientas de desarrollo de software convencionales ( control de traza, puntos de ruptura, depuradores, etc..). Sin embargo se pueden añadir a estas herramientas otras más especializadas que se han denominado con diferentes nombres : compilador de compiladores, generadores de compiladores, sistemas de escritura de traductores:  Generadores de analizadores léxicos: basada en el uso de expresiones regulares, generan automáticamente el código fuente para el análisis léxico a partir de una especificación de los tokens. El generador es un autómata finito. La más usada es lex, incorporada en el sistema operativo UNÍX. Existen versiones para PC.   Generadores de analizadores sintácticos: Construyen el código fuente del analizador sintáctico a partir de la especificación de la gramática del lenguaje fuente. La más usada yacc incluida en UNÍX. Tambien existen versiones para PC.    Analizadores de gramáticas: dada una gramática especificada formalmente, verifican si es de un determinado tipo o no. Normalmente se utilizan para verificar las gramáticas LL(k) y LR(k).   Máquinas de traducción dirigida por sintaxis: Producen un conjunto de rutinas que recorren el árbol sintáctico y generan código intermedio. Asocian una o más traducciones a cada nodo sintáctico.   Generadores automáticos de código: Trabajan con un conjunto de reglas que permiten la traducción del código en lenguaje intermedio al lenguaje objeto. Las reglas suelen remplazar instrucciones de código intermedio por patrones que contienen las instrucciones equivalentes de la máquina objeto.   Analizadores de flujo: Suministran la información necesaria para realizar las optimizaciones de código. 
  • 2.  Aplicación de los lenguajes Las técnicas empleadas en la construcción de traductores, compiladores e intérpretes pueden aplicarse en la construcción de otras herramientas:  Editores sensibles al contexto : Avisan al programador de posibles errores sintácticos cuando está escribiendo un programa fuente. Actualmente es muy común editores con sintaxis resaltada con colores,   Conversores de formato: Utilizan las técnicas de los traductores para convertir una descripción de ficheros en otra.   Preprocesadores: Toman como entrada un conjunto de instrucciones y generan código en un lenguaje de alto o medio nivel.   Formateadores de código fuente: Toman como entrada un código fuente y obtienen a la salida el mismo mostrado de manera que se pueda seguir la estructura del programa.   Generadores de código: Permiten desarrollar aplicaciones a partir de unas especificaciones muy compactas, que pueden ser tratadas como un lenguaje de aplicación. Un caso particular son los generadores de pantallas.   Verificación estática de programas: Leen el código fuente y lo analizan para descubrir errores potenciales sin ejecutar dicho programa.   Formateadores de texto: reciben como entrada un texto con indicaciones de cómo se desea la salida y generan dicho texto formateado en un fichero, o para una determinada impresora. Pueden estar especializados para fórmulas matemáticas, químicas, música, etc.   Intérpretes de comandos de un sistema operativo: reciben órdenes del sistema operativo, las analizan y las ejecutan ( Ej.: COMMAND.COM de MS-DOS).   Construcción de entornos operativos: Caso particular del anterior en el cual las órdenes suelen recibirse de forma gráfica ( Ej. WINDOWS).   Intérpretes para consultar base de datos: reciben las consultas, las analizan y las ejecutan (EJ.: SQL).   Compiladores de silicio: Utilizan las mismas técnicas de construcción de compiladores e intérpretes pero implantadas en hardware.   Procesamiento de lenguajes naturales: Aplican las técnicas de construcción de traductores a los lenguajes naturales, permitiendo el análisis comprensión y traducción.   Reconocimiento del habla: Se realiza un análisis de los sonidos para construir palabras   Reseña Histórica
  • 3.
  • 4.  Diseño y construcción de un compilador.
  • 5.  Las herramientas Flex y Bison. Estos nos ofrecen una gran cantidad de herramientas utilizando variables, operadores y librerías propias, como se detallan algunas en la siguiente descripción.
  • 6.
  • 7.  Que es Flex y Bison Flex y Bison, un generador de analizadores léxicos el primero y un generador de analizadores gramaticales el segundo, son dos herramientas útiles para crear programas que reaccionen a una entrada de datos con una estructura y un lenguaje predeterminado, como por ejemplo, podemos crear compiladores, interpretes y analizadores de linea de comando. 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. Uno de los usos principales de Flex es como acompañante del analizador de gramáticas Bison (o de Yacc). Los analizadores Bison necesitan una función llamda ‘yylex()’ para devolverles el siguiente token de la entrada. Esa función devuelve el tipo del próximo token y además puede poner cualquier valor asociado en la variable global yylval. Para usar Flex con Bison, normalmente se especifica la opción –d de Bison para que genera el fichero ‘y.tab.h’ que contiene las definiciones de todos los ‘%tokens’ que aparecen el fuente Bison.
  • 8.  Como se instala Flex y Bison Primero se descarga el archivo .rar . Creamos una carpeta en C que se llame DJGPP y descomprimimos los archivos contenidos en DJGPP ahí. Luego debemos crear una carpeta en la unidad C:que se llame PRUEBAS. En esta carpeta cargaremos todos nuestros proyectos de Flex y Bison. El siguiente paso es configurar las rutas de Flex y Bison, esto lo hacemos entrando al Cmd Colocándonos en la carpeta de pruebas con los comandos Cd Cd pruebas Y escribimos estos comandos cd PRUEBAS set djgpp=c:djgppdjgpp.env set path=c:djgppbin
  • 9. Con esto ya tendremos configurados Flex y Bison para que el Cmd los reconozca como comandos validos (cabe destacar que esta acción se tiene que repetir cada vez que se abre una nueva instancia del Cmd). Esto es la parte de configuración, ahora lo que se tiene que hacer es cargar los archivos léxicos y sintácticos creados en el bloc de notas. Por lo que se ejecutan los comandos Flex "nombre_de_archivo.l" Y Bison -dy "nombre_de_archivo.y" Se crean los archivos lexyy.c, y.tab.c, y.tab.h
  • 10.  Como se compila con Flex y Bison Para compilar se realizan los siguientes pasos: Escogemos una aplicación de consola y que sea un proyecto en c Agregamos los archivos creados por el Flex y bison Y compilamos Se crea el ejecutable con el nombre del proyecto en este caso "pruebita.exe"
  • 11. Y ejecutamos nuestro programa  2 Ejemplos de la creación de un compilador utilizando Flex y Bison. IDENTIFICADOR CALCULADORA