Алексей (Все сообщения пользователя)

Выбрать дату в календареВыбрать дату в календаре

Страницы: 1
Как закрыть форточку?
 
Прочитал всю ту ветку, проблема решается коряво, в квике непонятно на какие грабли ещё можно наступить, проблема с OnStop и работа с таблицами, озвучена давно и не решается никак. Т.е. это приводит к непредсказуемым результатам, и техподдержке всё равно что происходит. Вроде как бы почти работает, и так сойдёт их лозунг судя по всему. Печально на это всё смотреть.
Как закрыть форточку?
 
Цитата
Daniil Pozdnyakov написал:
Здравствуйте.

На основе описанного в документации QLUA.chm можно сделать вывод, что после вызова OnStop() не гарантировано, что main() завершится до конца, поэтому в вашем случае таблица и не удаляется.

На основе этого предлагаем добавить процедуру удаления окна в тело колбека OnStop().
Самое интересное что, чтобы я не написал в конце main, ломается всё только на DestroyTable, что происходит в этой функции что main  не завершается непонятно.
там операции с файлами делал, всё норм, цвета и текст в таблице менял, всё работает, кроме DestroyTable.
Как закрыть форточку?
 
Цитата
Алексей написал:
ещё кусочек кода который непонятно почему не работает
    Скрытый текст
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, проблема та же, не закрывается форточка.
Как закрыть форточку?
 
ещё кусочек кода который непонятно почему не работает
Скрытый текст

 message('main end2 is_run = ' .. tostring(is_run),1)
эта строчка уже не исполняется, всё ломает   DestroyTable(skt_id)
string.dump не верно работает
 
Цитата
Nikolay написал:
Ну так

Код
   local  f  =  assert(load([[ print ( 'hello' ) print ( 'world' )]]))  
Спасибо
string.dump не верно работает
 
Цитата
Anton написал:
Цитата
Алексей написал:
в бинарном открывал
Мы же видим, что результат привнесен текстовым режимом. Как так получилось, надо смотреть.,


Цитата
Алексей написал:
через dll вроде нормально можно защитить
Тут надо сначала выяснить, от чего защищаемся. Алгоритм восстанавливать что по луа-дизасму, что по просто дизасму - примерно одно и то же, если восстанавливающий в теме. Другое дело, что это времязатратно, большинство поделий просто переписать с нуля дешевле, чем нанять спеца их курочить. Если задачу реально ставить - а именно: "сложность восстановления алгоритма достаточно высока" - то можно нормально защитить. А если "вообще чтобы никто никогда не сломал", то это нерешаемая задача.

Цитата
Владимир написал:
ОТ СТЫДА попрятать!
От разного. Вот был случай например, попросили в проекте подсобить, тксть за ящик коньяку. Ну ок, подсобил. А потом один из штатных прогеров статью на хабре накропал, как надо задачку решать (которую я им и порешал) с кусками моего кода, вымарав копирайты. Неприятно же ж.
я бы скрин сделал и показал что всё в бинарном виде я делал, но тут на форуме беда с картинками.
не собираюсь я ничего прятать, и не буду свои творения продавать или раздавать, мне просто надо получить кусок бинарного кода, есть идея , пробую реализовать, а тут такая засада.
string.dump не верно работает
 
Цитата
Владимир написал:
Anton, В интерпретируемом коде сорцы попрятать?! Воистину, программисты вымерли! Ах, да - ОТ СТЫДА попрятать! ::  
я думал что тут не тролей, а нет, есть!
Чтобы дельного посоветовал, а стебатся мы все гаразд.
string.dump не верно работает
 
Цитата
Anton написал:
Цитата
Алексей написал:
взрыв мозга
Как минимум, заменены '1A  0A ' на '1A  0D 0A ' (или \n на \r\n, если не очевидно) и выброшены управляющие символы (01  04  04  04  08  00), что рантайм и должен делать, если файл открыт не в бинарном режиме. И еще какие-то замены должны быть и, хуже того, зависящие от текущей локали.

Цитата
Владимир написал:
а на кой вообще нужны эти .luac?
Некоторые на продажу делают, типа сорцы попрятать (до поры или совсем). Правда, конкретно эти luac на раз ломаются.
в бинарном открывал,
через dll вроде нормально можно защитить.
string.dump не верно работает
 
в тоже время сделал ещё эксперимент, очень простая функция без внешних переменных

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 61 53 00 19 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 не верно работает
 
переделал исходник, сохраняю совершенно другую функцию, результат отрицательный, не запускается в квике.
этот кусочек из файла  1B 4C 75 61 53 00 19 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.
Получается первые зеленые правильно идут, а между зелеными и красными должны быть байты размерности и их нет.  
И красные немного не те.
string.dump не верно работает
 
Цитата
Anton написал:
Цитата
Алексей написал:
смотрю кишки файла а там не хватает куска.
Выглядит так, будто были предприняты все усилия, чтобы не заработало.
1) откройте файл с 'wb', а не 'w+'
2) добавьте f:flush() перед f:close()
3) не надо main явно вызывать в конце.
1 абсолютно без разницы какая опция там, результат один и тот же
2 делал, не имеет значения, файл создаётся нормально.
3 это сделано чтобы чисто в lua запускать , без квика
и нормально работает если в чистом lua запускать
string.dump не верно работает
 
[img]file:///D:/2022-01-03_14-33-05.png[/img]
[img]file:///D:/2022-01-03_14-31-04.png[/img]
на синей картинке , кишки полученного файла
на другой описание внутреннего формата файла
string.dump не верно работает
 
жесть какой кривой форум, вставил картинку было всё хорошо, опубликовал, а тут хрень вылезла, ещё и не отредактируешь.
string.dump не верно работает
 
-- пишем такой код
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 байт

проверил на 8 квике и 9 , всё равно ошибка.
Страницы: 1
Наверх