2019-05-22 07:17:31 +08:00
|
|
|
#define SOL_ALL_SAFETIES_ON 1
|
|
|
|
#include <sol/sol.hpp>
|
|
|
|
|
|
|
|
#include <iostream>
|
|
|
|
|
|
|
|
|
2020-11-20 05:42:02 +08:00
|
|
|
int main() {
|
2021-03-06 23:14:48 +08:00
|
|
|
std::cout << "=== dump (serialize between states) ==="
|
|
|
|
<< std::endl;
|
2019-05-22 07:17:31 +08:00
|
|
|
|
|
|
|
// 2 states, transferring function from 1 to another
|
|
|
|
sol::state lua;
|
|
|
|
sol::state lua2;
|
2020-11-20 05:42:02 +08:00
|
|
|
|
2019-05-22 07:17:31 +08:00
|
|
|
// we're not going to run the code on the first
|
|
|
|
// state, so we only actually need
|
|
|
|
// the base lib on the second state
|
|
|
|
// (where we will run the serialized bytecode)
|
|
|
|
lua2.open_libraries(sol::lib::base);
|
|
|
|
|
|
|
|
// load this code (but do not run)
|
2021-03-06 23:14:48 +08:00
|
|
|
sol::load_result lr
|
|
|
|
= lua.load("a = function (v) print(v) return v end");
|
2019-05-22 07:17:31 +08:00
|
|
|
// check if it's sucessfully loaded
|
2022-09-28 13:56:26 +08:00
|
|
|
SOL_ASSERT(lr.valid());
|
2019-05-22 07:17:31 +08:00
|
|
|
|
|
|
|
// turn it into a function, then dump the bytecode
|
2021-03-06 23:14:48 +08:00
|
|
|
sol::protected_function target
|
|
|
|
= lr.get<sol::protected_function>();
|
2019-05-22 07:17:31 +08:00
|
|
|
sol::bytecode target_bc = target.dump();
|
|
|
|
|
2020-11-20 05:42:02 +08:00
|
|
|
// reload the byte code
|
2019-05-22 07:17:31 +08:00
|
|
|
// in the SECOND state
|
2021-03-06 23:14:48 +08:00
|
|
|
auto result2 = lua2.safe_script(
|
|
|
|
target_bc.as_string_view(), sol::script_pass_on_error);
|
2019-05-22 07:17:31 +08:00
|
|
|
// check if it was done properly
|
2022-09-28 13:56:26 +08:00
|
|
|
SOL_ASSERT(result2.valid());
|
2019-05-22 07:17:31 +08:00
|
|
|
|
|
|
|
// check in the second state if it was valid
|
|
|
|
sol::protected_function pf = lua2["a"];
|
|
|
|
int v = pf(25557);
|
2022-09-28 13:56:26 +08:00
|
|
|
SOL_ASSERT(v == 25557);
|
2019-05-22 07:17:31 +08:00
|
|
|
|
|
|
|
return 0;
|
2022-09-28 13:56:26 +08:00
|
|
|
}
|