1 /* Code generated from eC source file: AVLTree.ec */
3 #define __runtimePlatform 1
4 #elif defined(__APPLE__)
5 #define __runtimePlatform 3
7 #define __runtimePlatform 2
10 typedef long long int64;
11 typedef unsigned long long uint64;
15 #elif defined(__TINYC__)
17 #define __builtin_va_list va_list
18 #define __builtin_va_start va_start
19 #define __builtin_va_end va_end
21 #define strcasecmp stricmp
22 #define strncasecmp strnicmp
23 #define __declspec(x) __attribute__((x))
27 typedef long long int64;
28 typedef unsigned long long uint64;
30 typedef __int64 int64;
31 typedef unsigned __int64 uint64;
34 #define __ENDIAN_PAD(x) (8 - (x))
36 #define __ENDIAN_PAD(x) 0
39 # if defined(__GNUC__) || defined(__TINYC__)
40 # define stdcall __attribute__((__stdcall__))
42 # define stdcall __stdcall
48 #include <sys/types.h>
49 struct __ecereNameSpace__ecere__sys__BTNode;
51 struct __ecereNameSpace__ecere__sys__OldList
58 } __attribute__ ((gcc_struct));
60 struct __ecereNameSpace__ecere__com__DataValue
75 } __attribute__ ((gcc_struct)) __anon1;
76 } __attribute__ ((gcc_struct));
78 struct __ecereNameSpace__ecere__com__SerialBuffer
80 unsigned char * _buffer;
84 } __attribute__ ((gcc_struct));
86 extern void * __ecereNameSpace__ecere__com__eSystem_New(unsigned int size);
88 extern void * __ecereNameSpace__ecere__com__eSystem_New0(unsigned int size);
90 extern void * __ecereNameSpace__ecere__com__eSystem_Renew(void * memory, unsigned int size);
92 extern void * __ecereNameSpace__ecere__com__eSystem_Renew0(void * memory, unsigned int size);
94 extern void __ecereNameSpace__ecere__com__eSystem_Delete(void * memory);
96 extern void * memcpy(void * , const void * , size_t size);
98 struct __ecereNameSpace__ecere__com__CustomAVLTree
100 struct __ecereNameSpace__ecere__com__AVLNode * root;
102 } __attribute__ ((gcc_struct));
104 struct __ecereNameSpace__ecere__com__ClassTemplateParameter;
106 struct __ecereNameSpace__ecere__com__IteratorPointer;
108 struct __ecereNameSpace__ecere__com__Class;
110 struct __ecereNameSpace__ecere__com__Instance
113 struct __ecereNameSpace__ecere__com__Class * _class;
115 } __attribute__ ((gcc_struct));
117 extern long long __ecereNameSpace__ecere__com__eClass_GetProperty(struct __ecereNameSpace__ecere__com__Class * _class, const char * name);
119 extern void __ecereNameSpace__ecere__com__eClass_SetProperty(struct __ecereNameSpace__ecere__com__Class * _class, const char * name, long long value);
121 extern void __ecereNameSpace__ecere__com__eClass_DoneAddingTemplateParameters(struct __ecereNameSpace__ecere__com__Class * base);
123 extern void __ecereNameSpace__ecere__com__eInstance_SetMethod(struct __ecereNameSpace__ecere__com__Instance * instance, const char * name, void * function);
125 extern void __ecereNameSpace__ecere__com__eInstance_IncRef(struct __ecereNameSpace__ecere__com__Instance * instance);
127 int __ecereVMethodID___ecereNameSpace__ecere__com__Container_Find;
129 int __ecereVMethodID___ecereNameSpace__ecere__com__Container_Remove;
131 int __ecereVMethodID___ecereNameSpace__ecere__com__Container_Add;
133 struct __ecereNameSpace__ecere__com__Property;
135 struct __ecereNameSpace__ecere__com__Property
137 struct __ecereNameSpace__ecere__com__Property * prev;
138 struct __ecereNameSpace__ecere__com__Property * next;
140 unsigned int isProperty;
143 struct __ecereNameSpace__ecere__com__Class * _class;
144 const char * dataTypeString;
145 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
146 struct __ecereNameSpace__ecere__com__Instance * dataType;
147 void (* Set)(void * , int);
148 int (* Get)(void * );
149 unsigned int (* IsSet)(void * );
153 unsigned int conversion;
154 unsigned int watcherOffset;
155 const char * category;
156 unsigned int compiled;
157 unsigned int selfWatchable;
158 unsigned int isWatchable;
159 } __attribute__ ((gcc_struct));
161 extern void __ecereNameSpace__ecere__com__eInstance_FireSelfWatchers(struct __ecereNameSpace__ecere__com__Instance * instance, struct __ecereNameSpace__ecere__com__Property * _property);
163 extern void __ecereNameSpace__ecere__com__eInstance_StopWatching(struct __ecereNameSpace__ecere__com__Instance * instance, struct __ecereNameSpace__ecere__com__Property * _property, struct __ecereNameSpace__ecere__com__Instance * object);
165 extern void __ecereNameSpace__ecere__com__eInstance_Watch(void * instance, struct __ecereNameSpace__ecere__com__Property * _property, void * object, void (* callback)(void * , void * ));
167 extern void __ecereNameSpace__ecere__com__eInstance_FireWatchers(struct __ecereNameSpace__ecere__com__Instance * instance, struct __ecereNameSpace__ecere__com__Property * _property);
169 struct __ecereNameSpace__ecere__com__AVLNode;
171 struct __ecereNameSpace__ecere__com__AVLNode
173 struct __ecereNameSpace__ecere__com__AVLNode * parent;
174 struct __ecereNameSpace__ecere__com__AVLNode * left;
175 struct __ecereNameSpace__ecere__com__AVLNode * right;
178 } __attribute__ ((gcc_struct));
180 struct __ecereNameSpace__ecere__com__AVLNode * __ecereMethod___ecereNameSpace__ecere__com__AVLNode_Find(struct __ecereNameSpace__ecere__com__AVLNode * this, struct __ecereNameSpace__ecere__com__Class * Tclass, const uint64 key);
182 struct __ecereNameSpace__ecere__com__AVLNode * __ecereMethod___ecereNameSpace__ecere__com__AVLNode_FindAll(struct __ecereNameSpace__ecere__com__AVLNode * this, const uint64 key);
184 struct __ecereNameSpace__ecere__sys__BinaryTree;
186 struct __ecereNameSpace__ecere__sys__BinaryTree
188 struct __ecereNameSpace__ecere__sys__BTNode * root;
190 int (* CompareKey)(struct __ecereNameSpace__ecere__sys__BinaryTree * tree, uintptr_t a, uintptr_t b);
191 void (* FreeKey)(void * key);
192 } __attribute__ ((gcc_struct));
194 struct __ecereNameSpace__ecere__com__Method;
196 struct __ecereNameSpace__ecere__com__Method
199 struct __ecereNameSpace__ecere__com__Method * parent;
200 struct __ecereNameSpace__ecere__com__Method * left;
201 struct __ecereNameSpace__ecere__com__Method * right;
206 struct __ecereNameSpace__ecere__com__Class * _class;
208 const char * dataTypeString;
209 struct __ecereNameSpace__ecere__com__Instance * dataType;
211 } __attribute__ ((gcc_struct));
213 extern struct __ecereNameSpace__ecere__com__Method * __ecereNameSpace__ecere__com__eClass_AddMethod(struct __ecereNameSpace__ecere__com__Class * _class, const char * name, const char * type, void * function, int declMode);
215 struct __ecereNameSpace__ecere__com__Module;
217 extern struct __ecereNameSpace__ecere__com__Class * __ecereNameSpace__ecere__com__eSystem_RegisterClass(int type, const char * name, const char * baseName, int size, int sizeClass, unsigned int (* Constructor)(void * ), void (* Destructor)(void * ), struct __ecereNameSpace__ecere__com__Instance * module, int declMode, int inheritanceAccess);
219 extern struct __ecereNameSpace__ecere__com__Instance * __thisModule;
221 struct __ecereNameSpace__ecere__com__NameSpace;
223 struct __ecereNameSpace__ecere__com__NameSpace
226 struct __ecereNameSpace__ecere__com__NameSpace * btParent;
227 struct __ecereNameSpace__ecere__com__NameSpace * left;
228 struct __ecereNameSpace__ecere__com__NameSpace * right;
230 struct __ecereNameSpace__ecere__com__NameSpace * parent;
231 struct __ecereNameSpace__ecere__sys__BinaryTree nameSpaces;
232 struct __ecereNameSpace__ecere__sys__BinaryTree classes;
233 struct __ecereNameSpace__ecere__sys__BinaryTree defines;
234 struct __ecereNameSpace__ecere__sys__BinaryTree functions;
235 } __attribute__ ((gcc_struct));
237 struct __ecereNameSpace__ecere__com__Application
242 unsigned int isGUIApp;
243 struct __ecereNameSpace__ecere__sys__OldList allModules;
244 char * parsedCommand;
245 struct __ecereNameSpace__ecere__com__NameSpace systemNameSpace;
246 } __attribute__ ((gcc_struct));
248 struct __ecereNameSpace__ecere__com__Module
250 struct __ecereNameSpace__ecere__com__Instance * application;
251 struct __ecereNameSpace__ecere__sys__OldList classes;
252 struct __ecereNameSpace__ecere__sys__OldList defines;
253 struct __ecereNameSpace__ecere__sys__OldList functions;
254 struct __ecereNameSpace__ecere__sys__OldList modules;
255 struct __ecereNameSpace__ecere__com__Instance * prev;
256 struct __ecereNameSpace__ecere__com__Instance * next;
262 struct __ecereNameSpace__ecere__com__NameSpace privateNameSpace;
263 struct __ecereNameSpace__ecere__com__NameSpace publicNameSpace;
264 } __attribute__ ((gcc_struct));
266 void __ecereUnregisterModule_AVLTree(struct __ecereNameSpace__ecere__com__Instance * module)
271 struct __ecereNameSpace__ecere__com__DataMember;
273 struct __ecereNameSpace__ecere__com__ClassTemplateArgument
279 const char * dataTypeString;
280 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
281 } __attribute__ ((gcc_struct)) __anon1;
282 struct __ecereNameSpace__ecere__com__DataValue expression;
285 const char * memberString;
288 struct __ecereNameSpace__ecere__com__DataMember * member;
289 struct __ecereNameSpace__ecere__com__Property * prop;
290 struct __ecereNameSpace__ecere__com__Method * method;
291 } __attribute__ ((gcc_struct)) __anon1;
292 } __attribute__ ((gcc_struct)) __anon2;
293 } __attribute__ ((gcc_struct)) __anon1;
294 } __attribute__ ((gcc_struct));
296 struct __ecereNameSpace__ecere__com__DataMember
298 struct __ecereNameSpace__ecere__com__DataMember * prev;
299 struct __ecereNameSpace__ecere__com__DataMember * next;
301 unsigned int isProperty;
304 struct __ecereNameSpace__ecere__com__Class * _class;
305 const char * dataTypeString;
306 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
307 struct __ecereNameSpace__ecere__com__Instance * dataType;
311 struct __ecereNameSpace__ecere__sys__OldList members;
312 struct __ecereNameSpace__ecere__sys__BinaryTree membersAlpha;
314 short structAlignment;
315 short pointerAlignment;
316 } __attribute__ ((gcc_struct));
318 struct __ecereNameSpace__ecere__com__Class
320 struct __ecereNameSpace__ecere__com__Class * prev;
321 struct __ecereNameSpace__ecere__com__Class * next;
327 unsigned int (* Constructor)(void * );
328 void (* Destructor)(void * );
331 struct __ecereNameSpace__ecere__com__Class * base;
332 struct __ecereNameSpace__ecere__sys__BinaryTree methods;
333 struct __ecereNameSpace__ecere__sys__BinaryTree members;
334 struct __ecereNameSpace__ecere__sys__BinaryTree prop;
335 struct __ecereNameSpace__ecere__sys__OldList membersAndProperties;
336 struct __ecereNameSpace__ecere__sys__BinaryTree classProperties;
337 struct __ecereNameSpace__ecere__sys__OldList derivatives;
341 struct __ecereNameSpace__ecere__com__Instance * module;
342 struct __ecereNameSpace__ecere__com__NameSpace * nameSpace;
343 const char * dataTypeString;
344 struct __ecereNameSpace__ecere__com__Instance * dataType;
346 int defaultAlignment;
347 void (* Initialize)();
349 struct __ecereNameSpace__ecere__sys__OldList selfWatchers;
350 const char * designerClass;
351 unsigned int noExpansion;
352 const char * defaultProperty;
353 unsigned int comRedefinition;
356 unsigned int internalDecl;
358 unsigned int computeSize;
359 short structAlignment;
360 short pointerAlignment;
361 int destructionWatchOffset;
363 struct __ecereNameSpace__ecere__sys__OldList delayedCPValues;
364 int inheritanceAccess;
365 const char * fullName;
367 struct __ecereNameSpace__ecere__sys__OldList conversions;
368 struct __ecereNameSpace__ecere__sys__OldList templateParams;
369 struct __ecereNameSpace__ecere__com__ClassTemplateArgument * templateArgs;
370 struct __ecereNameSpace__ecere__com__Class * templateClass;
371 struct __ecereNameSpace__ecere__sys__OldList templatized;
373 unsigned int isInstanceClass;
374 unsigned int byValueSystemClass;
375 } __attribute__ ((gcc_struct));
377 extern struct __ecereNameSpace__ecere__com__ClassTemplateParameter * __ecereNameSpace__ecere__com__eClass_AddTemplateParameter(struct __ecereNameSpace__ecere__com__Class * _class, const char * name, int type, const void * info, struct __ecereNameSpace__ecere__com__ClassTemplateArgument * defaultArg);
379 static struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__AVLTree;
381 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Instance;
383 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__CustomAVLTree;
385 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__AVLNode;
387 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__IteratorPointer;
389 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Module;
391 uint64 __ecereMethod___ecereNameSpace__ecere__com__AVLTree_GetData(struct __ecereNameSpace__ecere__com__Instance * this, struct __ecereNameSpace__ecere__com__AVLNode * node)
393 return node ? ((((struct __ecereNameSpace__ecere__com__Instance *)(char *)this)->_class->templateArgs[5].__anon1.__anon1.dataTypeClass->type == 1) ? (uint64)(uintptr_t)(((unsigned char *)&node->key) + __ENDIAN_PAD(sizeof(void *))) : node->key) : (uint64)0;
396 unsigned int __ecereMethod___ecereNameSpace__ecere__com__AVLTree_SetData(struct __ecereNameSpace__ecere__com__Instance * this, struct __ecereNameSpace__ecere__com__AVLNode * node, uint64 value)
398 if(!((struct __ecereNameSpace__ecere__com__IteratorPointer * (*)(struct __ecereNameSpace__ecere__com__Instance *, const uint64 value))__extension__ ({
399 struct __ecereNameSpace__ecere__com__Instance * __internal_ClassInst = this;
401 __internal_ClassInst ? __internal_ClassInst->_vTbl : __ecereClass___ecereNameSpace__ecere__com__AVLTree->_vTbl;
402 })[__ecereVMethodID___ecereNameSpace__ecere__com__Container_Find])(this, value))
404 ((void (*)(struct __ecereNameSpace__ecere__com__Instance *, struct __ecereNameSpace__ecere__com__IteratorPointer * it))__extension__ ({
405 struct __ecereNameSpace__ecere__com__Instance * __internal_ClassInst = this;
407 __internal_ClassInst ? __internal_ClassInst->_vTbl : __ecereClass___ecereNameSpace__ecere__com__AVLTree->_vTbl;
408 })[__ecereVMethodID___ecereNameSpace__ecere__com__Container_Remove])(this, (void *)(node));
409 if(((struct __ecereNameSpace__ecere__com__Instance *)(char *)this)->_class->templateArgs[5].__anon1.__anon1.dataTypeClass->type == 1)
410 memcpy((void *)(((unsigned char *)&node->key) + __ENDIAN_PAD(sizeof(void *))), (void *)(uintptr_t)value, ((struct __ecereNameSpace__ecere__com__Instance *)(char *)this)->_class->templateArgs[5].__anon1.__anon1.dataTypeClass->structSize);
413 ((struct __ecereNameSpace__ecere__com__IteratorPointer * (*)(struct __ecereNameSpace__ecere__com__Instance *, uint64 value))__ecereClass___ecereNameSpace__ecere__com__AVLTree->_vTbl[__ecereVMethodID___ecereNameSpace__ecere__com__Container_Add])(this, (uint64)(uintptr_t)node);
419 struct __ecereNameSpace__ecere__com__AVLNode * __ecereMethod___ecereNameSpace__ecere__com__AVLTree_Find(struct __ecereNameSpace__ecere__com__Instance * this, const uint64 key)
421 struct __ecereNameSpace__ecere__com__AVLNode * root = ((struct __ecereNameSpace__ecere__com__CustomAVLTree *)(((char *)this + 0 + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->root;
423 return root ? __ecereMethod___ecereNameSpace__ecere__com__AVLNode_Find(root, ((struct __ecereNameSpace__ecere__com__Instance *)(char *)this)->_class->templateArgs[5].__anon1.__anon1.dataTypeClass, key) : (((void *)0));
426 struct __ecereNameSpace__ecere__com__AVLNode * __ecereMethod___ecereNameSpace__ecere__com__AVLTree_FindAll(struct __ecereNameSpace__ecere__com__Instance * this, const uint64 key)
428 struct __ecereNameSpace__ecere__com__AVLNode * root = ((struct __ecereNameSpace__ecere__com__CustomAVLTree *)(((char *)this + 0 + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->root;
430 return root ? __ecereMethod___ecereNameSpace__ecere__com__AVLNode_FindAll(root, key) : (((void *)0));
433 struct __ecereNameSpace__ecere__com__AVLNode * __ecereMethod___ecereNameSpace__ecere__com__AVLTree_Add(struct __ecereNameSpace__ecere__com__Instance * this, uint64 value)
435 struct __ecereNameSpace__ecere__com__AVLNode * node;
437 if(((struct __ecereNameSpace__ecere__com__Instance *)(char *)this)->_class->templateArgs[5].__anon1.__anon1.dataTypeClass->type == 1)
439 node = (struct __ecereNameSpace__ecere__com__AVLNode *)__ecereNameSpace__ecere__com__eSystem_New0(sizeof(unsigned char) * (sizeof(struct __ecereNameSpace__ecere__com__AVLNode) + ((struct __ecereNameSpace__ecere__com__Instance *)(char *)this)->_class->templateArgs[5].__anon1.__anon1.dataTypeClass->structSize - sizeof node->key));
440 memcpy((void *)(((unsigned char *)&node->key) + __ENDIAN_PAD(sizeof(void *))), (void *)(uintptr_t)value, ((struct __ecereNameSpace__ecere__com__Instance *)(char *)this)->_class->templateArgs[5].__anon1.__anon1.dataTypeClass->structSize);
443 node = (struct __ecereNameSpace__ecere__com__AVLNode *)__extension__ ({
444 struct __ecereNameSpace__ecere__com__AVLNode * __ecereInstance1 = __ecereNameSpace__ecere__com__eSystem_New0(sizeof(struct __ecereNameSpace__ecere__com__AVLNode));
446 __ecereInstance1->key = value, __ecereInstance1;
448 if(!((struct __ecereNameSpace__ecere__com__IteratorPointer * (*)(struct __ecereNameSpace__ecere__com__Instance *, uint64 value))__ecereClass___ecereNameSpace__ecere__com__CustomAVLTree->_vTbl[__ecereVMethodID___ecereNameSpace__ecere__com__Container_Add])(this, (uint64)(uintptr_t)node))
449 ((node ? (__ecereClass___ecereNameSpace__ecere__com__AVLNode->Destructor ? __ecereClass___ecereNameSpace__ecere__com__AVLNode->Destructor((void *)node) : 0, __ecereClass___ecereNameSpace__ecere__com__IteratorPointer->Destructor ? __ecereClass___ecereNameSpace__ecere__com__IteratorPointer->Destructor((void *)node) : 0, __ecereNameSpace__ecere__com__eSystem_Delete(node)) : 0), node = 0);
453 void __ecereMethod___ecereNameSpace__ecere__com__AVLTree_Remove(struct __ecereNameSpace__ecere__com__Instance * this, struct __ecereNameSpace__ecere__com__AVLNode * node)
455 ((void (*)(struct __ecereNameSpace__ecere__com__Instance *, struct __ecereNameSpace__ecere__com__IteratorPointer * it))__ecereClass___ecereNameSpace__ecere__com__CustomAVLTree->_vTbl[__ecereVMethodID___ecereNameSpace__ecere__com__Container_Remove])(this, (void *)(node));
456 ((node ? (__ecereClass___ecereNameSpace__ecere__com__AVLNode->Destructor ? __ecereClass___ecereNameSpace__ecere__com__AVLNode->Destructor((void *)node) : 0, __ecereClass___ecereNameSpace__ecere__com__IteratorPointer->Destructor ? __ecereClass___ecereNameSpace__ecere__com__IteratorPointer->Destructor((void *)node) : 0, __ecereNameSpace__ecere__com__eSystem_Delete(node)) : 0), node = 0);
459 void __ecereRegisterModule_AVLTree(struct __ecereNameSpace__ecere__com__Instance * module)
461 struct __ecereNameSpace__ecere__com__Class __attribute__((unused)) * class;
463 class = __ecereNameSpace__ecere__com__eSystem_RegisterClass(0, "ecere::com::AVLTree", "ecere::com::CustomAVLTree<BT = ecere::com::AVLNode<AT>, KT = AT, T = AT, D = AT>", 0, 0, (void *)0, (void *)0, module, 4, 1);
464 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->application && class)
465 __ecereClass___ecereNameSpace__ecere__com__AVLTree = class;
466 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "GetData", 0, __ecereMethod___ecereNameSpace__ecere__com__AVLTree_GetData, 1);
467 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "SetData", 0, __ecereMethod___ecereNameSpace__ecere__com__AVLTree_SetData, 1);
468 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Add", 0, __ecereMethod___ecereNameSpace__ecere__com__AVLTree_Add, 1);
469 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Remove", 0, __ecereMethod___ecereNameSpace__ecere__com__AVLTree_Remove, 1);
470 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Find", 0, __ecereMethod___ecereNameSpace__ecere__com__AVLTree_Find, 1);
471 __ecereNameSpace__ecere__com__eClass_AddTemplateParameter(class, "AT", 0, 0, (((void *)0)));
472 __ecereNameSpace__ecere__com__eClass_DoneAddingTemplateParameters(class);
474 class->fixed = (unsigned int)1;