index ebd198db2fc9f0cb61fe90b31f496dbfa4a13cf9..71fcaf3866a440c895be254c267961ed0f61be79 100644 (file)
--- a/notes
+++ b/notes
-- нету открытых массивов
-- нет символов и строк
-- нужен автокаст int -> real для DIV. Да и вообще каст типов.
+- Нужно передавать информацию о файле и строках в кодогенератор.
+- Нет процедур привязанных к типм (10.2)
+- Не полная реализация модуля Files
+ * Не реализована запись в файл
-- неÑ\82Ñ\83 опеÑ\80аÑ\82оÑ\80ов if, while и Ñ\82.д.
+- Ð\9dÑ\83жно пеÑ\80едлаÑ\82Ñ\8c кодогенеÑ\80аÑ\82оÑ\80 Ñ\87Ñ\82о бÑ\8b Ñ\81кладиÑ\80оваÑ\82Ñ\8c код в Ñ\81Ñ\82Ñ\80Ñ\83кÑ\82Ñ\83Ñ\80аÑ\85 а не напÑ\80Ñ\8fмÑ\83Ñ\8e Ñ\81Ñ\80аÑ\82Ñ\8c в Ñ\84айлÑ\8b
-- импоÑ\80Ñ\82иÑ\80Ñ\83емÑ\8bе модÑ\83ли не иниÑ\86иализиÑ\80Ñ\83Ñ\8eÑ\82Ñ\81Ñ\8f (Ñ\81екÑ\86иÑ\8f begin)
-- нету типа set
-- не Ñ\80еализована Ñ\81вÑ\91Ñ\80Ñ\82ка конÑ\81Ñ\82анÑ\82
-- не пÑ\80оÑ\82еÑ\81Ñ\82иÑ\80ованÑ\8b Ñ\82ипÑ\8b Ñ\80азннÑ\8bÑ\85 Ñ\80азмеÑ\80ов
+- Ð\9dе полнаÑ\8f Ñ\80еализаÑ\86иÑ\8f модÑ\83лÑ\8f Strings
+ * Не реализованы процедуры Insert Append Delete Replace Extract Pos
+- СделаÑ\82Ñ\8c пÑ\80овеÑ\80кÑ\83 повÑ\82оÑ\80ов в CASE.
+- СделаÑ\82Ñ\8c ноÑ\80малÑ\8cнÑ\83Ñ\8e пÑ\80овеÑ\80кÑ\83 налиÑ\87иÑ\8f RETURN.
-- не реализовано расширение типа record:
- libgccjit не умеет в классы. Проверки в рантайме надо делать вручную.
-- нет проверок границ массивов в рантайме:
- Потому что как минимум нет дескрипторов типа.
- Возможно можно заюзать это:
- https://gcc.gnu.org/onlinedocs/gcc/Pointer-Bounds-Checker-builtins.html
-- При вычислении размера структур не учитывается вравнивание.
- в libgccjit нет средств получения размера типов, в т.ч. структур
- Как происходит выравнивание и есть ли оно вообще по дефолту - не понятно:
- Нужно ли для получения выровненных структур использовать gcc_jit_type_get_aligned?
- Пересекается с этим:
- https://gcc.gnu.org/onlinedocs/gcc/Common-Type-Attributes.html
- Требуемые выравнивания для типов можно получить через встроинную функцию __alignof__(T)
- https://gcc.gnu.org/onlinedocs/gcc/Alignment.html
- Возможный алгоритм выравнивания:
- https://stackoverflow.com/questions/6963998/how-does-gcc-calculate-the-required-space-for-a-structure
- http://www.rendoc.tech/questions/834444/how-does-gcc-calculate-the-required-space-for-a-structure
- Есть ещё что-то для проверки границ объектов:
- https://gcc.gnu.org/onlinedocs/gcc/Object-Size-Checking.html
-- не понятен результат присваивания статических/разыменованных структур и массивов
- (* reca := recb; *) - побайтовое копирование?
-- не реализовано присваивание процедур к переменным-процедурам:
- в libgccjit нет средств получения указателя на функцию.
- Как решение-костыль - получение указателя в основной программе и сохранение в переменной.
-- не реализован автокаст:
- Не критично: libgccjit сам разруливает типы разных размеров.
-- не реализованы локальные процедуры:
- libgccjit не умеет в локальные функции.
- Обойти можно костылём как в jvm.
-- нет проверок переполнения как в рантайме, так и в компилтайме.
+- Нужны средства создания биндингов. (oakwood 3.5)
+- Любая ошибка фатальна
+
+- Примеры -5 DIV 3 и -5 MOD 3 работают не так как в (8.2.2)
+ Нужен другой тип округления?
+
+- Неплохо бы иметь оператор ** (oakwood 3.7)
+- Неплохо бы иметь параметры только для чтения (oakwood 5.13)
+- Надо что-то делать с ситуацией описанной в (okawood 2.4)
+- Нет модулей Math and MathL (oakwood 1.2.7)
+
+- Запретить проверку типа и приведене типа если указатель имеет значение NIL (oakwood 2.3.3)
+- Запретить доступ к битам SET которые не входят в пределы 0..MAX(SET) (oakwood 2.3.5)
+- Запретить каст через SHORT если значение не в пределах результата (в рантайме чтоли?) (oakwood 2.3.6)
+- Нет проверки переполнений (oakwood 2.3.8)
+- Нет проверок переполнения в компилтайме.
Возможно можно заюзать это:
https://gcc.gnu.org/onlinedocs/gcc/Integer-Overflow-Builtins.html
Возможно можно заюзать это:
https://gcc.gnu.org/onlinedocs/gcc/Integer-Overflow-Builtins.html
-- нету счёта строк / столбцов
-- любая ошибка фатальна
+- Не полная реализация модуля SYSTEM
+ * Процедуры GETREG PUTREG впринципе вписываются в jvm
+ и могут быть полезны при реализции рефлекции
+ * Остальное не имеет смысла в jvm
+- JVM: Не достаточно средств для реализации рефлексии на уровне локальных процедур.
+ Как минимум нужно каждой функции добавлять фрейм к параметрам (динамическая связь?)