2019-05-21 19:17:31 -04:00
|
|
|
#define SOL_ALL_SAFETIES_ON 1
|
2018-09-27 22:27:38 -07:00
|
|
|
#include <sol/sol.hpp>
|
2017-04-20 22:31:59 -04:00
|
|
|
|
|
|
|
|
2017-05-07 10:16:47 -04:00
|
|
|
// NOTE:
|
|
|
|
// There are TWO ways to retrieve the "this"
|
2021-03-06 10:14:48 -05:00
|
|
|
// object from calls, when it comes to constructors and regular
|
|
|
|
// member functions please pay attention to both: this is a
|
|
|
|
// low-level operation!
|
2017-05-07 10:16:47 -04:00
|
|
|
|
2017-04-20 22:31:59 -04:00
|
|
|
int main() {
|
|
|
|
struct thing {
|
|
|
|
|
|
|
|
thing(sol::this_state ts) {
|
|
|
|
lua_State* L = ts;
|
|
|
|
// references the object that called this function
|
|
|
|
// in constructors:
|
2019-11-29 13:08:41 -05:00
|
|
|
sol::stack_object selfobj(L, 1);
|
2017-04-20 22:31:59 -04:00
|
|
|
|
|
|
|
// definitely the same
|
|
|
|
thing& self = selfobj.as<thing>();
|
2021-03-06 01:03:23 -05:00
|
|
|
sol_c_assert(&self == this);
|
2017-04-20 22:31:59 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void func(sol::this_state ts) const {
|
|
|
|
lua_State* L = ts;
|
|
|
|
// references the object that called this function
|
|
|
|
// in regular member functions:
|
|
|
|
sol::stack_object selfobj(L, 1);
|
|
|
|
// "1" is the bottom of the Lua stack
|
|
|
|
// 2 is one up, so on and so forth...
|
|
|
|
thing& self = selfobj.as<thing>();
|
|
|
|
|
|
|
|
// definitely the same
|
2021-03-06 01:03:23 -05:00
|
|
|
sol_c_assert(&self == this);
|
2017-04-20 22:31:59 -04:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
sol::state lua;
|
|
|
|
lua.open_libraries(sol::lib::base);
|
|
|
|
|
2021-03-06 10:14:48 -05:00
|
|
|
lua.new_usertype<thing>("thing",
|
|
|
|
sol::constructors<thing(sol::this_state)>(),
|
|
|
|
"func",
|
|
|
|
&thing::func);
|
2017-04-20 22:31:59 -04:00
|
|
|
|
|
|
|
lua.script(R"(
|
|
|
|
obj = thing.new()
|
|
|
|
obj:func()
|
|
|
|
)");
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|