Skip to content

Latest commit

 

History

History
76 lines (52 loc) · 4.01 KB

File metadata and controls

76 lines (52 loc) · 4.01 KB

Código Fuente

Incluya en esta carpeta todo el código fuente que es necesario para compilar y/o ejecutar su compilador desde cero.

No incluya archivos generados automáticamente, tales como binarios (e.g, .exe, .pyc), archivos auxiliares o archivos de logs, reportes, etc.

Compilando su proyecto

Si es necesario compilar su proyecto, incluya todas las instrucciones necesarias en el archivo /src/makefile que está en esta misma carpeta. Durante la evaluación su proyecto se compilará ejecutando la siguiente secuencia:

$ cd source
$ make clean
$ make

Ejecutando su proyecto

Incluya en el archivo /src/coolc.sh todas las instrucciones que hacen falta para lanzar su compilador. Recibirá como entrada un archivo con extensión .cl y debe generar como salida un archivo .mips cuyo nombre será el mismo que la entrada.

Para lanzar el compilador, se ejecutará la siguiente instrucción:

$ cd source
$ ./compile.sh <input_file.cl>

NOTA: Su proyecto será ejecutado y evaluado en un entorno Linux. Si usted desarrolló en un entorno diferente, asegúrese de que es posible ejecutar su proyecto en Linux. En el caso de .NET, vea las instrucciones para portar su proyecto a .NET Core (la versión Open Source) aquí y asegúrese de probar que funciona en Linux. NO es posible entregar su proyecto en forma de una solución que necesite abrirse con Visual Studio para funcionar.

Sobre el lenguaje COOL

Ud. podrá encontrar la especificación formal del lenguaje COOL en el documento COOL Language Reference Manual, que se distribuye junto con el presente texto.

Sobre el funcionamiento del compilador

El compilador de COOL se ejecutará como se ha definido anteriormente. En caso de que no ocurran errores durante la operación del compilador, coolc.sh deberá terminar con código de salida 0, generar (o sobrescribir si ya existe) en la misma carpeta del archivo .cl procesado, y con el mismo nombre que éste, un archivo con extension .mips que pueda ser ejecutado con spim. Además, reportar a la salida estándar solamente lo siguiente:

<línea_con_nombre_y_versión_del_compilador>
<línea_con_copyright_para_el_compilador>

En caso de que ocurran errores durante la operación del compilador, coolc.sh deberá terminar con código de salida (exit code) 1 y reportar a la salida estándar (standard output stream) lo que sigue...

<línea_con_nombre_y_versión_del_compilador>
<línea_con_copyright_para_el_compilador>
<línea_de_error>_1
...
<línea_de_error>_n

... donde <línea_de_error>_i tiene el siguiente formato:

(<línea>,<columna>) - <tipo_de_error>: <texto_del_error>

Los campos <línea> y <columna> indican la ubicación del error en el fichero .cl procesado. En caso de que la naturaleza del error sea tal que no pueda asociárselo a una línea y columna en el archivo de código fuente, el valor de dichos campos debe ser 0.

El campo <tipo_de_error> será alguno entre:

  • CompilerError: se reporta al detectar alguna anomalía con la entrada del compilador. Por ejemplo, si el fichero a compilar no existe.
  • LexicographicError: errores detectados por el lexer.
  • SyntacticError: errores detectados por el parser.
  • NameError: se reporta al referenciar un identificador en un ámbito en el que no es visible.
  • TypeError: se reporta al detectar un problema de tipos. Incluye:
    • incompatibilidad de tipos entre rvalue y lvalue,
    • operación no definida entre objetos de ciertos tipos, y
    • tipo referenciado pero no definido.
  • AttributeError: se reporta cuando un atributo o método se referencia pero no está definido.
  • SemanticError: cualquier otro error semántico.

Sobre la Implementación del Compilador de COOL

Para la implementación del compilador Ud. debe utilizar una herramienta generadora de analizadores lexicográficos y sintácticos. Puede utilizar la que sea de su preferencia.