Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
teaching:cc4101:tareas:2022-1:tarea1 [2022/04/06 16:28] – [Parte 2. Verificación estática de tipos (2.5 ptos.)] tdiaz | teaching:cc4101:tareas:2022-1:tarea1 [2022/04/19 18:54] (current) – etanter | ||
---|---|---|---|
Line 1: | Line 1: | ||
- | ====== Tarea 1 (Entrega: | + | ====== Tarea 1 (Entrega: |
==== Tipos estáticos y contratos ==== | ==== Tipos estáticos y contratos ==== | ||
Line 64: | Line 64: | ||
} | } | ||
{ ;; Programa de Ejemplo 3 | { ;; Programa de Ejemplo 3 | ||
- | | + | |
| | ||
{add2 {triple 2}} | {add2 {triple 2}} | ||
Line 111: | Line 111: | ||
</ | </ | ||
- | En el BNF utilizamos '' | + | En el BNF utilizamos '' |
Los programas siguientes están bien tipados: | Los programas siguientes están bien tipados: | ||
Line 151: | Line 151: | ||
En esta parte, deben definir una nueva función '' | En esta parte, deben definir una nueva función '' | ||
- | **Instrucciones**: | + | **Observaciones importantes**: |
* Recuerden que la gramática BNF dicta la estructura de sus definiciones | * Recuerden que la gramática BNF dicta la estructura de sus definiciones | ||
* La verificación de tipos de un programa consiste en verificar que todas las definiciones de función estén bien tipadas, y que la última expresión tiene un tipo (no importa cuál). | * La verificación de tipos de un programa consiste en verificar que todas las definiciones de función estén bien tipadas, y que la última expresión tiene un tipo (no importa cuál). | ||
Line 158: | Line 158: | ||
* Para '' | * Para '' | ||
* Para una expresión '' | * Para una expresión '' | ||
- | * Para '' | + | * Para '' |
* En la aplicación de función se valida que el número de argumentos coincide, y que el tipo de los argumentos coincide con los tipos esperados de la función aplicada. La aplicación en sí tiene el tipo de retorno de la función aplicada. | * En la aplicación de función se valida que el número de argumentos coincide, y que el tipo de los argumentos coincide con los tipos esperados de la función aplicada. La aplicación en sí tiene el tipo de retorno de la función aplicada. | ||
Line 191: | Line 191: | ||
Ahora vamos a añadir verificación dinámica mediante contratos a las funciones de nuestro lenguaje. El único cambio en la sintaxis del lenguaje se ve reflejado en la definición de funciones, donde ahora se puede definir además un contrato para cada argumento: | Ahora vamos a añadir verificación dinámica mediante contratos a las funciones de nuestro lenguaje. El único cambio en la sintaxis del lenguaje se ve reflejado en la definición de funciones, donde ahora se puede definir además un contrato para cada argumento: | ||
<code scheme> | <code scheme> | ||
- | < | + | < |
< | < | ||
| {<id> : < | | {<id> : < | ||
Line 207: | Line 207: | ||
En esta parte, su función '' | En esta parte, su función '' | ||
- | **Instrucciones**: | + | **Observaciones importantes**: |
* En el intérprete, | * En el intérprete, | ||
* Cuando el contrato no se cumpla, el patrón de error es: <code scheme> | * Cuando el contrato no se cumpla, el patrón de error es: <code scheme> | ||
" | " | ||
</ | </ | ||
- | * Una función usada como contrato *debe* aceptar un solo argumento de cualquier tipo válido y *debe* retornar un valor de tipo '' | + | * Una función usada como contrato |
" | " | ||
</ | </ |