forked from LeenkxTeam/LNXSDK
724 lines
19 KiB
C
724 lines
19 KiB
C
#ifndef HX_CFFI_NEKO_LOADER_H
|
|
#define HX_CFFI_NEKO_LOADER_H
|
|
|
|
//-------- NEKO Interface -----------------------------------------------------
|
|
namespace
|
|
{
|
|
|
|
#include <hx/NekoFunc.h>
|
|
|
|
|
|
void *sNekoDllHandle = 0;
|
|
|
|
void *LoadNekoFunc(const char *inName)
|
|
{
|
|
#ifdef HX_WINRT
|
|
return 0;
|
|
#else
|
|
static bool tried = false;
|
|
if (tried && !sNekoDllHandle)
|
|
return 0;
|
|
tried = true;
|
|
|
|
if (!sNekoDllHandle)
|
|
{
|
|
#ifdef HX_WINDOWS
|
|
sNekoDllHandle = GetModuleHandleA("neko.dll");
|
|
#else
|
|
sNekoDllHandle = dlopen("libneko." NEKO_EXT, RTLD_NOW);
|
|
// The debian package creates libneko.so.0 without libneko.so...
|
|
// The fedora/openSUSE rpm packages create libneko.so.1...
|
|
if (!sNekoDllHandle)
|
|
sNekoDllHandle = dlopen("libneko." NEKO_EXT ".0", RTLD_NOW);
|
|
if (!sNekoDllHandle)
|
|
sNekoDllHandle = dlopen("libneko." NEKO_EXT ".1", RTLD_NOW);
|
|
if (!sNekoDllHandle)
|
|
sNekoDllHandle = dlopen("libneko." NEKO_EXT ".2", RTLD_NOW);
|
|
#endif
|
|
|
|
if (!sNekoDllHandle)
|
|
{
|
|
fprintf(stderr,"Could not link to neko.\n");
|
|
return 0;
|
|
}
|
|
}
|
|
|
|
|
|
#ifdef HX_WINDOWS
|
|
void *result = (void *)GetProcAddress((HMODULE)sNekoDllHandle,inName);
|
|
#else
|
|
void *result = dlsym(sNekoDllHandle,inName);
|
|
#endif
|
|
|
|
//printf(" %s = %p\n", inName, result );
|
|
return result;
|
|
#endif // !HX_WINRT
|
|
}
|
|
|
|
|
|
static int __a_id = 0;
|
|
static int __s_id = 0;
|
|
static int b_id = 0;
|
|
static int length_id = 0;
|
|
static int push_id = 0;
|
|
|
|
neko_value *gNeko2HaxeString = 0;
|
|
neko_value *gNekoNewArray = 0;
|
|
neko_value gNekoNull = 0;
|
|
neko_value gNekoTrue = 0;
|
|
neko_value gNekoFalse = 0;
|
|
|
|
|
|
namespace
|
|
{
|
|
void CheckInitDynamicNekoLoader()
|
|
{
|
|
if (!gNekoNull)
|
|
{
|
|
printf("Haxe code is missing a call to cpp.Prime.nekoInit().\n");
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
|
|
|
|
*/
|
|
|
|
void *DynamicNekoLoader(const char *inName);
|
|
|
|
typedef neko_value (*alloc_object_func)(neko_value);
|
|
typedef neko_value (*alloc_string_func)(const char *);
|
|
typedef neko_value (*alloc_abstract_func)(neko_vkind,void *);
|
|
typedef neko_value (*val_call1_func)(neko_value,neko_value);
|
|
typedef neko_value (*val_field_func)(neko_value,int);
|
|
typedef neko_value (*alloc_float_func)(double);
|
|
typedef void (*alloc_field_func)(neko_value,int,neko_value);
|
|
typedef neko_value *(*alloc_root_func)(int);
|
|
typedef char *(*alloc_private_func)(int);
|
|
typedef neko_value (*copy_string_func)(const char *,int);
|
|
typedef int (*val_id_func)(const char *);
|
|
typedef neko_buffer (*alloc_buffer_func)(const char *);
|
|
typedef neko_value (*val_buffer_func)(neko_buffer);
|
|
typedef void (*buffer_append_sub_func)(neko_buffer,const char *,int);
|
|
typedef void (*fail_func)(neko_value,const char *,int);
|
|
typedef neko_value (*alloc_array_func)(unsigned int);
|
|
typedef void (*val_gc_func)(neko_value,void *);
|
|
typedef void (*val_ocall1_func)(neko_value,int,neko_value);
|
|
typedef neko_value (*alloc_empty_string_func)(int);
|
|
|
|
static alloc_object_func dyn_alloc_object = 0;
|
|
static alloc_string_func dyn_alloc_string = 0;
|
|
static alloc_abstract_func dyn_alloc_abstract = 0;
|
|
static val_call1_func dyn_val_call1 = 0;
|
|
static val_field_func dyn_val_field = 0;
|
|
static alloc_field_func dyn_alloc_field = 0;
|
|
static alloc_float_func dyn_alloc_float = 0;
|
|
static alloc_root_func dyn_alloc_root = 0;
|
|
static alloc_private_func dyn_alloc_private = 0;
|
|
static alloc_private_func dyn_alloc = 0;
|
|
static copy_string_func dyn_copy_string = 0;
|
|
static val_id_func dyn_val_id = 0;
|
|
static alloc_buffer_func dyn_alloc_buffer = 0;
|
|
static val_buffer_func dyn_val_buffer = 0;
|
|
static fail_func dyn_fail = 0;
|
|
static buffer_append_sub_func dyn_buffer_append_sub = 0;
|
|
static alloc_array_func dyn_alloc_array = 0;
|
|
static val_gc_func dyn_val_gc = 0;
|
|
static val_ocall1_func dyn_val_ocall1 = 0;
|
|
static alloc_empty_string_func dyn_alloc_empty_string = 0;
|
|
|
|
|
|
neko_value api_alloc_string(const char *inString)
|
|
{
|
|
CheckInitDynamicNekoLoader();
|
|
neko_value neko_string = dyn_alloc_string(inString);
|
|
if (gNeko2HaxeString)
|
|
return dyn_val_call1(*gNeko2HaxeString,neko_string);
|
|
return neko_string;
|
|
}
|
|
|
|
|
|
char *api_alloc_string_data(const char *inString,int inLength)
|
|
{
|
|
CheckInitDynamicNekoLoader();
|
|
char *result = (char *)dyn_alloc_private(inLength+1);
|
|
memcpy(result,inString,inLength);
|
|
result[inLength]='\0';
|
|
return result;
|
|
}
|
|
|
|
|
|
neko_value api_alloc_raw_string(int inLength)
|
|
{
|
|
CheckInitDynamicNekoLoader();
|
|
return dyn_alloc_empty_string(inLength);
|
|
}
|
|
|
|
|
|
#define NEKO_NOT_IMPLEMENTED(func) dyn_fail(api_alloc_string("NOT Implemented:" func),__FILE__,__LINE__)
|
|
|
|
void * api_empty() { return 0; }
|
|
|
|
bool api_val_bool(neko_value arg1) { return arg1==gNekoTrue; }
|
|
int api_val_int(neko_value arg1) { return neko_val_int(arg1); }
|
|
double api_val_float(neko_value arg1) { return *(double *)( ((char *)arg1) + 4 ); }
|
|
double api_val_number(neko_value arg1) { return neko_val_is_int(arg1) ? neko_val_int(arg1) : api_val_float(arg1); }
|
|
|
|
|
|
neko_value api_alloc_bool(bool arg1) { CheckInitDynamicNekoLoader(); return arg1 ? gNekoTrue : gNekoFalse; }
|
|
neko_value api_alloc_int(int arg1) { return neko_alloc_int(arg1); }
|
|
neko_value api_alloc_empty_object()
|
|
{
|
|
return dyn_alloc_object(gNekoNull);
|
|
}
|
|
|
|
neko_value api_buffer_to_string(neko_buffer arg1)
|
|
{
|
|
neko_value neko_string = dyn_val_buffer(arg1);
|
|
if (gNeko2HaxeString)
|
|
return dyn_val_call1(*gNeko2HaxeString,neko_string);
|
|
return neko_string;
|
|
}
|
|
|
|
|
|
const char * api_val_string(neko_value arg1)
|
|
{
|
|
if (neko_val_is_string(arg1))
|
|
return neko_val_string(arg1);
|
|
|
|
if (neko_val_is_object(arg1))
|
|
{
|
|
neko_value s = dyn_val_field(arg1,__s_id);
|
|
if (neko_val_is_string(s))
|
|
return neko_val_string(s);
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
void api_alloc_field_numeric(neko_value arg1,int arg2, double arg3)
|
|
{
|
|
dyn_alloc_field(arg1, arg2, dyn_alloc_float(arg3) );
|
|
}
|
|
|
|
double api_val_field_numeric(neko_value arg1,int arg2)
|
|
{
|
|
neko_value field = dyn_val_field(arg1, arg2);
|
|
if (neko_val_is_number(field))
|
|
return api_val_number(field);
|
|
if (field==gNekoTrue)
|
|
return 1;
|
|
return 0;
|
|
}
|
|
|
|
|
|
|
|
|
|
int api_val_strlen(neko_value arg1)
|
|
{
|
|
if (neko_val_is_string(arg1))
|
|
return neko_val_strlen(arg1);
|
|
|
|
if (neko_val_is_object(arg1))
|
|
{
|
|
neko_value l = dyn_val_field(arg1,length_id);
|
|
if (neko_val_is_int(l))
|
|
return api_val_int(l);
|
|
}
|
|
return 0;
|
|
}
|
|
void api_buffer_set_size(neko_buffer inBuffer,int inLen) {
|
|
NEKO_NOT_IMPLEMENTED("api_buffer_set_size");
|
|
}
|
|
|
|
|
|
void api_buffer_append_char(neko_buffer inBuffer,int inChar)
|
|
{
|
|
NEKO_NOT_IMPLEMENTED("api_buffer_append_char");
|
|
}
|
|
|
|
|
|
|
|
// Byte arrays - use strings
|
|
neko_buffer api_val_to_buffer(neko_value arg1)
|
|
{
|
|
return (neko_buffer)api_val_string(arg1);
|
|
}
|
|
bool api_val_is_buffer(neko_value arg1) { return neko_val_is_string(arg1); }
|
|
int api_buffer_size(neko_buffer inBuffer) { return neko_val_strlen((neko_value)inBuffer); }
|
|
char * api_buffer_data(neko_buffer inBuffer) { return (char *)api_val_string((neko_value)inBuffer); }
|
|
|
|
char * api_val_dup_string(neko_value inVal)
|
|
{
|
|
int len = api_val_strlen(inVal);
|
|
const char *ptr = api_val_string(inVal);
|
|
char *result = dyn_alloc_private(len+1);
|
|
memcpy(result,ptr,len);
|
|
result[len] = '\0';
|
|
return result;
|
|
}
|
|
|
|
neko_value api_alloc_string_len(const char *inStr,int inLen)
|
|
{
|
|
if (gNeko2HaxeString)
|
|
{
|
|
if (!inStr)
|
|
return dyn_val_call1(*gNeko2HaxeString,api_alloc_raw_string(inLen));
|
|
return dyn_val_call1(*gNeko2HaxeString,dyn_copy_string(inStr,inLen));
|
|
}
|
|
if (!inStr)
|
|
inStr = dyn_alloc_private(inLen);
|
|
return dyn_copy_string(inStr,inLen);
|
|
}
|
|
|
|
neko_buffer api_alloc_buffer_len(int inLen)
|
|
{
|
|
neko_value str=api_alloc_string_len(0,inLen+1);
|
|
char *s=(char *)api_val_string(str);
|
|
memset(s,0,inLen+1);
|
|
return (neko_buffer)str;
|
|
}
|
|
|
|
|
|
|
|
neko_value api_alloc_wstring_len(const wchar_t *inStr,int inLen)
|
|
{
|
|
int len = 0;
|
|
const wchar_t *chars = inStr;
|
|
for(int i=0;i<inLen;i++)
|
|
{
|
|
int c = chars[i];
|
|
if( c <= 0x7F ) len++;
|
|
else if( c <= 0x7FF ) len+=2;
|
|
else if( c <= 0xFFFF ) len+=3;
|
|
else len+= 4;
|
|
}
|
|
|
|
char *result = dyn_alloc_private(len);//+1?
|
|
unsigned char *data = (unsigned char *) &result[0];
|
|
for(int i=0;i<inLen;i++)
|
|
{
|
|
int c = chars[i];
|
|
if( c <= 0x7F )
|
|
*data++ = c;
|
|
else if( c <= 0x7FF )
|
|
{
|
|
*data++ = 0xC0 | (c >> 6);
|
|
*data++ = 0x80 | (c & 63);
|
|
}
|
|
else if( c <= 0xFFFF )
|
|
{
|
|
*data++ = 0xE0 | (c >> 12);
|
|
*data++ = 0x80 | ((c >> 6) & 63);
|
|
*data++ = 0x80 | (c & 63);
|
|
}
|
|
else
|
|
{
|
|
*data++ = 0xF0 | (c >> 18);
|
|
*data++ = 0x80 | ((c >> 12) & 63);
|
|
*data++ = 0x80 | ((c >> 6) & 63);
|
|
*data++ = 0x80 | (c & 63);
|
|
}
|
|
}
|
|
//result[len] = 0;
|
|
|
|
return api_alloc_string_len(result,len);
|
|
}
|
|
|
|
|
|
|
|
const wchar_t *api_val_wstring(neko_value arg1)
|
|
{
|
|
int len = api_val_strlen(arg1);
|
|
|
|
unsigned char *b = (unsigned char *)api_val_string(arg1);
|
|
wchar_t *result = (wchar_t *)dyn_alloc_private((len+1)*sizeof(wchar_t));
|
|
int l = 0;
|
|
|
|
for(int i=0;i<len;)
|
|
{
|
|
int c = b[i++];
|
|
if (c==0) break;
|
|
else if( c < 0x80 )
|
|
{
|
|
result[l++] = c;
|
|
}
|
|
else if( c < 0xE0 )
|
|
result[l++] = ( ((c & 0x3F) << 6) | (b[i++] & 0x7F) );
|
|
else if( c < 0xF0 )
|
|
{
|
|
int c2 = b[i++];
|
|
result[l++] = ( ((c & 0x1F) << 12) | ((c2 & 0x7F) << 6) | ( b[i++] & 0x7F) );
|
|
}
|
|
else
|
|
{
|
|
int c2 = b[i++];
|
|
int c3 = b[i++];
|
|
result[l++] = ( ((c & 0x0F) << 18) | ((c2 & 0x7F) << 12) | ((c3 << 6) & 0x7F) | (b[i++] & 0x7F) );
|
|
}
|
|
}
|
|
result[l] = '\0';
|
|
|
|
return result;
|
|
}
|
|
|
|
|
|
wchar_t * api_val_dup_wstring(neko_value inVal)
|
|
{
|
|
return (wchar_t *)api_val_wstring(inVal);
|
|
}
|
|
|
|
|
|
|
|
int api_val_type(neko_value arg1)
|
|
{
|
|
int t=neko_val_type(arg1);
|
|
|
|
if (t==VAL_OBJECT)
|
|
{
|
|
neko_value __a = dyn_val_field(arg1,__a_id);
|
|
if (neko_val_is_array(__a))
|
|
return valtArray;
|
|
neko_value __s = dyn_val_field(arg1,__s_id);
|
|
if (neko_val_is_string(__s))
|
|
return valtString;
|
|
}
|
|
if (t<7)
|
|
return (hxValueType)t;
|
|
if (t==VAL_ABSTRACT)
|
|
return valtAbstractBase;
|
|
|
|
if (t==VAL_PRIMITIVE || t==VAL_JITFUN)
|
|
return valtFunction;
|
|
if (t==VAL_32_BITS || t==VAL_INT)
|
|
return valtInt;
|
|
return valtNull;
|
|
}
|
|
|
|
neko_value *api_alloc_root()
|
|
{
|
|
return dyn_alloc_root(1);
|
|
}
|
|
|
|
|
|
void * api_val_to_kind(neko_value arg1,neko_vkind arg2)
|
|
{
|
|
neko_vkind k = (neko_vkind)neko_val_kind(arg1);
|
|
if (k!=arg2)
|
|
return 0;
|
|
return neko_val_data(arg1);
|
|
}
|
|
|
|
|
|
int api_alloc_kind()
|
|
{
|
|
static int id = 1;
|
|
int result = id;
|
|
id += 4;
|
|
return result;
|
|
}
|
|
neko_value api_alloc_null()
|
|
{
|
|
CheckInitDynamicNekoLoader();
|
|
return gNekoNull;
|
|
}
|
|
|
|
neko_value api_create_abstract(neko_vkind inKind,int inSize,void *inFinalizer)
|
|
{
|
|
void *data = dyn_alloc(inSize);
|
|
neko_value val = dyn_alloc_abstract(inKind, data);
|
|
dyn_val_gc(val, inFinalizer);
|
|
return val;
|
|
}
|
|
|
|
void api_free_abstract(neko_value inAbstract)
|
|
{
|
|
if (neko_val_is_abstract(inAbstract))
|
|
{
|
|
dyn_val_gc(inAbstract,0);
|
|
neko_val_kind(inAbstract) = 0;
|
|
}
|
|
}
|
|
|
|
|
|
neko_value api_buffer_val(neko_buffer arg1)
|
|
{
|
|
if (neko_val_is_string(arg1))
|
|
return (neko_value)arg1;
|
|
|
|
if (neko_val_is_object(arg1))
|
|
{
|
|
neko_value s = dyn_val_field((neko_value)arg1,__s_id);
|
|
if (neko_val_is_string(s))
|
|
return (neko_value)(s);
|
|
}
|
|
|
|
|
|
return api_alloc_null();
|
|
}
|
|
|
|
|
|
void api_hx_error()
|
|
{
|
|
dyn_fail(dyn_alloc_string("An unknown error has occurred."),"",1);
|
|
}
|
|
|
|
void * api_val_data(neko_value arg1) { return neko_val_data(arg1); }
|
|
|
|
// Array access - generic
|
|
int api_val_array_size(neko_value arg1)
|
|
{
|
|
if (neko_val_is_array(arg1))
|
|
return neko_val_array_size(arg1);
|
|
neko_value l = dyn_val_field(arg1,length_id);
|
|
return neko_val_int(l);
|
|
}
|
|
|
|
|
|
neko_value api_val_array_i(neko_value arg1,int arg2)
|
|
{
|
|
if (neko_val_is_array(arg1))
|
|
return neko_val_array_ptr(arg1)[arg2];
|
|
return neko_val_array_ptr(dyn_val_field(arg1,__a_id))[arg2];
|
|
}
|
|
|
|
void api_val_array_set_i(neko_value arg1,int arg2,neko_value inVal)
|
|
{
|
|
if (!neko_val_is_array(arg1))
|
|
arg1 = dyn_val_field(arg1,__a_id);
|
|
neko_val_array_ptr(arg1)[arg2] = inVal;
|
|
}
|
|
|
|
void api_val_array_set_size(neko_value arg1,int inLen)
|
|
{
|
|
NEKO_NOT_IMPLEMENTED("api_val_array_set_size");
|
|
}
|
|
|
|
void api_val_array_push(neko_value inArray,neko_value inValue)
|
|
{
|
|
dyn_val_ocall1(inArray,push_id,inValue);
|
|
}
|
|
|
|
|
|
neko_value api_alloc_array(int arg1)
|
|
{
|
|
if (!gNekoNewArray)
|
|
return dyn_alloc_array(arg1);
|
|
return dyn_val_call1(*gNekoNewArray,neko_alloc_int(arg1));
|
|
}
|
|
|
|
|
|
neko_value * api_val_array_value(neko_value arg1)
|
|
{
|
|
if (neko_val_is_array(arg1))
|
|
return neko_val_array_ptr(arg1);
|
|
return neko_val_array_ptr(dyn_val_field(arg1,__a_id));
|
|
}
|
|
|
|
neko_value api_val_call0_traceexcept(neko_value arg1)
|
|
{
|
|
NEKO_NOT_IMPLEMENTED("api_val_call0_traceexcept");
|
|
return gNekoNull;
|
|
}
|
|
|
|
|
|
int api_val_fun_nargs(neko_value arg1)
|
|
{
|
|
if (!arg1 || !neko_val_is_function(arg1) )
|
|
return faNotFunction;
|
|
return neko_val_fun_nargs(arg1);
|
|
}
|
|
|
|
|
|
|
|
void api_val_gc(neko_value obj, void *finalizer)
|
|
{
|
|
// Let neko deal with ints or abstracts ...
|
|
if (neko_val_is_int(obj) || neko_val_is_abstract(obj))
|
|
{
|
|
dyn_val_gc(obj,finalizer);
|
|
}
|
|
else
|
|
{
|
|
// Hack type to abstract for the duration
|
|
neko_val_type old_tag = neko_val_tag(obj);
|
|
neko_val_tag(obj) = VAL_ABSTRACT;
|
|
dyn_val_gc(obj,finalizer);
|
|
neko_val_tag(obj) = old_tag;
|
|
}
|
|
}
|
|
|
|
void api_gc_change_managed_memory(int,const char *)
|
|
{
|
|
// Nothing to do here
|
|
}
|
|
|
|
bool api_gc_try_blocking() { return false; }
|
|
bool api_gc_try_unblocking() { return false; }
|
|
|
|
#define IMPLEMENT_HERE(x) if (!strcmp(inName,#x)) return (void *)api_##x;
|
|
#define IGNORE_API(x) if (!strcmp(inName,#x)) return (void *)api_empty;
|
|
|
|
|
|
void *DynamicNekoLoader(const char *inName)
|
|
{
|
|
IMPLEMENT_HERE(alloc_kind)
|
|
IMPLEMENT_HERE(alloc_null)
|
|
IMPLEMENT_HERE(val_to_kind)
|
|
if (!strcmp(inName,"hx_fail"))
|
|
return LoadNekoFunc("_neko_failure");
|
|
IMPLEMENT_HERE(val_type)
|
|
IMPLEMENT_HERE(val_bool)
|
|
IMPLEMENT_HERE(val_int)
|
|
IMPLEMENT_HERE(val_float)
|
|
IMPLEMENT_HERE(val_number)
|
|
IMPLEMENT_HERE(val_field_numeric)
|
|
IMPLEMENT_HERE(alloc_bool)
|
|
IMPLEMENT_HERE(alloc_int)
|
|
IMPLEMENT_HERE(alloc_empty_object)
|
|
IMPLEMENT_HERE(alloc_root)
|
|
IMPLEMENT_HERE(val_gc)
|
|
IMPLEMENT_HERE(gc_try_blocking)
|
|
IMPLEMENT_HERE(gc_try_unblocking)
|
|
|
|
IMPLEMENT_HERE(create_abstract)
|
|
IMPLEMENT_HERE(free_abstract)
|
|
|
|
IGNORE_API(gc_enter_blocking)
|
|
IGNORE_API(gc_exit_blocking)
|
|
IGNORE_API(gc_safe_point)
|
|
IGNORE_API(gc_add_root)
|
|
IGNORE_API(gc_remove_root)
|
|
IGNORE_API(gc_set_top_of_stack)
|
|
IGNORE_API(gc_change_managed_memory)
|
|
IGNORE_API(create_root)
|
|
IGNORE_API(query_root)
|
|
IGNORE_API(destroy_root)
|
|
IGNORE_API(hx_register_prim)
|
|
IGNORE_API(val_array_int)
|
|
IGNORE_API(val_array_double)
|
|
IGNORE_API(val_array_float)
|
|
IGNORE_API(val_array_bool)
|
|
|
|
if (!strcmp(inName,"hx_alloc"))
|
|
return LoadNekoFunc("neko_alloc");
|
|
|
|
IMPLEMENT_HERE(buffer_to_string)
|
|
IMPLEMENT_HERE(buffer_val)
|
|
|
|
if (!strcmp(inName,"val_iter_field_vals"))
|
|
return LoadNekoFunc("neko_val_iter_fields");
|
|
|
|
IMPLEMENT_HERE(val_strlen)
|
|
IMPLEMENT_HERE(val_wstring)
|
|
IMPLEMENT_HERE(val_string)
|
|
IMPLEMENT_HERE(alloc_string)
|
|
IMPLEMENT_HERE(alloc_raw_string)
|
|
IMPLEMENT_HERE(alloc_string_data)
|
|
IMPLEMENT_HERE(val_dup_wstring)
|
|
IMPLEMENT_HERE(val_dup_string)
|
|
IMPLEMENT_HERE(alloc_string_len)
|
|
IMPLEMENT_HERE(alloc_wstring_len)
|
|
|
|
IMPLEMENT_HERE(val_is_buffer)
|
|
IMPLEMENT_HERE(val_to_buffer)
|
|
IMPLEMENT_HERE(alloc_buffer_len)
|
|
IMPLEMENT_HERE(buffer_size)
|
|
IMPLEMENT_HERE(buffer_set_size)
|
|
IMPLEMENT_HERE(buffer_append_char)
|
|
IMPLEMENT_HERE(buffer_data)
|
|
|
|
IMPLEMENT_HERE(hx_error)
|
|
IMPLEMENT_HERE(val_array_i)
|
|
IMPLEMENT_HERE(val_array_size)
|
|
IMPLEMENT_HERE(val_data)
|
|
IMPLEMENT_HERE(val_array_set_i)
|
|
IMPLEMENT_HERE(val_array_set_size)
|
|
IMPLEMENT_HERE(val_array_push)
|
|
IMPLEMENT_HERE(alloc_array)
|
|
IMPLEMENT_HERE(alloc_field_numeric)
|
|
IMPLEMENT_HERE(val_array_value)
|
|
|
|
IMPLEMENT_HERE(val_fun_nargs)
|
|
|
|
IMPLEMENT_HERE(val_call0_traceexcept)
|
|
|
|
|
|
char buffer[100];
|
|
strcpy(buffer,"neko_");
|
|
strcat(buffer,inName);
|
|
void *result = LoadNekoFunc(buffer);
|
|
if (result)
|
|
return result;
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
ResolveProc InitDynamicNekoLoader()
|
|
{
|
|
static bool init = false;
|
|
if (!init)
|
|
{
|
|
dyn_alloc_private = (alloc_private_func)LoadNekoFunc("neko_alloc_private");
|
|
dyn_alloc = (alloc_private_func)LoadNekoFunc("neko_alloc");
|
|
dyn_alloc_object = (alloc_object_func)LoadNekoFunc("neko_alloc_object");
|
|
dyn_alloc_string = (alloc_string_func)LoadNekoFunc("neko_alloc_string");
|
|
dyn_alloc_abstract = (alloc_abstract_func)LoadNekoFunc("neko_alloc_abstract");
|
|
dyn_val_call1 = (val_call1_func)LoadNekoFunc("neko_val_call1");
|
|
dyn_val_field = (val_field_func)LoadNekoFunc("neko_val_field");
|
|
dyn_alloc_field = (alloc_field_func)LoadNekoFunc("neko_alloc_field");
|
|
dyn_alloc_float = (alloc_float_func)LoadNekoFunc("neko_alloc_float");
|
|
dyn_alloc_root = (alloc_root_func)LoadNekoFunc("neko_alloc_root");
|
|
dyn_copy_string = (copy_string_func)LoadNekoFunc("neko_copy_string");
|
|
dyn_val_id = (val_id_func)LoadNekoFunc("neko_val_id");
|
|
dyn_alloc_buffer = (alloc_buffer_func)LoadNekoFunc("neko_alloc_buffer");
|
|
dyn_val_buffer = (val_buffer_func)LoadNekoFunc("neko_buffer_to_string");
|
|
dyn_fail = (fail_func)LoadNekoFunc("_neko_failure");
|
|
dyn_buffer_append_sub = (buffer_append_sub_func)LoadNekoFunc("neko_buffer_append_sub");
|
|
dyn_alloc_array = (alloc_array_func)LoadNekoFunc("neko_alloc_array");
|
|
dyn_val_gc = (val_gc_func)LoadNekoFunc("neko_val_gc");
|
|
dyn_val_ocall1 = (val_ocall1_func)LoadNekoFunc("neko_val_ocall1");
|
|
dyn_alloc_empty_string = (alloc_empty_string_func)LoadNekoFunc("neko_alloc_empty_string");
|
|
init = true;
|
|
}
|
|
|
|
if (!dyn_val_id)
|
|
return 0;
|
|
|
|
|
|
__a_id = dyn_val_id("__a");
|
|
__s_id = dyn_val_id("__s");
|
|
b_id = dyn_val_id("b");
|
|
length_id = dyn_val_id("length");
|
|
push_id = dyn_val_id("push");
|
|
|
|
return DynamicNekoLoader;
|
|
}
|
|
|
|
|
|
neko_value neko_init(neko_value inNewString,neko_value inNewArray,neko_value inNull, neko_value inTrue, neko_value inFalse)
|
|
{
|
|
InitDynamicNekoLoader();
|
|
|
|
gNekoNull = inNull;
|
|
gNekoTrue = inTrue;
|
|
gNekoFalse = inFalse;
|
|
|
|
gNeko2HaxeString = dyn_alloc_root(1);
|
|
*gNeko2HaxeString = inNewString;
|
|
gNekoNewArray = dyn_alloc_root(1);
|
|
*gNekoNewArray = inNewArray;
|
|
|
|
return gNekoNull;
|
|
}
|
|
|
|
|
|
|
|
} // end anon namespace
|
|
|
|
#endif
|
|
|