string.dump не верно работает

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

Вот отрывок из книги создателя языка:

Lua принимает предкомпилированный код практически везде, где он допускает исходный код. В частности, loadfile и load принимают предкомпилированный код.

Мы можем написать упрощенную версию luac непосредственно на Lua:


Код
p = loadfile(arg[1]) 
f = io.open(arg[2], "wb") 
f:write(string.dump(p)) 
f:close() 


Основная функция здесь — это string.dump: она получает функцию Lua и возвращает ее предкомпилированный код как строку, правильно оформленную для ее обратной загрузки в Lua.


Т.к. в Квике теперь две версии lua, то необходимо запускать все в одной версии.
 
Алексей,  еще раз по буквам весь скрипт (и ничего более)
Код
function main()
   local f = io.open(getScriptPath() .. '\\1.luac', 'wb')
   f:write(string.dump(main,true))
   f:flush()
   f:close()
end

Nikolay,  он два раза пишет в файл, один раз явным вызовом, другой - когда квик запускает мейн во втором потоке. Что там за каша получится никто не знает.
 
переделал исходник, сохраняю совершенно другую функцию, результат отрицательный, не запускается в квике.
этот кусочек из файла  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.
Получается первые зеленые правильно идут, а между зелеными и красными должны быть байты размерности и их нет.  
И красные немного не те.
 
в тоже время сделал ещё эксперимент, очень простая функция без внешних переменных

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
только красная часть отличается  
 
Вопрос из спортивного интереса: а на кой вообще нужны эти .luac? Я всегда запускаю файл .lua, он всегда компилируется при запуске и прекрасно работает. Время на компиляцию стремится к нулю...
 
Цитата
Алексей написал:
взрыв мозга
Как минимум, заменены '1A 0A' на '1A 0D 0A' (или \n на \r\n, если не очевидно) и выброшены управляющие символы (01  04  04  04  08  00), что рантайм и должен делать, если файл открыт не в бинарном режиме. И еще какие-то замены должны быть и, хуже того, зависящие от текущей локали.

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

Цитата
Владимир написал:
а на кой вообще нужны эти .luac?
Некоторые на продажу делают, типа сорцы попрятать (до поры или совсем). Правда, конкретно эти luac на раз ломаются.
в бинарном открывал,
через dll вроде нормально можно защитить.
 
Anton, В интерпретируемом коде сорцы попрятать?! Воистину, программисты вымерли! Ах, да - ОТ СТЫДА попрятать! :smile:  
 
Цитата
Владимир написал:
Anton, В интерпретируемом коде сорцы попрятать?! Воистину, программисты вымерли! Ах, да - ОТ СТЫДА попрятать! ::  
я думал что тут не тролей, а нет, есть!
Чтобы дельного посоветовал, а стебатся мы все гаразд.
 
Алексей, Я дельное и посоветовал: используйте файлы .lua и не занимайтесь хернёй.
 
Цитата
Алексей написал:
в бинарном открывал
Мы же видим, что результат привнесен текстовым режимом. Как так получилось, надо смотреть.

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

Цитата
Владимир написал:
ОТ СТЫДА попрятать!
От разного. Вот был случай например, попросили в проекте подсобить, тксть за ящик коньяку. Ну ок, подсобил. А потом один из штатных прогеров статью на хабре накропал, как надо задачку решать (которую я им и порешал) с кусками моего кода, вымарав копирайты. Неприятно же ж.
 
Anton, Да я давал на Хабре даже исходники своего "сортира" - те, кто получали, умолкали, кто нет - визжали что-то непотребное, да тыкали в третий том Кнута. :smile: Программисты ВЫМЕРЛИ!
 
Цитата
Anton написал:
Цитата
Алексей написал:
в бинарном открывал
Мы же видим, что результат привнесен текстовым режимом. Как так получилось, надо смотреть.,


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

Цитата
Владимир написал:
ОТ СТЫДА попрятать!
От разного. Вот был случай например, попросили в проекте подсобить, тксть за ящик коньяку. Ну ок, подсобил. А потом один из штатных прогеров статью на хабре накропал, как надо задачку решать (которую я им и порешал) с кусками моего кода, вымарав копирайты. Неприятно же ж.
я бы скрин сделал и показал что всё в бинарном виде я делал, но тут на форуме беда с картинками.
не собираюсь я ничего прятать, и не буду свои творения продавать или раздавать, мне просто надо получить кусок бинарного кода, есть идея , пробую реализовать, а тут такая засада.
 
Ну так

Код
local f = assert(load([[print('hello')print('world')]]))
 
Цитата
Nikolay написал:
Ну так

Код
   local  f  =  assert(load([[ print ( 'hello' ) print ( 'world' )]]))  
Спасибо
Страницы: 1
Читают тему
Наверх