2019-05-22 07:17:31 +08:00
|
|
|
#define SOL_ALL_SAFETIES_ON 1
|
2018-09-28 13:27:38 +08:00
|
|
|
#include <sol/sol.hpp>
|
2017-08-07 00:20:32 +08:00
|
|
|
|
|
|
|
|
2021-03-06 14:03:23 +08:00
|
|
|
int main(int, char*[]) {
|
2017-08-07 00:20:32 +08:00
|
|
|
sol::state lua;
|
|
|
|
lua.script("function func (a, b) return (a + b) * 2 end");
|
|
|
|
|
|
|
|
sol::reference func_ref = lua["func"];
|
|
|
|
|
|
|
|
// for some reason, you need to use the low-level API
|
|
|
|
func_ref.push(); // function on stack now
|
|
|
|
|
|
|
|
// maybe this is in a lua_CFunction you bind,
|
|
|
|
// or maybe you're trying to work with a pre-existing system
|
|
|
|
// maybe you've used a custom lua_load call, or you're working
|
|
|
|
// with state_view's load(lua_Reader, ...) call...
|
|
|
|
// here's a little bit of how you can work with the stack
|
|
|
|
lua_State* L = lua.lua_state();
|
2020-01-08 23:46:22 +08:00
|
|
|
sol::stack_aligned_unsafe_function func(L, -1);
|
2017-08-07 00:20:32 +08:00
|
|
|
lua_pushinteger(L, 5); // argument 1, using plain API
|
|
|
|
lua_pushinteger(L, 6); // argument 2
|
2020-01-08 23:46:22 +08:00
|
|
|
|
|
|
|
// take 2 arguments from the top,
|
2017-08-07 00:20:32 +08:00
|
|
|
// and use "stack_aligned_function" to call
|
|
|
|
int result = func(sol::stack_count(2));
|
|
|
|
|
|
|
|
// make sure everything is clean
|
2021-03-06 14:03:23 +08:00
|
|
|
sol_c_assert(result == 22);
|
|
|
|
sol_c_assert(lua.stack_top() == 0); // stack is empty/balanced
|
2017-08-07 00:20:32 +08:00
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|