MODULE Test;
+TYPE
+ R1 = RECORD END;
+(* R2 = RECORD (R1) END; *)
+ R3 = RECORD END;
+
VAR
- a : POINTER TO RECORD END;
- b : POINTER TO ARRAY OF INTEGER;
- c : PROCEDURE;
+(*
+ a : R1;
+ b : R2;
+*)
+ c : R3;
BEGIN
- a := NIL;
- b := NIL;
- c := NIL;
+(* a := b; *)
END Test.
+- Уточнить как должна работать проверка импорта на чтение. (8.1)
+
- Нет модуля SYSTEM
- Нет функций ASH CAP CHR ENTIER LEN LONG ODD ORD SHORT
- Нет процедур ASSERT COPY DEC EXCL HALT INC INCL
- Не реализована свёртка констант
- Нужно пробежаться по стандарту и всё перепроверить.
+- JVM: Импортируемые модули не инициализируются
- JVM: Не реализовано полное сранение массивов.
- JVM: Не реализовано полное сранение записей.
- JVM: Не достаточно средств для реализации рефлексии на уровне локальных процедур.
memset(t, 0, sizeof *t);
type -> gen_type = t;
- if(type -> class != OBERON_TYPE_NOTYPE)
- {
- t -> wide = jvm_is_wide_type(type);
- t -> prefix = jvm_get_prefix(type);
- t -> postfix = jvm_get_postfix(type);
- }
-
- t -> cell_size = jvm_cell_size_for_type(type);
-
- if(type -> class != OBERON_TYPE_NIL)
- {
- t -> desc = jvm_get_descriptor(type);
- }
-
+ gen_module_t * m;
switch(type -> class)
{
case OBERON_TYPE_NOTYPE:
case OBERON_TYPE_NIL:
break;
case OBERON_TYPE_RECORD:
- ;
- gen_module_t * m;
m = type -> module -> gen_mod;
oberon_generate_record_class(m, type);
break;
gen_error("oberon_generator_init_type: unk calss %i", type -> class);
break;
}
+
+ if(type -> class != OBERON_TYPE_NOTYPE)
+ {
+ t -> wide = jvm_is_wide_type(type);
+ t -> prefix = jvm_get_prefix(type);
+ t -> postfix = jvm_get_postfix(type);
+ }
+
+ t -> cell_size = jvm_cell_size_for_type(type);
+
+ if(type -> class != OBERON_TYPE_NIL)
+ {
+ t -> desc = jvm_get_descriptor(type);
+ }
}
void