DEADSOFTWARE

Исправлен цикл REPEAT, исправлено использование HUGEINT как индекса массива
[dsw-obn.git] / notes
diff --git a/notes b/notes
index 0576334c3d003d72efdf80e9946f50d4f68ef97d..46fe2580f6b3cf7faac2e184637d5e37210fb222 100644 (file)
--- a/notes
+++ b/notes
@@ -1,69 +1,44 @@
-- открытые массивы работкают криво как статические аргументы процедур
-    Случай 1: не проходит проверки libgccjit
-    (*
-     TYPE Ar = ARRAY OF INTEGER;
-     VAR a : POINTER TO Ar;
+- Не доделан модуль CPMath (тоже самое синхронизировать с Math/MathL)
+    * Сделать нормальную реализацию IntPower
+    * Реализовать Mantissa
+    * Есть нативные рализации Frac и Trunc?
 
-     (* так же и с VAR-параметром *)
-     PROCEDURE Ax(x : Ar);
-     END Ax;
+- Нужно делать проверку границ при касте индекса массива с типом HUGEINT
 
-     Ax(a);
-     *)
-    Случай 2: массив должен быть указателем, да и ещё копироваться
-    (*
-     TYPE Ar = ARRAY OF INTEGER;
-     VAR a : POINTER TO Ar;
+- Нужно передавать информацию о файле и строках в кодогенератор.
+- Нет процедур привязанных к типм (10.2)
+- Не полная реализация модуля Files 
 
-     (* при использовании VAR-параметра работает *)
-     PROCEDURE Ax(x : Ar);
-     END Ax;
+- Разршить отсутсвие RETURN в функциях без BEGIN
+    С вкорячиванием трапа, естественно.
+- Нужно передлать кодогенератор что бы складировать код в структурах а не напрямую срать в файлы
 
-     Ax(a^);
-     *)
+- Не полная реализация модуля Strings 
+    * Не реализованы процедуры Insert Append Delete Replace Extract Pos
+- Сделать проверку повторов в CASE.
+- Сделать нормальную проверку наличия RETURN.
 
-- Ð½ÐµÑ\82 Ñ\81имволов Ð¸ Ñ\81Ñ\82Ñ\80ок
-- Ð½Ñ\83жен Ð°Ð²Ñ\82окаÑ\81Ñ\82 int -> real Ð´Ð»Ñ\8f DIV. Ð\94а Ð¸ Ð²Ð¾Ð¾Ð±Ñ\89е ÐºÐ°Ñ\81Ñ\82 Ñ\82ипов.
+- Ð\9dÑ\83жнÑ\8b Ñ\81Ñ\80едÑ\81Ñ\82ва Ñ\81озданиÑ\8f Ð±Ð¸Ð½Ð´Ð¸Ð½Ð³Ð¾Ð². (oakwood 3.5)
+- Ð\9bÑ\8eбаÑ\8f Ð¾Ñ\88ибка Ñ\84аÑ\82алÑ\8cна
 
-- нету операторов if, while и т.д.
+- Примеры -5 DIV 3 и -5 MOD 3 работают не так как в (8.2.2)
+    Нужен другой тип округления?
 
-- импортируемые модули не инициализируются (секция begin)
-- нету типа set
-- не реализована свёртка констант
-- не протестированы типы разнных размеров
+- Неплохо бы иметь оператор ** (oakwood 3.7)
+- Неплохо бы иметь параметры только для чтения (oakwood 5.13)
+- Надо что-то делать с ситуацией описанной в (okawood 2.4)
 
-- не реализовано расширение типа 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.
-- нет проверок переполнения как в рантайме, так и в компилтайме.
+- Запретить проверку типа и приведене типа если указатель имеет значение 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
 
-- нету счёта строк / столбцов
-- любая ошибка фатальна
+- Не полная реализация модуля SYSTEM
+    * Процедуры GETREG PUTREG впринципе вписываются в jvm
+      и могут быть полезны при реализции рефлекции
+    * Остальное не имеет смысла в jvm
+- JVM: Не достаточно средств для реализации рефлексии на уровне локальных процедур.
+    Как минимум нужно каждой функции добавлять фрейм к параметрам (динамическая связь?)