forked from LeenkxTeam/LNXSDK
184 lines
5.7 KiB
C++
184 lines
5.7 KiB
C++
#ifndef HX_NATIVE_INCLUDED_H
|
|
#define HX_NATIVE_INCLUDED_H
|
|
/*
|
|
*
|
|
This file is in the public domain, and can be freely distributed.
|
|
|
|
*/
|
|
|
|
#include <stdio.h>
|
|
|
|
#ifndef HXCPP_H
|
|
#define HXCPP_H
|
|
typedef double Float;
|
|
typedef void Void;
|
|
|
|
//typedef int Int;
|
|
//typedef bool Bool;
|
|
|
|
#ifndef HXCPP_CLASS_ATTRIBUTES
|
|
#define HXCPP_CLASS_ATTRIBUTES
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define HX_DECLARE_NATIVE0(klass) \
|
|
class klass;
|
|
#define HX_DECLARE_NATIVE1(ns1,klass) namespace ns1 { HX_DECLARE_NATIVE0(klass) }
|
|
#define HX_DECLARE_NATIVE2(ns2,ns1,klass) namespace ns2 { HX_DECLARE_NATIVE1(ns1,klass) }
|
|
#define HX_DECLARE_NATIVE3(ns3,ns2,ns1,klass) namespace ns3 { HX_DECLARE_NATIVE2(ns2,ns1,klass) }
|
|
#define HX_DECLARE_NATIVE4(ns4,ns3,ns2,ns1,klass) namespace ns4 { HX_DECLARE_NATIVE3(ns3,ns2,ns1,klass) }
|
|
#define HX_DECLARE_NATIVE5(ns5,ns4,ns3,ns2,ns1,klass) namespace ns5 { HX_DECLARE_NATIVE4(ns4,ns3,ns2,ns1,klass) }
|
|
#define HX_DECLARE_NATIVE6(ns6,ns5,ns4,ns3,ns2,ns1,klass) namespace ns6 { HX_DECLARE_NATIVE5(ns5,ns4,ns3,ns2,ns1,klass) }
|
|
#define HX_DECLARE_NATIVE7(ns7,ns6,ns5,ns4,ns3,ns2,ns1,klass) namespace ns7 { HX_DECLARE_NATIVE6(ns6,ns5,ns4,ns3,ns2,ns1,klass) }
|
|
#define HX_DECLARE_NATIVE8(ns8,ns7,ns6,ns5,ns4,ns3,ns2,ns1,klass) namespace ns8 { HX_DECLARE_NATIVE7(ns7,ns6,ns5,ns4,ns3,ns2,ns1,klass) }
|
|
#define HX_DECLARE_NATIVE9(ns9,ns8,ns7,ns6,ns5,ns4,ns3,ns2,ns1,klass) namespace ns9 { HX_DECLARE_NATIVE8(ns8,ns7,ns6,ns5,ns4,ns3,ns2,ns1,klass) }
|
|
|
|
|
|
|
|
|
|
|
|
namespace hx
|
|
{
|
|
class Object;
|
|
|
|
class HXCPP_CLASS_ATTRIBUTES NativeInterface
|
|
{
|
|
public:
|
|
virtual hx::Object *__GetRealObject() = 0;
|
|
void _hx_addRef();
|
|
void _hx_decRef();
|
|
};
|
|
|
|
template<typename T>
|
|
class Native
|
|
{
|
|
public:
|
|
T ptr;
|
|
|
|
Native () : ptr(0) { }
|
|
Native (T inPtr) : ptr(inPtr) { }
|
|
Native (const Native<T> &inNative) : ptr(inNative.ptr) { }
|
|
#ifdef CPP_VARIANT_ONCE_H
|
|
Native (const cpp::Variant &inVariant) {
|
|
hx::Object *obj = inVariant.asObject();
|
|
ptr = obj ? (T)inVariant.valObject->__GetHandle() : 0;
|
|
}
|
|
#endif
|
|
|
|
inline Native &operator=(T inPtr) { ptr=inPtr; return *this; }
|
|
inline Native &operator=(const Native<T> &inNative) { ptr=inNative.ptr; return *this; }
|
|
#ifdef HX_NULL_H
|
|
inline Native &operator=(const ::null &) { ptr=0; return *this; }
|
|
#endif
|
|
inline T operator->() const { return ptr; }
|
|
|
|
inline operator T() const { return ptr; }
|
|
|
|
template<typename O>
|
|
inline bool operator==(const Native<O> &inOther) const
|
|
{ return ptr == inOther.ptr; }
|
|
template<typename O>
|
|
inline bool operator!=(const Native<O> &inOther) const
|
|
{ return ptr != inOther.ptr; }
|
|
|
|
};
|
|
|
|
HXCPP_CLASS_ATTRIBUTES const char *Init();
|
|
HXCPP_CLASS_ATTRIBUTES void PushTopOfStack(void *);
|
|
HXCPP_CLASS_ATTRIBUTES void PopTopOfStack();
|
|
HXCPP_CLASS_ATTRIBUTES void GcAddOffsetRoot(void *inRoot, int inOffset);
|
|
HXCPP_CLASS_ATTRIBUTES void GcSetOffsetRoot(void *inRoot, int inOffset);
|
|
HXCPP_CLASS_ATTRIBUTES void GcRemoveOffsetRoot(void *inRoot);
|
|
HXCPP_CLASS_ATTRIBUTES int GcGetThreadAttachedCount();
|
|
|
|
class HXCPP_CLASS_ATTRIBUTES NativeAttach
|
|
{
|
|
bool isAttached;
|
|
public:
|
|
NativeAttach(bool inAttach=true)
|
|
{
|
|
isAttached = false;
|
|
if (inAttach)
|
|
attach();
|
|
}
|
|
~NativeAttach()
|
|
{
|
|
detach();
|
|
}
|
|
void attach()
|
|
{
|
|
if (!isAttached)
|
|
{
|
|
isAttached = true;
|
|
hx::PushTopOfStack(this);
|
|
}
|
|
}
|
|
void detach()
|
|
{
|
|
if (isAttached)
|
|
{
|
|
isAttached = false;
|
|
hx::PopTopOfStack();
|
|
}
|
|
}
|
|
};
|
|
|
|
template<typename T>
|
|
class Ref
|
|
{
|
|
public:
|
|
T ptr;
|
|
|
|
Ref() : ptr(0) { }
|
|
Ref(const T &inT) : ptr(0) { setPtr(inT); }
|
|
template<typename O>
|
|
inline Ref(const Native<O> &inNative) : ptr(0) { setPtr(inNative.ptr); }
|
|
template<typename O>
|
|
inline Ref(const Ref<O> &inRef) : ptr(0) { setPtr(inRef.ptr); }
|
|
|
|
~Ref() { setPtr(0); }
|
|
void setPtr(T inPtr)
|
|
{
|
|
hx::Object *old = ptr ? ptr->__GetRealObject() : 0;
|
|
int oldOffset = old ? (int)(size_t)((char *)inPtr - (char *)old) : 0;
|
|
hx::Object *next = inPtr ? inPtr->__GetRealObject() : 0;
|
|
int nextOffset = next ? (int)(size_t)((char *)inPtr - (char *)next) : 0;
|
|
|
|
ptr = inPtr;
|
|
if (next)
|
|
{
|
|
if (!old)
|
|
GcAddOffsetRoot(&ptr, nextOffset);
|
|
else if (oldOffset!=nextOffset)
|
|
GcSetOffsetRoot(&ptr, nextOffset);
|
|
}
|
|
else if (old)
|
|
GcRemoveOffsetRoot(&ptr);
|
|
}
|
|
|
|
inline Ref &operator=(const T &inPtr) { setPtr(inPtr); return *this; }
|
|
template<typename O>
|
|
inline Ref &operator=(const Native<O> &inNative) { setPtr(inNative.ptr); return *this; }
|
|
template<typename O>
|
|
inline Ref &operator=(const Ref<O> &inRef) { setPtr(inRef.ptr); return *this; }
|
|
|
|
template<typename O>
|
|
inline bool operator==(const Ref<O> &inOther) const
|
|
{ return ptr == inOther.ptr; }
|
|
template<typename O>
|
|
inline bool operator!=(const Ref<O> &inOther) const
|
|
{ return ptr != inOther.ptr; }
|
|
|
|
T operator->() { return ptr; }
|
|
};
|
|
|
|
#define HX_NATIVE_IMPLEMENTATION hx::Object *__GetRealObject() { return this; }
|
|
#define HX_EXTERN_NATIVE_IMPLEMENTATION hx::Object *__GetRealObject() { return 0; }
|
|
}
|
|
|
|
#endif
|
|
|