int a;
a.OnGetString(0,0,0);
a.OnFree();
- a.OnCopy(null);
- a.OnCompare(null);
+ a.OnCopy(0);
+ a.OnCompare(0);
a.OnSaveEdit(null,0);
a.OnEdit(null,null,0,0,0,20,0);
a.OnGetDataFromString(null);
}
+#define uint _uint
+#include <stdarg.h>
+#include <stdio.h>
+#undef uint
+
default:
+FILE *eC_stdout(void);
+FILE *eC_stderr(void);
+
extern int __ecereVMethodID_class_OnGetString;
extern int __ecereVMethodID_class_OnGetDataFromString;
extern int __ecereVMethodID_class_OnCompare;
/*static */char * Enum_OnGetString(Class _class, int * data, char * tempString, void * fieldData, bool * needClass)
{
- EnumClassData enumeration = (EnumClassData)_class.data;
- NamedLink item;
- for(item = enumeration.values.first; item; item = item.next)
- if((int)item.data == *data)
- break;
+ NamedLink item = null;
+ Class b;
+ for(b = _class; !item && b && b.type == enumClass; b = b.base)
+ {
+ EnumClassData enumeration = (EnumClassData)b.data;
+ for(item = enumeration.values.first; item; item = item.next)
+ if((int)item.data == *data)
+ break;
+ }
if(item)
{
strcpy(tempString, item.name);
static bool Enum_OnGetDataFromString(Class _class, int * data, char * string)
{
- EnumClassData enumeration = (EnumClassData)_class.data;
- NamedLink item;
- for(item = enumeration.values.first; item; item = item.next)
+ NamedLink item = null;
+ Class b;
+ for(b = _class; !item && b && b.type == enumClass; b = b.base)
{
- if(item.name && !strcmpi(item.name, string))
- break;
+ EnumClassData enumeration = (EnumClassData)_class.data;
+ for(item = enumeration.values.first; item; item = item.next)
+ {
+ if(item.name && !strcmpi(item.name, string))
+ break;
+ }
}
if(item)
{
for(member = _class.membersAndProperties.first; member; member = member.next)
{
int memberResult = 0;
+ if(member.id < 0) continue;
if(member.isProperty || member.type == normalMember)
{
Class memberType = member.dataTypeClass;
int result = 0;
if(data1 && data2)
{
- if(*(void **)data1 > *(void **)data2)
- result = 1;
- else if(*(void **)data1 < *(void **)data2)
- result = -1;
+ if(_class.typeSize == 8)
+ {
+ if(*(uint64 *)data1 > *(uint64 *)data2)
+ result = 1;
+ else if(*(uint64 *)data1 < *(uint64 *)data2)
+ result = -1;
+ }
+ else
+ {
+ if(*(uint *)data1 > *(uint *)data2)
+ result = 1;
+ else if(*(uint *)data1 < *(uint *)data2)
+ result = -1;
+ }
}
else if(!data1 && data2)
return 1;
{
// WHY DOES _class.module NOT SEEM TO WORK?
Module module = _class.templateClass ? _class.templateClass.module : _class.module;
- if(_class.type == enumClass)
+ if(_class.type == normalClass && _class.base && !_class.base.base)
+ {
+ if(sizeof(uintsize) == 8)
+ return UInt64Hex_OnGetString(_class, (void *)&data, tempString, fieldData, needClass);
+ else
+ return UIntegerHex_OnGetString(_class, (void *)&data, tempString, fieldData, needClass);
+ }
+ else if(_class.type == enumClass)
{
return Enum_OnGetString(_class, data, tempString, fieldData, needClass);
}
else if(_class.type == unitClass)
{
- Class dataType = eSystem_FindClass(module, _class.dataTypeString);
+ Class dataType;
+ Property prop;
+ for(prop = _class.conversions.first; prop; prop = prop.next)
+ {
+ bool refProp = false;
+ Class c;
+ if(!strcmp(prop.name, _class.base.fullName))
+ refProp = true;
+ else if( (c = eSystem_FindClass(_class.module, prop.name) ) )
+ {
+ Property p;
+ for(p = c.conversions.first; p; p = p.next)
+ {
+ if(!strcmp(p.name, _class.base.fullName) && !p.Set && !p.Get)
+ {
+ refProp = true;
+ break;
+ }
+ }
+ }
+ if(refProp)
+ {
+ if(prop.Set && prop.Get)
+ {
+ String dts = _class.base.dataTypeString;
+ if(!strcmp(dts, "double"))
+ {
+ double d = ((double(*)(double))(void *)prop.Set)(*(double *)data);
+ return ((char *(*)(void *, void *, char *, void *, bool *))(void *)class(double)._vTbl[__ecereVMethodID_class_OnGetString])(class(double), &d, tempString, fieldData, needClass);
+ }
+ else if(!strcmp(dts, "float"))
+ {
+ float d = ((float(*)(float))(void *)prop.Set)(*(float *)data);
+ return ((char *(*)(void *, void *, char *, void *, bool *))(void *)class(float)._vTbl[__ecereVMethodID_class_OnGetString])(class(float), &d, tempString, fieldData, needClass);
+ }
+ else if(!strcmp(dts, "int"))
+ {
+ int d = ((int(*)(int))(void *)prop.Set)(*(int *)data);
+ return ((char *(*)(void *, void *, char *, void *, bool *))(void *)class(int)._vTbl[__ecereVMethodID_class_OnGetString])(class(int), &d, tempString, fieldData, needClass);
+ }
+ else if(!strcmp(dts, "int64"))
+ {
+ int64 d = ((int64(*)(int64))(void *)prop.Set)(*(int64 *)data);
+ return ((char *(*)(void *, void *, char *, void *, bool *))(void *)class(int64)._vTbl[__ecereVMethodID_class_OnGetString])(class(int64), &d, tempString, fieldData, needClass);
+ }
+ }
+ else
+ break;
+ }
+ }
+ dataType = eSystem_FindClass(module, _class.dataTypeString);
return ((char *(*)(void *, void *, char *, void *, bool *))(void *)dataType._vTbl[__ecereVMethodID_class_OnGetString])(dataType, data, tempString, fieldData, needClass);
}
else
char memberString[1024];
Class memberType = member.dataTypeClass;
char * name = member.name;
+ if(member.id < 0) continue;
memberString[0] = 0;
DataValue value = { 0 };
if(!strcmp(prop.dataTypeString, "float"))
{
- value.f = ((float(*)())(void *)prop.Get)(data);
+ value.f = ((float(*)(void *))(void *)prop.Get)(data);
if(value.f)
{
bool needClass = true;
strcat(memberString, "f");
}
}
- else
+ else if(memberType.type == normalClass || memberType.type == noHeadClass)
{
- value.i = prop.Get(data);
- if(value.i || prop.IsSet)
+ value.p = ((void *(*)(void *))(void *)prop.Get)(data);
+ if(value.p || prop.IsSet)
{
bool needClass = true;
char * result = ((char *(*)(void *, void *, char *, void *, bool *))(void *)memberType._vTbl[__ecereVMethodID_class_OnGetString])(memberType,
strcpy(memberString, result);
}
}
+ else
+ {
+ value.i = ((int(*)(void *))(void *)prop.Get)(data);
+ if(value.i || prop.IsSet)
+ {
+ bool needClass = true;
+ char * result = ((char *(*)(void *, void *, char *, void *, bool *))(void *)memberType._vTbl[__ecereVMethodID_class_OnGetString])(memberType, &value, memberString, null, &needClass);
+ if(result && result != memberString)
+ strcpy(memberString, result);
+ }
+ }
}
}
}
char internalMemberString[1024];
byte * memberData = ((byte *)data + (((member._class.type == normalClass) ? member._class.offset : 0) + member.offset));
int c;
- for(c = 0; c < memberType.structSize; c++)
+ uint typeSize = (memberType.type == normalClass) ? memberType.typeSize : memberType.structSize;
+ for(c = 0; c < typeSize; c++)
if(memberData[c])
break;
- if(c < memberType.structSize)
+ if(c < typeSize)
{
bool needClass = true;
char * result;
result = ((char *(*)(void *, void *, char *, void *, bool *))(void *)memberType._vTbl[__ecereVMethodID_class_OnGetString])(memberType, *(Instance *)memberData, internalMemberString, null, &needClass);
else
result = ((char *(*)(void *, void *, char *, void *, bool *))(void *)memberType._vTbl[__ecereVMethodID_class_OnGetString])(memberType, memberData, internalMemberString, null, &needClass);
- if(needClass)
+ if(needClass && strcmp(memberType.dataTypeString, "char *"))
{
//strcpy(memberString, memberType.name);
strcat(memberString, "{ ");
result = Enum_OnGetDataFromString(_class, (int *)data, string);
else if(_class.type == unitClass)
{
- Class dataType = eSystem_FindClass(module, _class.dataTypeString);
+ Class dataType;
+ Property prop;
+ for(prop = _class.conversions.first; prop; prop = prop.next)
+ {
+ bool refProp = false;
+ Class c;
+ if(!strcmp(prop.name, _class.base.fullName))
+ refProp = true;
+ else if( (c = eSystem_FindClass(_class.module, prop.name) ) )
+ {
+ Property p;
+ for(p = c.conversions.first; p; p = p.next)
+ {
+ if(!strcmp(p.name, _class.base.fullName) && !p.Set && !p.Get)
+ {
+ refProp = true;
+ break;
+ }
+ }
+ }
+ if(refProp)
+ {
+ if(prop.Set && prop.Get)
+ {
+ String dts = _class.base.dataTypeString;
+ if(!strcmp(dts, "double"))
+ {
+ double d;
+ bool result = ((bool (*)(void *, void *, const char *))(void *)class(double)._vTbl[__ecereVMethodID_class_OnGetDataFromString])(class(double), &d, string);
+ *(double *)data =((double(*)(double))(void *)prop.Get)(d);
+ return result;
+ }
+ else if(!strcmp(dts, "float"))
+ {
+ float d;
+ bool result = ((bool (*)(void *, void *, const char *))(void *)class(float)._vTbl[__ecereVMethodID_class_OnGetDataFromString])(class(float), &d, string);
+ *(float *)data = ((float(*)(float))(void *)prop.Get)(d);
+ return result;
+ }
+ else if(!strcmp(dts, "int"))
+ {
+ int d;
+ bool result = ((bool (*)(void *, void *, const char *))(void *)class(int)._vTbl[__ecereVMethodID_class_OnGetDataFromString])(class(int), &d, string);
+ *(int *)data = ((int(*)(int))(void *)prop.Get)(d);
+ return result;
+ }
+ else if(!strcmp(dts, "int64"))
+ {
+ int64 d;
+ bool result = ((bool (*)(void *, void *, const char *))(void *)class(int64)._vTbl[__ecereVMethodID_class_OnGetDataFromString])(class(int64), &d, string);
+ *(int64 *)data = ((int64(*)(int64))(void *)prop.Get)(d);
+ return result;
+ }
+ }
+ else
+ break;
+ }
+ }
+ dataType = eSystem_FindClass(module, _class.dataTypeString);
return ((bool (*)(void *, void *, const char *))(void *)dataType._vTbl[__ecereVMethodID_class_OnGetDataFromString])(dataType, data, string);
}
else if(!string[0] && _class.type == normalClass)
*(int *)((byte *)data + (((thisMember._class.type == normalClass) ? thisMember._class.offset : 0) + thisMember.offset)) = value.i;
}
else if(thisMember.isProperty && ((Property)thisMember).Set)
- ((Property)thisMember).Set(data, value.i);
+ {
+ if(memberType.type == noHeadClass || memberType.type == normalClass || memberType.type == structClass)
+ ((void (*)(void *, void *))(void *)((Property)thisMember).Set)(data, value.p);
+ else
+ ((void (*)(void *, int))(void *)((Property)thisMember).Set)(data, value.i);
+ }
}
}
else
if(dataType)
((void (*)(void *, void *, void *))(void *)dataType._vTbl[__ecereVMethodID_class_OnCopy])(dataType, data, newData);
}
- else if(_class.type != structClass && _class.type != systemClass)
+ else if(_class.type != structClass && (_class.type != systemClass || _class.byValueSystemClass))
{
*data = newData;
}
while(lastClass != _class)
{
DataMember member;
- for(; _class && (!_class.base || _class.base.type != systemClass) && _class != lastClass; _class = _class.base);
- lastClass = _class;
+ Class c;
+ for(c = _class; c && (!c.base || c.base.type != systemClass) && c.base != lastClass; c = c.base);
+ lastClass = c;
- for(member = _class.membersAndProperties.first; member; member = member.next)
+ for(member = c.membersAndProperties.first; member; member = member.next)
{
+ if(member.id < 0) continue;
if(member.isProperty || member.type == normalMember)
{
Class memberType = member.dataTypeClass;
while(lastClass != _class)
{
DataMember member;
- for(; _class && (!_class.base || _class.base.type != systemClass) && _class != lastClass; _class = _class.base);
- lastClass = _class;
+ Class c;
+ for(c = _class; c && (!c.base || c.base.type != systemClass) && c.base != lastClass; c = c.base);
+ lastClass = c;
- for(member = _class.membersAndProperties.first; member; member = member.next)
+ for(member = c.membersAndProperties.first; member; member = member.next)
{
+ if(member.id < 0) continue;
if(member.isProperty || member.type == normalMember)
{
Class memberType = member.dataTypeClass;
return false;
}
+static char * Int16_OnGetString(Class _class, short * data, char * string, void * fieldData, bool * needClass)
+{
+ sprintf(string, "%d", (int)*data);
+ return string;
+}
+
+static bool Int16_OnGetDataFromString(Class _class, short * data, char * string)
+{
+ char * end;
+ short result = (short)strtol(string, &end, 0);
+
+ if(end > string)
+ {
+ *data = result;
+ return true;
+ }
+ return false;
+}
+
+static int Int16_OnCompare(Class _class, short * data1, short * data2)
+{
+ int result = 0;
+ if(!data1 && !data2) result = 0;
+ else if(data1 && !data2) result = 1;
+ else if(!data1 && data2) result = -1;
+ else if(*data1 > *data2) result = 1;
+ else if(*data1 < *data2) result = -1;
+ return result;
+}
+
static int UInteger_OnCompare(Class _class, unsigned int * data1, unsigned int * data2)
{
int result = 0;
return string;
}
+static int UInt16_OnCompare(Class _class, uint16 * data1, unsigned int * data2)
+{
+ int result = 0;
+ if(!data1 && !data2) result = 0;
+ else if(data1 && !data2) result = 1;
+ else if(!data1 && data2) result = -1;
+ else if(*data1 > *data2) result = 1;
+ else if(*data1 < *data2) result = -1;
+ return result;
+}
+
+static char * UInt16_OnGetString(Class _class, uint16 * data, char * string, void * fieldData, bool * needClass)
+{
+ sprintf(string, "%u", (uint)*data);
+ return string;
+}
+
+
+static char * UIntegerHex_OnGetString(Class _class, unsigned int * data, char * string, void * fieldData, bool * needClass)
+{
+ sprintf(string, "%x", *data);
+ return string;
+}
+
static bool UInteger_OnGetDataFromString(Class _class, unsigned int * data, char * string)
{
char * end;
- uint result = strtoul(string, &end, 0);
+ uint result = (uint)strtoul(string, &end, 0);
+ if(end > string)
+ {
+ *data = result;
+ return true;
+ }
+ return false;
+}
+
+static bool UInt16_OnGetDataFromString(Class _class, uint16 * data, char * string)
+{
+ char * end;
+ uint16 result = (uint16)strtoul(string, &end, 0);
if(end > string)
{
*data = result;
return result;
}
+static int IntPtr64_OnCompare(Class _class, int64 data1, int64 data2)
+{
+ int result = 0;
+ if(data1 > data2) result = 1;
+ else if(data1 < data2) result = -1;
+ return result;
+}
+
+static int IntPtr32_OnCompare(Class _class, int data1, int data2)
+{
+ int result = 0;
+ if(data1 > data2) result = 1;
+ else if(data1 < data2) result = -1;
+ return result;
+}
+
+static int UIntPtr64_OnCompare(Class _class, uint64 data1, uint64 data2)
+{
+ int result = 0;
+ if(data1 > data2) result = 1;
+ else if(data1 < data2) result = -1;
+ return result;
+}
+
+static int UIntPtr32_OnCompare(Class _class, uint32 data1, uint32 data2)
+{
+ int result = 0;
+ if(data1 > data2) result = 1;
+ else if(data1 < data2) result = -1;
+ return result;
+}
+
static char * Int64_OnGetString(Class _class, int64 * data, char * string, void * fieldData, bool * needClass)
{
sprintf(string, FORMAT64D, *data);
return string;
}
+static char * UInt64Hex_OnGetString(Class _class, uint64 * data, char * string, void * fieldData, bool * needClass)
+{
+ sprintf(string, FORMAT64HEX, *data);
+ return string;
+}
+
+static char * UIntPtr64_OnGetString(Class _class, uint64 data, char * string, void * fieldData, bool * needClass)
+{
+ return UInt64Hex_OnGetString(_class, &data, string, fieldData, needClass);
+}
+
+static char * UIntPtr32_OnGetString(Class _class, uint data, char * string, void * fieldData, bool * needClass)
+{
+ return UIntegerHex_OnGetString(_class, &data, string, fieldData, needClass);
+}
+
+static char * IntPtr64_OnGetString(Class _class, uint64 data, char * string, void * fieldData, bool * needClass)
+{
+ return Int64_OnGetString(_class, &data, string, fieldData, needClass);
+}
+
+static char * IntPtr32_OnGetString(Class _class, uint data, char * string, void * fieldData, bool * needClass)
+{
+ return Integer_OnGetString(_class, &data, string, fieldData, needClass);
+}
+
+static bool Int64_OnGetDataFromString(Class _class, uint64 * data, char * string)
+{
+ char * end;
+ uint64 result = _strtoi64(string, &end, 0);
+ if(end > string)
+ {
+ *data = result;
+ return true;
+ }
+ return false;
+}
+
+static bool UInt64_OnGetDataFromString(Class _class, uint64 * data, char * string)
+{
+ char * end;
+ uint64 result = _strtoui64(string, &end, 0);
+ if(end > string)
+ {
+ *data = result;
+ return true;
+ }
+ return false;
+}
+
/*static */void Byte_OnSerialize(Class _class, byte * data, IOChannel channel)
{
channel.WriteData(data, 1);
*data = 0;
}
-
/*static */void Int_OnSerialize(Class _class, int * data, IOChannel channel)
{
byte bytes[4];
channel.WriteData(bytes, 4);
}
+/*static */void IntPtr32_OnSerialize(Class _class, int data, IOChannel channel)
+{
+ byte bytes[4];
+ PUTXDWORD(bytes, data);
+ channel.WriteData(bytes, 4);
+}
+
/*static */void Int_OnUnserialize(Class _class, int * data, IOChannel channel)
{
byte bytes[4];
*data = 0;
}
+/*static */void Enum_OnSerialize(Class _class, int * data, IOChannel channel)
+{
+ Class dataType = strcmp(_class.dataTypeString, "int") ? eSystem_FindClass(_class.module, _class.dataTypeString) : null;
+ if(dataType)
+ ((void (*)(void *, void *, void *))(void *)dataType._vTbl[__ecereVMethodID_class_OnSerialize])(dataType, data, channel);
+ else
+ Int_OnSerialize(_class, data, channel);
+}
+
+/*static */void Enum_OnUnserialize(Class _class, int * data, IOChannel channel)
+{
+ Class dataType = strcmp(_class.dataTypeString, "int") ? eSystem_FindClass(_class.module, _class.dataTypeString) : null;
+ if(dataType)
+ ((void (*)(void *, void *, void *))(void *)dataType._vTbl[__ecereVMethodID_class_OnUnserialize])(dataType, data, channel);
+ else
+ Int_OnUnserialize(_class, data, channel);
+}
+
/*static */void Int64_OnSerialize(Class _class, int64 * data, IOChannel channel)
{
byte bytes[8];
channel.WriteData(bytes, 8);
}
+static void IntPtr64_OnSerialize(Class _class, int64 data, IOChannel channel)
+{
+ byte bytes[8];
+ PUTXQWORD(bytes, data);
+ channel.WriteData(bytes, 8);
+}
+
/*static */void Int64_OnUnserialize(Class _class, int64 * data, IOChannel channel)
{
byte bytes[8];
integerClass.dataTypeString = CopyString("int64");
eClass_AddMethod(integerClass, "OnGetString", null, Int64_OnGetString, publicAccess);
eClass_AddMethod(integerClass, "OnCompare", null, Int64_OnCompare, publicAccess);
- // eClass_AddMethod(integerClass, "OnGetDataFromString", null, Integer64_OnGetDataFromString, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetDataFromString", null, Int64_OnGetDataFromString, publicAccess);
eClass_AddMethod(integerClass, "OnSerialize", null, Int64_OnSerialize, publicAccess);
eClass_AddMethod(integerClass, "OnUnserialize", null, Int64_OnUnserialize, publicAccess);
eClass_AddMethod(integerClass, "OnSerialize", null, Word_OnSerialize, publicAccess);
eClass_AddMethod(integerClass, "OnUnserialize", null, Word_OnUnserialize, publicAccess);
+ eClass_AddMethod(integerClass, "OnCompare", null, UInt16_OnCompare, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetString", null, UInt16_OnGetString, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetDataFromString", null, UInt16_OnGetDataFromString, publicAccess);
integerClass = eSystem_RegisterClass(normalClass, "short", null, 0, 0, null, null, module, baseSystemAccess, publicAccess);
integerClass.type = systemClass;
eClass_AddMethod(integerClass, "OnSerialize", null, Word_OnSerialize, publicAccess);
eClass_AddMethod(integerClass, "OnUnserialize", null, Word_OnUnserialize, publicAccess);
+ eClass_AddMethod(integerClass, "OnCompare", null, Int16_OnCompare, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetString", null, Int16_OnGetString, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetDataFromString", null, Int16_OnGetDataFromString, publicAccess);
/*
integerClass = eSystem_RegisterClass(normalClass, "uint32", null, 0, 0, null, null, module, baseSystemAccess);
integerClass.structSize = 0;
integerClass.typeSize = sizeof(uint64);
eClass_AddMethod(integerClass, "OnGetString", null, UInt64_OnGetString, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetDataFromString", null, UInt64_OnGetDataFromString, publicAccess);
eClass_AddMethod(integerClass, "OnSerialize", null, Int64_OnSerialize, publicAccess);
eClass_AddMethod(integerClass, "OnUnserialize", null, Int64_OnUnserialize, publicAccess);
- eClass_AddMethod(integerClass, "OnCompare", null, Int64_OnCompare, publicAccess);
+ eClass_AddMethod(integerClass, "OnCompare", null, UInt64_OnCompare, publicAccess);
integerClass = eSystem_RegisterClass(normalClass, "byte", null, 0, 0, null, null, module, baseSystemAccess, publicAccess);
integerClass.type = systemClass;
eClass_AddMethod(integerClass, "OnSerialize", null, Byte_OnSerialize, publicAccess);
eClass_AddMethod(integerClass, "OnUnserialize", null, Byte_OnUnserialize, publicAccess);
+ integerClass = eSystem_RegisterClass(normalClass, "intsize", null, 0, 0, null, null, module, baseSystemAccess, publicAccess);
+ integerClass.type = systemClass;
+ delete integerClass.dataTypeString;
+ integerClass.dataTypeString = CopyString("ssize_t");
+ integerClass.structSize = 0;
+ integerClass.typeSize = sizeof(intsize);
+ if(sizeof(intsize) == 8)
+ {
+ eClass_AddMethod(integerClass, "OnGetString", null, Int64_OnGetString, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetDataFromString", null, Int64_OnGetDataFromString, publicAccess);
+ eClass_AddMethod(integerClass, "OnSerialize", null, Int64_OnSerialize, publicAccess);
+ eClass_AddMethod(integerClass, "OnUnserialize", null, Int64_OnUnserialize, publicAccess);
+ eClass_AddMethod(integerClass, "OnCompare", null, Int64_OnCompare, publicAccess);
+ }
+ else
+ {
+ eClass_AddMethod(integerClass, "OnCompare", null, Integer_OnCompare, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetString", null, Integer_OnGetString, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetDataFromString", null, Integer_OnGetDataFromString, publicAccess);
+ eClass_AddMethod(integerClass, "OnSerialize", null, Int_OnSerialize, publicAccess);
+ eClass_AddMethod(integerClass, "OnUnserialize", null, Int_OnUnserialize, publicAccess);
+ }
+
+ integerClass = eSystem_RegisterClass(normalClass, "uintsize", null, 0, 0, null, null, module, baseSystemAccess, publicAccess);
+ integerClass.type = systemClass;
+ delete integerClass.dataTypeString;
+ integerClass.dataTypeString = CopyString("size_t");
+ integerClass.structSize = 0;
+ integerClass.typeSize = sizeof(uintsize);
+ if(sizeof(uintsize) == 8)
+ {
+ eClass_AddMethod(integerClass, "OnGetString", null, UInt64Hex_OnGetString, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetDataFromString", null, UInt64_OnGetDataFromString, publicAccess);
+ eClass_AddMethod(integerClass, "OnSerialize", null, Int64_OnSerialize, publicAccess);
+ eClass_AddMethod(integerClass, "OnUnserialize", null, Int64_OnUnserialize, publicAccess);
+ eClass_AddMethod(integerClass, "OnCompare", null, UInt64_OnCompare, publicAccess);
+ }
+ else
+ {
+ eClass_AddMethod(integerClass, "OnGetString", null, UIntegerHex_OnGetString, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetDataFromString", null, UInteger_OnGetDataFromString, publicAccess);
+ eClass_AddMethod(integerClass, "OnSerialize", null, Int_OnSerialize, publicAccess);
+ eClass_AddMethod(integerClass, "OnUnserialize", null, Int_OnUnserialize, publicAccess);
+ eClass_AddMethod(integerClass, "OnCompare", null, UInteger_OnCompare, publicAccess);
+ }
+
integerClass = eSystem_RegisterClass(normalClass, "uintptr", null, 0, 0, null, null, module, baseSystemAccess, publicAccess);
integerClass.type = systemClass;
delete integerClass.dataTypeString;
integerClass.dataTypeString = CopyString("uintptr_t");
integerClass.structSize = 0;
integerClass.typeSize = sizeof(uintptr);
+ integerClass.byValueSystemClass = true;
if(sizeof(uintptr) == 8)
{
- eClass_AddMethod(integerClass, "OnGetString", null, UInt64_OnGetString, publicAccess);
- eClass_AddMethod(integerClass, "OnSerialize", null, Int64_OnSerialize, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetString", null, UIntPtr64_OnGetString, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetDataFromString", null, UInt64_OnGetDataFromString, publicAccess);
+ eClass_AddMethod(integerClass, "OnSerialize", null, IntPtr64_OnSerialize, publicAccess);
eClass_AddMethod(integerClass, "OnUnserialize", null, Int64_OnUnserialize, publicAccess);
- eClass_AddMethod(integerClass, "OnCompare", null, UInt64_OnCompare, publicAccess);
+ eClass_AddMethod(integerClass, "OnCompare", null, UIntPtr64_OnCompare, publicAccess);
}
else
{
- eClass_AddMethod(integerClass, "OnCompare", null, UInteger_OnCompare, publicAccess);
- eClass_AddMethod(integerClass, "OnGetString", null, UInteger_OnGetString, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetString", null, UIntPtr32_OnGetString, publicAccess);
eClass_AddMethod(integerClass, "OnGetDataFromString", null, UInteger_OnGetDataFromString, publicAccess);
- eClass_AddMethod(integerClass, "OnSerialize", null, Int_OnSerialize, publicAccess);
+ eClass_AddMethod(integerClass, "OnSerialize", null, IntPtr32_OnSerialize, publicAccess);
eClass_AddMethod(integerClass, "OnUnserialize", null, Int_OnUnserialize, publicAccess);
+ eClass_AddMethod(integerClass, "OnCompare", null, UIntPtr32_OnCompare, publicAccess);
}
integerClass = eSystem_RegisterClass(normalClass, "intptr", null, 0, 0, null, null, module, baseSystemAccess, publicAccess);
integerClass.dataTypeString = CopyString("intptr_t");
integerClass.structSize = 0;
integerClass.typeSize = sizeof(intptr);
+ integerClass.byValueSystemClass = true;
if(sizeof(intptr) == 8)
{
- eClass_AddMethod(integerClass, "OnGetString", null, Int64_OnGetString, publicAccess);
- eClass_AddMethod(integerClass, "OnSerialize", null, Int64_OnSerialize, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetString", null, IntPtr64_OnGetString, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetDataFromString", null, Int64_OnGetDataFromString, publicAccess);
+ eClass_AddMethod(integerClass, "OnSerialize", null, IntPtr64_OnSerialize, publicAccess);
eClass_AddMethod(integerClass, "OnUnserialize", null, Int64_OnUnserialize, publicAccess);
- eClass_AddMethod(integerClass, "OnCompare", null, Int64_OnCompare, publicAccess);
+ eClass_AddMethod(integerClass, "OnCompare", null, IntPtr64_OnCompare, publicAccess);
}
else
{
- eClass_AddMethod(integerClass, "OnCompare", null, Integer_OnCompare, publicAccess);
- eClass_AddMethod(integerClass, "OnGetString", null, Integer_OnGetString, publicAccess);
+ eClass_AddMethod(integerClass, "OnGetString", null, IntPtr32_OnGetString, publicAccess);
eClass_AddMethod(integerClass, "OnGetDataFromString", null, Integer_OnGetDataFromString, publicAccess);
- eClass_AddMethod(integerClass, "OnSerialize", null, Int_OnSerialize, publicAccess);
+ eClass_AddMethod(integerClass, "OnSerialize", null, IntPtr32_OnSerialize, publicAccess);
eClass_AddMethod(integerClass, "OnUnserialize", null, Int_OnUnserialize, publicAccess);
+ eClass_AddMethod(integerClass, "OnCompare", null, IntPtr32_OnCompare, publicAccess);
}
}
{
Class enumClass = eSystem_FindClass(module, "enum");
- eClass_AddMethod(enumClass, "OnSerialize", null, Int_OnSerialize, publicAccess);
- eClass_AddMethod(enumClass, "OnUnserialize", null, Int_OnUnserialize, publicAccess);
+ eClass_AddMethod(enumClass, "OnSerialize", null, Enum_OnSerialize, publicAccess);
+ eClass_AddMethod(enumClass, "OnUnserialize", null, Enum_OnUnserialize, publicAccess);
// Data Types
RegisterClass_Integer(module);
RegisterClass_String(module);
}
-#define uint _uint
-#include <stdarg.h>
-#include <stdio.h>
-#undef uint
-
public int PrintStdArgsToBuffer(char * buffer, int maxLen, typed_object object, va_list args)
{
int len = 0;
va_start(args, object);
PrintStdArgsToBuffer(buffer, sizeof(buffer), object, args);
va_end(args);
- fputs(buffer, stdout);
+ fputs(buffer, eC_stdout());
}