X-Git-Url: http://deadsoftware.ru/gitweb?p=dsw-obn.git;a=blobdiff_plain;f=notes;h=9ff5af38d1d1334d8adee189a0d370664dca1269;hp=ebd198db2fc9f0cb61fe90b31f496dbfa4a13cf9;hb=HEAD;hpb=ea5cf056abf2bf42e9f328b9c1f2d94ee96bcc4c diff --git a/notes b/notes index ebd198d..9ff5af3 100644 --- a/notes +++ b/notes @@ -1,46 +1,40 @@ -- нету открытых массивов -- нет символов и строк -- нужен автокаст int -> real для DIV. Да и вообще каст типов. +- Jasmin создаёт ошибку в float константах, надо как-то порешать. +- Нужно делать проверку границ при касте индекса массива с типом HUGEINT -- нету операторов if, while и т.д. +- Нет процедур привязанных к типм (10.2) +- Не полная реализация модуля Files + * Нет процедур ReadNum WriteNum -- импортируемые модули не инициализируются (секция begin) -- нету типа set -- не реализована свёртка констант -- не протестированы типы разнных размеров +- Разршить отсутсвие RETURN в функциях без BEGIN + С вкорячиванием трапа, естественно. +- Нужно передлать кодогенератор что бы складировать код в структурах а не напрямую срать в файлы -- не реализовано расширение типа 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. -- нет проверок переполнения как в рантайме, так и в компилтайме. +- Не полная реализация модуля Strings + * Не реализованы процедуры Insert Append Delete Replace Extract Pos +- Сделать проверку повторов в CASE. +- Сделать нормальную проверку наличия RETURN. + +- Нужны средства создания биндингов. (oakwood 3.5) +- Любая ошибка фатальна + +- Примеры -5 DIV 3 и -5 MOD 3 работают не так как в (8.2.2) + Нужен другой тип округления? + +- Неплохо бы иметь оператор ** (oakwood 3.7) +- Неплохо бы иметь параметры только для чтения (oakwood 5.13) +- Надо что-то делать с ситуацией описанной в (okawood 2.4) + +- Запретить проверку типа и приведене типа если указатель имеет значение 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: Не достаточно средств для реализации рефлексии на уровне локальных процедур. + Как минимум нужно каждой функции добавлять фрейм к параметрам (динамическая связь?)