feat(charka): nivel 88 + modelo de datos compartido en charka-ir
Los nombres de condición de COBOL (IF ES-VALIDO), que antes el transpilador evaluaba siempre como false. Y, de paso, se elimina la duplicación de la resolución del modelo de datos. - charka-ir gana un módulo `model`: resolve_data(&[DataItem]) -> DataModel aplana el árbol de datos a campos elementales (Field con FieldKind) y a nombres de condición (ConditionName). El Ir lleva ahora un campo `model` — la fuente única de verdad sobre la clasificación de PICTURE. - charka-codegen y charka-shadow consumen ir.model en vez de reimplementar cada uno la clasificación, el ancho de PICTURE y la normalización de VALUE. charka-codegen ya no depende de charka-bcd. - Cond::Named (un nivel 88) se resuelve a `padre = valor`: el codegen emite la comparación, el intérprete sombra la evalúa. - Corregido: un dato con hijos de nivel 88 antes se perdía como si fuera un grupo; ahora se reconoce como campo elemental. - Corpus: programa nuevo 10-condicion (semáforo con 88 de texto y de número). Verificado: intérprete y crate compilado dan igual salida. Tests: charka-ir 23, charka-codegen 17, charka-shadow 15. fmt + clippy limpios. Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
This commit is contained in:
@@ -3,6 +3,30 @@
|
||||
Transpilador COBOL → Rust. El módulo más grande del ecosistema (Fase D
|
||||
del plan macro) — el parser COBOL completo es un esfuerzo multi-mes.
|
||||
|
||||
### feat(charka): nombres de condición (nivel 88) + modelo de datos compartido
|
||||
|
||||
`IF ES-VALIDO` — los nombres de condición de COBOL, que antes el
|
||||
transpilador evaluaba siempre como `false`. Y, de paso, se elimina una
|
||||
duplicación: la resolución del modelo de datos.
|
||||
|
||||
- `charka-ir` gana un módulo `model`: `resolve_data(&[DataItem]) ->
|
||||
DataModel` aplana el árbol de datos a campos elementales (`Field` con
|
||||
`FieldKind`) y a nombres de condición (`ConditionName`). El `Ir`
|
||||
ahora lleva un campo `model`. Es la fuente única de verdad sobre la
|
||||
clasificación de PICTURE.
|
||||
- `charka-codegen` y `charka-shadow` consumen `ir.model` en vez de
|
||||
reimplementar cada uno la clasificación numérico/alfanumérico, el
|
||||
ancho de PICTURE y la normalización de `VALUE`. `charka-codegen` ya
|
||||
no depende de `charka-bcd`.
|
||||
- `Cond::Named` (un nivel 88) se resuelve a `padre = valor`: el codegen
|
||||
emite la comparación, el intérprete sombra la evalúa.
|
||||
- Corregido de paso: un dato con hijos de nivel 88 (p. ej.
|
||||
`01 WS-FLAG PIC X. 88 ES-SI VALUE 'Y'.`) antes se perdía como si
|
||||
fuera un grupo; ahora se reconoce como campo elemental.
|
||||
- Corpus: programa nuevo `10-condicion` (un semáforo con 88 de texto y
|
||||
de número, en `IF` e `IF/ELSE`). Verificado: intérprete y crate
|
||||
compilado dan la misma salida.
|
||||
|
||||
### feat(charka): EVALUATE — el case de COBOL
|
||||
|
||||
`EVALUATE` atraviesa el pipeline entero — antes el parser lo guardaba
|
||||
|
||||
Reference in New Issue
Block a user