-- нету типа set
-- нету операторов if, while и т.д.
-
- Нужен тип представляющий типы
Требуется для оператора IS и некоторых встраиваемых функций
+
+- Нет типа SET
- Нет оператора IS
-- не реализованы все встроенные функции
-- не реализована свёртка констант
+- Нет конструкции CASE
+- Нет конструкции FOR
+- Нет конструкции LOOP/EXIT
+- Нет конструкции WITH
+- Нет модуля SYSTEM
+- Нет функций ASH CAP CHR ENTIER LEN LONG MAX MIN ODD ORD SHORT SIZE
+- Нет процедур ASSERT COPY DEC EXCL HALT INC INCL
+- Не реализована свёртка констант
+- Не счёта строк / столбцов
-- нету счёта строк / столбцов
-- любая ошибка фатальна
+- Нужно пробежаться по стандарту и всё перепроверить.
- Нужны средства создания биндингов. На данный момент реализуемо как заглушки для модулей.
-- нет проверок переполнения в компилтайме.
+- Любая ошибка фатальна
+- Нет проверок переполнения в компилтайме.
Возможно можно заюзать это:
https://gcc.gnu.org/onlinedocs/gcc/Integer-Overflow-Builtins.html
ELSE,
ELSIF,
WHILE,
- DO
+ DO,
+ REPEAT,
+ UNTIL
};
// =======================================================================
{
ctx -> token = DO;
}
+ else if(strcmp(ident, "REPEAT") == 0)
+ {
+ ctx -> token = REPEAT;
+ }
+ else if(strcmp(ident, "UNTIL") == 0)
+ {
+ ctx -> token = UNTIL;
+ }
}
static void
oberon_assert_token(ctx, END);
oberon_generate_label(ctx, end);
}
+ else if(ctx -> token == REPEAT)
+ {
+ gen_label_t * begin;
+ oberon_expr_t * cond;
+
+ begin = oberon_generator_reserve_label(ctx);
+ oberon_generate_label(ctx, begin);
+ oberon_assert_token(ctx, REPEAT);
+
+ oberon_statement_seq(ctx);
+
+ oberon_assert_token(ctx, UNTIL);
+
+ cond = oberon_expr(ctx);
+ if(cond -> result -> class != OBERON_TYPE_BOOLEAN)
+ {
+ oberon_error(ctx, "condition must be boolean");
+ }
+
+ oberon_generate_branch(ctx, cond, true, begin);
+ }
else if(ctx -> token == RETURN)
{
oberon_assert_token(ctx, RETURN);