|
|
||
|
Doug Rogers wrote: (...)
int l_event_new(lua_State* L, const char* event_name)
{
lua_newtable(L); // local obj = {}
luaL_getmetatable(L, "Event.mt"); // setmetatable(obj, mt)
lua_setmetatable(L, -2);
lua_pushstring(L, event_name); // obj.name = event_name
lua_settable(L, -2, "name");
return 1; // return obj
}
Shouldn't it be something like...
int l_event_new( lua_State* L )
{
luaL_checkstr(L, 1);
lua_newtable(L); // local obj = {}
luaL_getmetatable(L, "Event.mt"); // setmetatable(obj, mt)
lua_setmetatable(L, -2);
lua_pushvalue(L, 1); // obj.name = event_name
lua_settable(L, -2, "name");
return 1; // return obj
}
?
--rb