index c1a8b0b5dfc95559b85b6c5fdbf0dbad7a58e315..0576334c3d003d72efdf80e9946f50d4f68ef97d 100644 (file)
--- a/notes
+++ b/notes
-- нету комментариев
+- открытые массивы работкают криво как статические аргументы процедур
+ Случай 1: не проходит проверки libgccjit
+ (*
+ TYPE Ar = ARRAY OF INTEGER;
+ VAR a : POINTER TO Ar;
-- нету тестовых процедур для ввода-вывода
-- нету процедуры NEW
-- нету открытых массивов
+ (* так же и с 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
- не реализована свёртка констант
- не протестированы типы разнных размеров
-- не реализовано присваивание к переменным-процедурам:
- в libgccjit нет средств получения указателя на функцию.
- Как решение - получение указателя в основной программе.
- не реализовано расширение типа 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.
-- не понятен результат присваивания статических/разыменованных структур (* reca := recb; *)
-- не понятен результат присваивания статических/разыменованных массивов (* arr1 := arr2; *)
+- нет проверок переполнения как в рантайме, так и в компилтайме.
+ Возможно можно заюзать это:
+ https://gcc.gnu.org/onlinedocs/gcc/Integer-Overflow-Builtins.html
- нету счёта строк / столбцов
- любая ошибка фатальна