Можно ли изменить строки (содержимое и размер) в байт-коде Lua, чтобы он все еще был корректным? - PullRequest
2 голосов
/ 07 сентября 2010

Можно ли изменить строки (содержимое и размер) в байт-коде Lua, чтобы он по-прежнему был правильным? Речь идет о переводе строк в байт-код Lua. Конечно, не каждый язык имеет одинаковый размер для каждого слова ...

Ответы [ 3 ]

3 голосов
/ 07 сентября 2010

Да, если вы знаете, что делаете. Строки имеют префикс по размеру, хранящемуся как int. Размер и порядковый номер этого int зависит от платформы. Но почему вы должны редактировать байт-код? Вы потеряли источники?

1 голос
/ 09 сентября 2013

После некоторого погружения через исходный код Lua я нашел такое решение:

#include "lua.h"
#include "lauxlib.h"

#include "lopcodes.h"
#include "lobject.h"
#include "lundump.h"

/* Definition from luac.c: */
#define toproto(L,i) (clvalue(L->top+(i))->l.p)

writer_function(lua_State* L, const void* p, size_t size, void* u)
{
    UNUSED(L);
    return (fwrite(p,size,1,(FILE*)u)!=1) && (size!=0);
}

static void
lua_bytecode_change_const(lua_State *l, Proto *f_proto,
                   int const_index, const char *new_const)
{
    TValue *tmp_tv = NULL;
    const TString *tmp_ts = NULL;

    tmp_ts = luaS_newlstr(l, new_const, strlen(new_const));
    tmp_tv = &f_proto->k[INDEXK(const_index)];
    setsvalue(l, tmp_tv, tmp_ts);

    return;
}

int main(void)
{
    lua_State *l = NULL;
    Proto *lua_function_prototype = NULL;
    FILE *output_file_hnd = NULL;

    l = lua_open();
    luaL_loadfile(l, "some_input_file.lua");
    lua_proto = toproto(l, -1);
    output_file_hnd = fopen("some_output_file.luac", "w");

    lua_bytecode_change_const(l, lua_function_prototype, some_const_index, "some_new_const");
    lua_lock(l);
    luaU_dump(l, lua_function_prototype, writer_function, output_file_hnd, 0);
    lua_unlock(l);

    return 0;
}

Сначала мы запустили Lua VM и загрузили скрипт, который мы хотим изменить.Скомпилировано или нет, не имеет значения.Затем создайте прототип функции Lua, проанализируйте и измените ее постоянную таблицу.Выгрузите прототип в файл.

Надеюсь, вы поняли это для основной идеи.

0 голосов
/ 09 сентября 2010

Вы можете попробовать использовать декомпилятор LuaDec .Декомпилятор позволил бы изменять строки в сгенерированном коде Lua, аналогичном исходному.

ChunkSpy имеет A No-Frills Введение в Lua 5.1 VM Инструкция может помочь вам понять формат скомпилированного блока и внести изменения непосредственно в байт-код, если это необходимо.

...