Прочитал всю ту ветку, проблема решается коряво, в квике непонятно на какие грабли ещё можно наступить, проблема с OnStop и работа с таблицами, озвучена давно и не решается никак. Т.е. это приводит к непредсказуемым результатам, и техподдержке всё равно что происходит. Вроде как бы почти работает, и так сойдёт их лозунг судя по всему. Печально на это всё смотреть.
На основе описанного в документации QLUA.chm можно сделать вывод, что после вызова OnStop() не гарантировано, что main() завершится до конца, поэтому в вашем случае таблица и не удаляется.
На основе этого предлагаем добавить процедуру удаления окна в тело колбека OnStop().
Самое интересное что, чтобы я не написал в конце main, ломается всё только на DestroyTable, что происходит в этой функции что main не завершается непонятно. там операции с файлами делал, всё норм, цвета и текст в таблице менял, всё работает, кроме DestroyTable.
Как закрыть форточку?
Пользователь
Сообщений: Регистрация: 03.01.2022
25.02.2022 13:17:00
Цитата
Алексей написал: ещё кусочек кода который непонятно почему не работает Скрытый текст is_run = true message('start is_run = ' .. tostring(is_run),1) function main() skt_id = AllocTable() CreateWindow(skt_id) SetWindowPos(skt_id, 500, 0, 800, 400) message('main start is_run = ' .. tostring(is_run),1) while is_run do sleep(100) end message('main end1 is_run = ' .. tostring(is_run),1) DestroyTable(skt_id) message('main end2 is_run = ' .. tostring(is_run),1) end
function OnStop() is_run = false return 200 end message('main end2 is_run = ' .. tostring(is_run),1) эта строчка уже не исполняется, всё ломает DestroyTable(skt_id)
проверил код на новой версии 9,4,0,130, проблема та же, не закрывается форточка.
Как закрыть форточку?
Пользователь
Сообщений: Регистрация: 03.01.2022
24.02.2022 12:35:19
ещё кусочек кода который непонятно почему не работает
Скрытый текст
is_run = truemessage('start is_run = ' .. tostring(is_run),1) function main() skt_id = AllocTable() CreateWindow(skt_id) SetWindowPos(skt_id, 500, 0, 800, 400) message('main start is_run = ' .. tostring(is_run),1) while is_run do sleep(100) end message('main end1 is_run = ' .. tostring(is_run),1) DestroyTable(skt_id) message('main end2 is_run = ' .. tostring(is_run),1) end
function OnStop() is_run = false return 200 end
message('main end2 is_run = ' .. tostring(is_run),1) эта строчка уже не исполняется, всё ломает DestroyTable(skt_id)
Мы же видим, что результат привнесен текстовым режимом. Как так получилось, надо смотреть.,
Цитата
написал: через dll вроде нормально можно защитить
Тут надо сначала выяснить, от чего защищаемся. Алгоритм восстанавливать что по луа-дизасму, что по просто дизасму - примерно одно и то же, если восстанавливающий в теме. Другое дело, что это времязатратно, большинство поделий просто переписать с нуля дешевле, чем нанять спеца их курочить. Если задачу реально ставить - а именно: "сложность восстановления алгоритма достаточно высока" - то можно нормально защитить. А если "вообще чтобы никто никогда не сломал", то это нерешаемая задача.
Цитата
написал: ОТ СТЫДА попрятать!
От разного. Вот был случай например, попросили в проекте подсобить, тксть за ящик коньяку. Ну ок, подсобил. А потом один из штатных прогеров статью на хабре накропал, как надо задачку решать (которую я им и порешал) с кусками моего кода, вымарав копирайты. Неприятно же ж.
я бы скрин сделал и показал что всё в бинарном виде я делал, но тут на форуме беда с картинками. не собираюсь я ничего прятать, и не буду свои творения продавать или раздавать, мне просто надо получить кусок бинарного кода, есть идея , пробую реализовать, а тут такая засада.
string.dump не верно работает
Пользователь
Сообщений: Регистрация: 03.01.2022
03.01.2022 19:49:35
Цитата
Владимир написал: , В интерпретируемом коде сорцы попрятать?! Воистину, программисты вымерли! Ах, да - ОТ СТЫДА попрятать! ::
я думал что тут не тролей, а нет, есть! Чтобы дельного посоветовал, а стебатся мы все гаразд.
Как минимум, заменены '1A 0A ' на '1A 0D 0A ' (или \n на \r\n, если не очевидно) и выброшены управляющие символы (01 04 04 04 08 00), что рантайм и должен делать, если файл открыт не в бинарном режиме. И еще какие-то замены должны быть и, хуже того, зависящие от текущей локали.
Цитата
написал: а на кой вообще нужны эти .luac?
Некоторые на продажу делают, типа сорцы попрятать (до поры или совсем). Правда, конкретно эти luac на раз ломаются.
в бинарном открывал, через dll вроде нормально можно защитить.
string.dump не верно работает
Пользователь
Сообщений: Регистрация: 03.01.2022
03.01.2022 14:45:00
в тоже время сделал ещё эксперимент, очень простая функция без внешних переменных
function test() message('Test',1) end
function main() local f = io.open(getScriptPath() .. '\\test.luac', 'wb') f:write(string.dump(test,true)) f:flush() f:close() end
создался файл test.luac и он работает у меня взрыв мозга 1B 4C 75 6153 0019 93 0D 0A 1A 0A 04 08 04 08 08 78 56 00 00 00 00 00 00 00 00 00 00 00 28 77 только красная часть отличается
string.dump не верно работает
Пользователь
Сообщений: Регистрация: 03.01.2022
03.01.2022 14:36:43
переделал исходник, сохраняю совершенно другую функцию, результат отрицательный, не запускается в квике. этот кусочек из файла 1B 4C 75 6153 0019 93 0D 0D 0A 1A 0D 0A 04 08 04 08 08 78 56 00 00 00 00 00 00 00 00 00 00 00 в документации написано Byte numbers are in origin-1 decimal (mostly showing the arithmetic) and origin-0 hex. 1 x00: 1b 4c 75 61 LUA_SIGNATURE from lua.h. 5 x04: 52 00 Binary-coded decimal 52 for the Lua version, 00 to say the bytecode is compatible with the "official" PUC-Rio implementation. 5+2 x06: 01 04 04 04 08 00 Six system parameters. On x386 machines they mean: little-endian, 4-byte integers, 4-byte VM instructions, 4-byte size_t numbers, 8-byte Lua numbers, floating-point. These parameters must all match up between the bytecode file and the Lua interpreter, otherwise the bytecode is invalid. 7+6 x0c: 19 93 0d 0a 1a 0a Present in all bytecode produced by Lua 5.2 from PUC-Rio. Described in lundump.h as "data to catch conversion errors". Might be constructed from binary-coded decimal 1993 (the year it all started), Windows line terminator, MS-DOS text file terminator, Unix line terminator. Получается первые зеленые правильно идут, а между зелеными и красными должны быть байты размерности и их нет. И красные немного не те.
написал: смотрю кишки файла а там не хватает куска.
Выглядит так, будто были предприняты все усилия, чтобы не заработало. 1) откройте файл с 'wb', а не 'w+' 2) добавьте f:flush() перед f:close() 3) не надо main явно вызывать в конце.
1 абсолютно без разницы какая опция там, результат один и тот же 2 делал, не имеет значения, файл создаётся нормально. 3 это сделано чтобы чисто в lua запускать , без квика и нормально работает если в чистом lua запускать
string.dump не верно работает
Пользователь
Сообщений: Регистрация: 03.01.2022
03.01.2022 09:47:09
[img]file:///D:/2022-01-03_14-33-05.png[/img] [img]file:///D:/2022-01-03_14-31-04.png[/img] на синей картинке , кишки полученного файла на другой описание внутреннего формата файла
string.dump не верно работает
Пользователь
Сообщений: Регистрация: 03.01.2022
03.01.2022 09:39:12
жесть какой кривой форум, вставил картинку было всё хорошо, опубликовал, а тут хрень вылезла, ещё и не отредактируешь.
string.dump не верно работает
Пользователь
Сообщений: Регистрация: 03.01.2022
03.01.2022 09:36:13
-- пишем такой код function main() local f = io.open(getScriptPath() .. '\\1.luac', 'w+') f:write(string.dump(main,true)) f:close() end
main()
в результате получается файл 1.luac и он не запускается в quike (пишет corrupted precompiled chunk) смотрю кишки файла а там не хватает куска. [img][/img]
согласно документации после версии LUA должно быть ещё 6 байт