From 6016ece202eef94ed76bd20d4f7879ccc71cc2e6 Mon Sep 17 00:00:00 2001 From: chai Date: Tue, 12 Mar 2019 23:08:31 +0800 Subject: *luax --- Source/3rdParty/Luax/luax_class.cpp | 32 +++++++++++++++++++++++++++----- 1 file changed, 27 insertions(+), 5 deletions(-) (limited to 'Source/3rdParty/Luax/luax_class.cpp') diff --git a/Source/3rdParty/Luax/luax_class.cpp b/Source/3rdParty/Luax/luax_class.cpp index 99da697..52cf6b7 100644 --- a/Source/3rdParty/Luax/luax_class.cpp +++ b/Source/3rdParty/Luax/luax_class.cpp @@ -1,27 +1,33 @@ #include "luax_state.h" #include "luax_class.h" +#include "luax_runtime.h" namespace Luax { LuaxClass::LuaxClass() - : mRefCount(1) // 构造时默认有一个引用 + : mRC(1) // 构造时默认有一个引用 + , mSafer(false) { } LuaxClass::~LuaxClass() { + assert(mSafer); } void LuaxClass::Retain() { - ++mRefCount; + ++mRC; } void LuaxClass::Release() { - if (--mRefCount <= 0) + if (--mRC <= 0) + { + mSafer = true; // 打开析构safer delete this; + } } bool LuaxClass::PushLuaUserdata(LuaxState& state) @@ -29,9 +35,20 @@ namespace Luax return true; } - void LuaxClass::BindToLua(LuaxState& state) + void LuaxClass::BindFactoryToLua(LuaxState& state) + { + //assert(!mUserdata); + + // + state.PushPtrUserData(this); + + lua_newtable(state); // ref table + lua_newtable(state); // member table + + } + + void LuaxClass::BindSingletonToLua(LuaxState& state) { - assert(!mUserdata); } @@ -47,4 +64,9 @@ namespace Luax return 0; } + int LuaxClass::l_ToString(lua_State* L) + { + return 0; + } + } \ No newline at end of file -- cgit v1.1-26-g67d0