DEADSOFTWARE

JVM: Добавлена частичная реализация модуля Out
[dsw-obn.git] / notes
diff --git a/notes b/notes
index 0576334c3d003d72efdf80e9946f50d4f68ef97d..2cfcb16fd6c024c7bd3df454f5e55456851fa8f7 100644 (file)
--- a/notes
+++ b/notes
@@ -1,67 +1,26 @@
-- открытые массивы работкают криво как статические аргументы процедур
-    Случай 1: не проходит проверки libgccjit
-    (*
-     TYPE Ar = ARRAY OF INTEGER;
-     VAR a : POINTER TO Ar;
+- Какие-то проблемы с определением типов наперёд:
+  (*
+    TYPE
+    R2 = RECORD r : R1 END;
+    R1 = RECORD END;
+  *)
+- Нужно изменить передачу информации о вызываемой процедуре в MODE_CALL
+   На данный момент конкретная процедура передаётся в поле var, вместо parent
+   Что не позволяет делать процедуры-переменные в полях записей, массивах и т.д.
+- Нужны средства создания биндингов. Хотя бы как заглушки для модулей.
 
-     (* так же и с VAR-параметром *)
-     PROCEDURE Ax(x : Ar);
-     END Ax;
-
-     Ax(a);
-     *)
-    Случай 2: массив должен быть указателем, да и ещё копироваться
-    (*
-     TYPE Ar = ARRAY OF INTEGER;
-     VAR a : POINTER TO Ar;
-
-     (* при использовании VAR-параметра работает *)
-     PROCEDURE Ax(x : Ar);
-     END Ax;
-
-     Ax(a^);
-     *)
-
-- нет символов и строк
 - нужен автокаст int -> real для DIV. Да и вообще каст типов.
+- нет символов и строк
 
 - нету операторов if, while и т.д.
 
-- импортируемые модули не инициализируются (секция begin)
 - нету типа set
 - не реализована свёртка констант
 - не протестированы типы разнных размеров
 
-- не реализовано расширение типа 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.
-- нет проверок переполнения как в рантайме, так и в компилтайме.
+- не реализовано расширение типа record
+- не реализован автокаст
+- нет проверок переполнения в компилтайме.
     Возможно можно заюзать это:
       https://gcc.gnu.org/onlinedocs/gcc/Integer-Overflow-Builtins.html