X-Git-Url: http://deadsoftware.ru/gitweb?a=blobdiff_plain;f=notes;h=0576334c3d003d72efdf80e9946f50d4f68ef97d;hb=e763da864f7330c2b53029782c6b0d85543eb4d2;hp=0dd194e9e6e6057ced4ec2518616dd9f63622934;hpb=338eeae16495bbdcbd8c4f3dad4996346e26139b;p=dsw-obn.git diff --git a/notes b/notes index 0dd194e..0576334 100644 --- a/notes +++ b/notes @@ -1,16 +1,69 @@ -- хреновая проверка типов-указателей -- нету процедуры NEW -- не реализовано расширение типа record -- не реализована краткая форма многомерных массивов и краткой формы доступа к ним (* [1, 2, 3] - компилится, но вычисляется только первый аргумент *) - -- не реализованы локальные объявления в процедурах -- не работает присваивание к переменным-процедурам. -- не понятен результат присваивания статических структур (* reca := recb; *) -- не понятен результат присваивания статических массивов (* arr1 := arr2; *) -- не реализованы var-параметры в генераторе -- не реализованы процедуры "наперёд" +- открытые массивы работкают криво как статические аргументы процедур + Случай 1: не проходит проверки libgccjit + (* + TYPE Ar = ARRAY OF INTEGER; + VAR a : POINTER TO Ar; + (* так же и с 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. +- нет проверок переполнения как в рантайме, так и в компилтайме. + Возможно можно заюзать это: + https://gcc.gnu.org/onlinedocs/gcc/Integer-Overflow-Builtins.html + +- нету счёта строк / столбцов +- любая ошибка фатальна