mirror of https://github.com/axmolengine/axmol.git
* tolua_pushusertype_ccobject() & tolua_remove_ccobject_by_refid() return errcode
This commit is contained in:
parent
7e170c7517
commit
2ece926122
|
@ -17,12 +17,12 @@ TOLUA_API void tolua_prepare_ccobject_table(lua_State* L)
|
||||||
lua_rawset(L, LUA_REGISTRYINDEX);
|
lua_rawset(L, LUA_REGISTRYINDEX);
|
||||||
}
|
}
|
||||||
|
|
||||||
TOLUA_API void tolua_pushusertype_ccobject(lua_State* L, int refid, int* p_refid, void* ptr, const char* type)
|
TOLUA_API int tolua_pushusertype_ccobject(lua_State* L, int refid, int* p_refid, void* ptr, const char* type)
|
||||||
{
|
{
|
||||||
if (ptr == NULL || p_refid == NULL)
|
if (ptr == NULL || p_refid == NULL)
|
||||||
{
|
{
|
||||||
lua_pushnil(L);
|
lua_pushnil(L);
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (*p_refid == 0)
|
if (*p_refid == 0)
|
||||||
|
@ -42,16 +42,16 @@ TOLUA_API void tolua_pushusertype_ccobject(lua_State* L, int refid, int* p_refid
|
||||||
lua_pushstring(L, type); /* stack: refid_type refid type */
|
lua_pushstring(L, type); /* stack: refid_type refid type */
|
||||||
lua_rawset(L, -3); /* refid_type[refid] = type, stack: refid_type */
|
lua_rawset(L, -3); /* refid_type[refid] = type, stack: refid_type */
|
||||||
lua_pop(L, 1); /* stack: - */
|
lua_pop(L, 1); /* stack: - */
|
||||||
|
// printf("[LUA] push CCObject - refid: %d, ptr: %x, type: %s\n", *p_refid, (int)ptr, type);
|
||||||
//printf("[LUA] push CCObject - refid: %d, ptr: %x, type: %s\n", *p_refid, (int)ptr, type);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
tolua_pushusertype(L, ptr, type);
|
tolua_pushusertype(L, ptr, type);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
TOLUA_API void tolua_remove_ccobject_by_refid(lua_State* L, int refid)
|
TOLUA_API int tolua_remove_ccobject_by_refid(lua_State* L, int refid)
|
||||||
{
|
{
|
||||||
if (refid == 0) return;
|
if (refid == 0) return -1;
|
||||||
|
|
||||||
// get ptr from tolua_refid_ptr_mapping
|
// get ptr from tolua_refid_ptr_mapping
|
||||||
lua_pushstring(L, TOLUA_REFID_PTR_MAPPING);
|
lua_pushstring(L, TOLUA_REFID_PTR_MAPPING);
|
||||||
|
@ -65,7 +65,7 @@ TOLUA_API void tolua_remove_ccobject_by_refid(lua_State* L, int refid)
|
||||||
lua_pop(L, 1);
|
lua_pop(L, 1);
|
||||||
// Lua stack has closed, C++ object not in Lua.
|
// Lua stack has closed, C++ object not in Lua.
|
||||||
//printf("[LUA ERROR] remove CCObject with NULL ptr, refid: %d\n", refid);
|
//printf("[LUA ERROR] remove CCObject with NULL ptr, refid: %d\n", refid);
|
||||||
return;
|
return -2;
|
||||||
}
|
}
|
||||||
|
|
||||||
// remove ptr from tolua_refid_ptr_mapping
|
// remove ptr from tolua_refid_ptr_mapping
|
||||||
|
@ -84,7 +84,7 @@ TOLUA_API void tolua_remove_ccobject_by_refid(lua_State* L, int refid)
|
||||||
{
|
{
|
||||||
lua_pop(L, 2);
|
lua_pop(L, 2);
|
||||||
printf("[LUA ERROR] remove CCObject with NULL type, refid: %d, ptr: %x\n", refid, (int)ptr);
|
printf("[LUA ERROR] remove CCObject with NULL type, refid: %d, ptr: %x\n", refid, (int)ptr);
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* type = lua_tostring(L, -1);
|
const char* type = lua_tostring(L, -1);
|
||||||
|
@ -115,7 +115,7 @@ TOLUA_API void tolua_remove_ccobject_by_refid(lua_State* L, int refid)
|
||||||
// Lua object has released (GC), C++ object not in ubox.
|
// Lua object has released (GC), C++ object not in ubox.
|
||||||
//printf("[LUA ERROR] remove CCObject with NULL ubox, refid: %d, ptr: %x, type: %s\n", refid, (int)ptr, type);
|
//printf("[LUA ERROR] remove CCObject with NULL ubox, refid: %d, ptr: %x, type: %s\n", refid, (int)ptr, type);
|
||||||
lua_pop(L, 3);
|
lua_pop(L, 3);
|
||||||
return;
|
return -3;
|
||||||
}
|
}
|
||||||
|
|
||||||
void** ud = (void**)lua_touserdata(L, -1);
|
void** ud = (void**)lua_touserdata(L, -1);
|
||||||
|
@ -124,7 +124,7 @@ TOLUA_API void tolua_remove_ccobject_by_refid(lua_State* L, int refid)
|
||||||
{
|
{
|
||||||
printf("[LUA ERROR] remove CCObject with NULL userdata, refid: %d, ptr: %x, type: %s\n", refid, (int)ptr, type);
|
printf("[LUA ERROR] remove CCObject with NULL userdata, refid: %d, ptr: %x, type: %s\n", refid, (int)ptr, type);
|
||||||
lua_pop(L, 2);
|
lua_pop(L, 2);
|
||||||
return;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
// clean userdata
|
// clean userdata
|
||||||
|
@ -135,7 +135,8 @@ TOLUA_API void tolua_remove_ccobject_by_refid(lua_State* L, int refid)
|
||||||
lua_rawset(L, -3); /* ubox[ptr] = nil, stack: mt ubox */
|
lua_rawset(L, -3); /* ubox[ptr] = nil, stack: mt ubox */
|
||||||
|
|
||||||
lua_pop(L, 2);
|
lua_pop(L, 2);
|
||||||
//printf("[LUA] remove CCObject, refid: %d, ptr: %x, type: %s\n", refid, (int)ptr, type);
|
// printf("[LUA] remove CCObject, refid: %d, ptr: %x, type: %s\n", refid, (int)ptr, type);
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
TOLUA_API int tolua_ref_function(lua_State* L, int lo, int def)
|
TOLUA_API int tolua_ref_function(lua_State* L, int lo, int def)
|
||||||
|
|
|
@ -8,14 +8,14 @@
|
||||||
extern "C"
|
extern "C"
|
||||||
{
|
{
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define TOLUA_REFID_PTR_MAPPING "tolua_refid_ptr_mapping"
|
#define TOLUA_REFID_PTR_MAPPING "tolua_refid_ptr_mapping"
|
||||||
#define TOLUA_REFID_TYPE_MAPPING "tolua_refid_type_mapping"
|
#define TOLUA_REFID_TYPE_MAPPING "tolua_refid_type_mapping"
|
||||||
#define TOLUA_REFID_FUNC_MAPPING "tolua_refid_func_mapping"
|
#define TOLUA_REFID_FUNC_MAPPING "tolua_refid_func_mapping"
|
||||||
|
|
||||||
TOLUA_API void tolua_prepare_ccobject_table(lua_State* L);
|
TOLUA_API void tolua_prepare_ccobject_table(lua_State* L);
|
||||||
TOLUA_API void tolua_pushusertype_ccobject(lua_State* L, int uid, int* p_refid, void* ptr, const char* type);
|
TOLUA_API int tolua_pushusertype_ccobject(lua_State* L, int uid, int* p_refid, void* ptr, const char* type);
|
||||||
TOLUA_API void tolua_remove_ccobject_by_refid(lua_State* L, int refid);
|
TOLUA_API int tolua_remove_ccobject_by_refid(lua_State* L, int refid);
|
||||||
|
|
||||||
TOLUA_API int tolua_ref_function(lua_State* L, int lo, int def);
|
TOLUA_API int tolua_ref_function(lua_State* L, int lo, int def);
|
||||||
TOLUA_API void tolua_remove_function_by_refid(lua_State* L, int refid);
|
TOLUA_API void tolua_remove_function_by_refid(lua_State* L, int refid);
|
||||||
|
|
Loading…
Reference in New Issue