From 7c2f33bdf37de7acf9b0728a115377081344db1c Mon Sep 17 00:00:00 2001 From: chai Date: Sun, 11 Nov 2018 20:18:26 +0800 Subject: =?UTF-8?q?*=E6=A0=BC=E5=BC=8F=E5=8C=96?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/lua/common/je_lua_shared.hpp | 54 ++++++++++++++++------------------------ 1 file changed, 22 insertions(+), 32 deletions(-) (limited to 'src/lua/common/je_lua_shared.hpp') diff --git a/src/lua/common/je_lua_shared.hpp b/src/lua/common/je_lua_shared.hpp index 7ad7c1d..53f557a 100644 --- a/src/lua/common/je_lua_shared.hpp +++ b/src/lua/common/je_lua_shared.hpp @@ -11,46 +11,45 @@ namespace JinEngine public: void retain() { - ++(*count); + ++count; } void release() { - if (--(*count) <= 0) + if (--count <= 0) delete this; } // object type string const char* const type; - void setUserdata(void* data) - { - userdata = data; - } + void setUserdata(void* data) + { + userdata = data; + } - void* getUserdata() - { - return userdata; - } + void* getUserdata() + { + return userdata; + } protected: SharedBase(void* obj, const char* t) - : object(obj) + : count(1) + , object(obj) , type(t) { - count = new int(1); } SharedBase(const SharedBase&); virtual ~SharedBase() { - } void* object; - int* count; - void* userdata; + int count; + void* userdata; }; template @@ -62,35 +61,26 @@ namespace JinEngine { } - ~Shared() - { - T* obj = static_cast(object); - delete obj; - } - T* operator->() { - return static_cast(object); + return (T*)object; } T* getObject() { - return static_cast(object); + return (T*)object; } - T* operator &() - { - return static_cast(object); - } + private: + // Disable copy constructor. + Shared(const Shared& shared); - T& operator *() + ~Shared() { - return *(static_cast(object)); + T* obj = static_cast(object); + delete obj; } - private: - Shared(const Shared& ref); - }; } -- cgit v1.1-26-g67d0