summaryrefslogtreecommitdiff
path: root/plugins/MirLua/src/m_core.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/MirLua/src/m_core.cpp')
-rw-r--r--plugins/MirLua/src/m_core.cpp26
1 files changed, 4 insertions, 22 deletions
diff --git a/plugins/MirLua/src/m_core.cpp b/plugins/MirLua/src/m_core.cpp
index 8d388bf8c7..1b4bc8d390 100644
--- a/plugins/MirLua/src/m_core.cpp
+++ b/plugins/MirLua/src/m_core.cpp
@@ -18,7 +18,7 @@ static int core_CreateHookableEvent(lua_State *L)
int HookEventObjParam(void *obj, WPARAM wParam, LPARAM lParam, LPARAM param)
{
- lua_State *L = (lua_State*)obj;
+ lua_State *L = lua_newthread((lua_State*)obj);
int ref = param;
lua_rawgeti(L, LUA_REGISTRYINDEX, ref);
@@ -46,9 +46,7 @@ static int core_HookEvent(lua_State *L)
lua_pushvalue(L, 2);
int ref = luaL_ref(L, LUA_REGISTRYINDEX);
- lua_State *T = lua_newthread(L);
-
- HANDLE hEvent = HookEventObjParam(name, HookEventObjParam, T, ref);
+ HANDLE hEvent = HookEventObjParam(name, HookEventObjParam, g_mLua, ref);
if (hEvent == NULL)
{
luaL_unref(L, LUA_REGISTRYINDEX, ref);
@@ -57,9 +55,6 @@ static int core_HookEvent(lua_State *L)
return 1;
}
- lua_rawsetp(L, LUA_REGISTRYINDEX, hEvent);
- lua_pushlightuserdata(L, hEvent);
-
return 1;
}
@@ -69,11 +64,6 @@ static int core_UnhookEvent(lua_State *L)
HANDLE hEvent = lua_touserdata(L, 1);
int res = UnhookEvent(hEvent);
- if (!res)
- {
- lua_pushnil(L);
- lua_rawsetp(L, LUA_REGISTRYINDEX, hEvent);
- }
lua_pushboolean(L, !res);
return 1;
@@ -107,7 +97,7 @@ static int core_DestroyHookableEvent(lua_State *L)
INT_PTR CreateServiceFunctionObjParam(void *obj, WPARAM wParam, LPARAM lParam, LPARAM param)
{
- lua_State *L = (lua_State*)obj;
+ lua_State *L = lua_newthread((lua_State*)obj);
int ref = param;
lua_rawgeti(L, LUA_REGISTRYINDEX, ref);
@@ -130,9 +120,7 @@ static int core_CreateServiceFunction(lua_State *L)
lua_pushvalue(L, 2);
int ref = luaL_ref(L, LUA_REGISTRYINDEX);
- lua_State *T = lua_newthread(L);
-
- HANDLE hService = CreateServiceFunctionObjParam(name, CreateServiceFunctionObjParam, T, ref);
+ HANDLE hService = CreateServiceFunctionObjParam(name, CreateServiceFunctionObjParam, g_mLua, ref);
if (!hService)
{
luaL_unref(L, LUA_REGISTRYINDEX, ref);
@@ -140,9 +128,6 @@ static int core_CreateServiceFunction(lua_State *L)
return 1;
}
- lua_rawsetp(L, LUA_REGISTRYINDEX, hService);
- lua_pushlightuserdata(L, hService);
-
return 1;
}
@@ -175,9 +160,6 @@ static int core_DestroyServiceFunction(lua_State *L)
DestroyServiceFunction(hService);
- lua_pushnil(L);
- lua_rawsetp(L, LUA_REGISTRYINDEX, hService);
-
return 0;
}