aboutsummaryrefslogtreecommitdiff
path: root/src/lua/common
diff options
context:
space:
mode:
authorchai <chaifix@163.com>2018-11-11 20:18:26 +0800
committerchai <chaifix@163.com>2018-11-11 20:18:26 +0800
commit7c2f33bdf37de7acf9b0728a115377081344db1c (patch)
treecd82766dd4d1d84229ae610e69225bb48b3001b9 /src/lua/common
parente92caa97329016d012b46b9d37e1b2c3b613a8f2 (diff)
*格式化
Diffstat (limited to 'src/lua/common')
-rw-r--r--src/lua/common/je_lua_proxy.h37
-rw-r--r--src/lua/common/je_lua_shared.hpp54
2 files changed, 44 insertions, 47 deletions
diff --git a/src/lua/common/je_lua_proxy.h b/src/lua/common/je_lua_proxy.h
index 56e5fee..b476aa6 100644
--- a/src/lua/common/je_lua_proxy.h
+++ b/src/lua/common/je_lua_proxy.h
@@ -1,6 +1,8 @@
#ifndef __JIN_COMMON_PROXY_H
#define __JIN_COMMON_PROXY_H
+#include "../luax.h"
+
#include "je_lua_shared.hpp"
namespace JinEngine
@@ -11,56 +13,61 @@ namespace JinEngine
class Proxy
{
public:
- void bind(SharedBase* ref)
+ void bind(SharedBase* shared)
{
- if (ref == nullptr)
+ if (shared == nullptr)
return;
- shared = ref;
+ reference = shared;
}
void release()
{
- if (shared != nullptr)
+ if (reference != nullptr)
{
- shared->release();
- shared = nullptr;
+ reference->release();
+ reference = nullptr;
}
}
void retain()
{
- if (shared != nullptr)
- shared->retain();
+ if (reference != nullptr)
+ reference->retain();
}
void setUserdata(void* data)
{
- if (shared != nullptr)
- shared->setUserdata(data);
+ if (reference != nullptr)
+ reference->setUserdata(data);
}
template<class T>
Shared<T>& getShared()
{
- return *(static_cast<Shared<T>*>(shared));
+ return *(Shared<T>*) reference;
}
template<class T>
T* getObject()
{
- Shared<T>& ref = getShared<T>();
- return ref.getObject();
+ Shared<T>& shared = getShared<T>();
+ return shared.getObject();
}
const char* getObjectType()
{
- return shared->type;
+ return reference->type;
}
- SharedBase* shared;
+ SharedBase* reference;
};
+ inline Proxy* luax_newinstance(lua_State* L, const char* type)
+ {
+ return static_cast<Proxy*>(luax_newinstance(L, type, sizeof(Proxy)));
+ }
+
} // namespace Lua
} // namespace JinEngine
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<class T>
@@ -62,35 +61,26 @@ namespace JinEngine
{
}
- ~Shared()
- {
- T* obj = static_cast<T*>(object);
- delete obj;
- }
-
T* operator->()
{
- return static_cast<T*>(object);
+ return (T*)object;
}
T* getObject()
{
- return static_cast<T*>(object);
+ return (T*)object;
}
- T* operator &()
- {
- return static_cast<T*>(object);
- }
+ private:
+ // Disable copy constructor.
+ Shared(const Shared<T>& shared);
- T& operator *()
+ ~Shared()
{
- return *(static_cast<T*>(object));
+ T* obj = static_cast<T*>(object);
+ delete obj;
}
- private:
- Shared(const Shared<T>& ref);
-
};
}