1 /* Code generated from eC source file: BTNode.ec */
3 typedef long long int64;
4 typedef unsigned long long uint64;
8 #elif defined(__TINYC__)
10 #define __builtin_va_list va_list
11 #define __builtin_va_start va_start
12 #define __builtin_va_end va_end
14 #define strcasecmp stricmp
15 #define strncasecmp strnicmp
16 #define __declspec(x) __attribute__((x))
20 typedef long long int64;
21 typedef unsigned long long uint64;
23 typedef __int64 int64;
24 typedef unsigned __int64 uint64;
27 #define __ENDIAN_PAD(x) (8 - (x))
29 #define __ENDIAN_PAD(x) 0
32 #include <sys/types.h>
34 #if /*defined(_W64) || */(defined(__WORDSIZE) && __WORDSIZE == 8) || defined(__x86_64__)
40 #define arch_PointerSize sizeof(void *)
41 #define structSize_Instance (_64BIT ? 24 : 12)
43 struct __ecereNameSpace__ecere__com__Instance;
45 extern void * __ecereNameSpace__ecere__com__eSystem_New(unsigned int size);
47 extern void * __ecereNameSpace__ecere__com__eSystem_New0(unsigned int size);
49 extern void * __ecereNameSpace__ecere__com__eSystem_Renew(void * memory, unsigned int size);
51 extern void * __ecereNameSpace__ecere__com__eSystem_Renew0(void * memory, unsigned int size);
53 extern void __ecereNameSpace__ecere__com__eSystem_Delete(void * memory);
55 struct __ecereNameSpace__ecere__sys__BTNode
58 struct __ecereNameSpace__ecere__sys__BTNode * parent, * left, * right;
60 } __attribute__ ((gcc_struct));
62 static struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__BTNode;
64 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__BinaryTree;
66 struct __ecereNameSpace__ecere__sys__BinaryTree
68 struct __ecereNameSpace__ecere__sys__BTNode * root;
70 int (* CompareKey)(struct __ecereNameSpace__ecere__sys__BinaryTree * tree, uintptr_t a, uintptr_t b);
71 void (* FreeKey)(void * key);
72 } __attribute__ ((gcc_struct));
74 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__OldList;
76 struct __ecereNameSpace__ecere__sys__OldList
83 } __attribute__ ((gcc_struct));
85 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Class;
87 struct __ecereNameSpace__ecere__com__Class
89 struct __ecereNameSpace__ecere__com__Class * prev;
90 struct __ecereNameSpace__ecere__com__Class * next;
96 int (* Constructor)(struct __ecereNameSpace__ecere__com__Instance *);
97 void (* Destructor)(struct __ecereNameSpace__ecere__com__Instance *);
100 struct __ecereNameSpace__ecere__com__Class * base;
101 struct __ecereNameSpace__ecere__sys__BinaryTree methods;
102 struct __ecereNameSpace__ecere__sys__BinaryTree members;
103 struct __ecereNameSpace__ecere__sys__BinaryTree prop;
104 struct __ecereNameSpace__ecere__sys__OldList membersAndProperties;
105 struct __ecereNameSpace__ecere__sys__BinaryTree classProperties;
106 struct __ecereNameSpace__ecere__sys__OldList derivatives;
110 struct __ecereNameSpace__ecere__com__Instance * module;
111 struct __ecereNameSpace__ecere__com__NameSpace * nameSpace;
112 const char * dataTypeString;
113 struct __ecereNameSpace__ecere__com__Instance * dataType;
115 int defaultAlignment;
116 void (* Initialize)();
118 struct __ecereNameSpace__ecere__sys__OldList selfWatchers;
119 const char * designerClass;
120 unsigned int noExpansion;
121 const char * defaultProperty;
122 unsigned int comRedefinition;
125 unsigned int internalDecl;
127 unsigned int computeSize;
129 int destructionWatchOffset;
131 struct __ecereNameSpace__ecere__sys__OldList delayedCPValues;
132 int inheritanceAccess;
133 const char * fullName;
135 struct __ecereNameSpace__ecere__sys__OldList conversions;
136 struct __ecereNameSpace__ecere__sys__OldList templateParams;
137 struct __ecereNameSpace__ecere__com__ClassTemplateArgument * templateArgs;
138 struct __ecereNameSpace__ecere__com__Class * templateClass;
139 struct __ecereNameSpace__ecere__sys__OldList templatized;
141 unsigned int isInstanceClass;
142 unsigned int byValueSystemClass;
143 } __attribute__ ((gcc_struct));
145 extern long long __ecereNameSpace__ecere__com__eClass_GetProperty(struct __ecereNameSpace__ecere__com__Class * _class, const char * name);
147 extern void __ecereNameSpace__ecere__com__eClass_SetProperty(struct __ecereNameSpace__ecere__com__Class * _class, const char * name, long long value);
149 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Property;
151 struct __ecereNameSpace__ecere__com__Property
153 struct __ecereNameSpace__ecere__com__Property * prev;
154 struct __ecereNameSpace__ecere__com__Property * next;
156 unsigned int isProperty;
159 struct __ecereNameSpace__ecere__com__Class * _class;
160 const char * dataTypeString;
161 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
162 struct __ecereNameSpace__ecere__com__Instance * dataType;
163 void (* Set)(void * , int);
164 int (* Get)(void * );
165 unsigned int (* IsSet)(void * );
169 unsigned int conversion;
170 unsigned int watcherOffset;
171 const char * category;
172 unsigned int compiled;
173 unsigned int selfWatchable;
174 unsigned int isWatchable;
175 } __attribute__ ((gcc_struct));
177 extern void __ecereNameSpace__ecere__com__eInstance_FireSelfWatchers(struct __ecereNameSpace__ecere__com__Instance * instance, struct __ecereNameSpace__ecere__com__Property * _property);
179 extern void __ecereNameSpace__ecere__com__eInstance_SetMethod(struct __ecereNameSpace__ecere__com__Instance * instance, const char * name, void * function);
181 extern void __ecereNameSpace__ecere__com__eInstance_IncRef(struct __ecereNameSpace__ecere__com__Instance * instance);
183 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);
185 extern void __ecereNameSpace__ecere__com__eInstance_Watch(void * instance, struct __ecereNameSpace__ecere__com__Property * _property, void * object, void (* callback)(void * , void * ));
187 extern void __ecereNameSpace__ecere__com__eInstance_FireWatchers(struct __ecereNameSpace__ecere__com__Instance * instance, struct __ecereNameSpace__ecere__com__Property * _property);
189 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Instance;
191 struct __ecereNameSpace__ecere__com__Instance
194 struct __ecereNameSpace__ecere__com__Class * _class;
196 } __attribute__ ((gcc_struct));
198 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__DataMember;
200 struct __ecereNameSpace__ecere__com__DataMember
202 struct __ecereNameSpace__ecere__com__DataMember * prev;
203 struct __ecereNameSpace__ecere__com__DataMember * next;
205 unsigned int isProperty;
208 struct __ecereNameSpace__ecere__com__Class * _class;
209 const char * dataTypeString;
210 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
211 struct __ecereNameSpace__ecere__com__Instance * dataType;
215 struct __ecereNameSpace__ecere__sys__OldList members;
216 struct __ecereNameSpace__ecere__sys__BinaryTree membersAlpha;
219 } __attribute__ ((gcc_struct));
221 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Method;
223 struct __ecereNameSpace__ecere__com__Method
226 struct __ecereNameSpace__ecere__com__Method * parent;
227 struct __ecereNameSpace__ecere__com__Method * left;
228 struct __ecereNameSpace__ecere__com__Method * right;
233 struct __ecereNameSpace__ecere__com__Class * _class;
235 const char * dataTypeString;
236 struct __ecereNameSpace__ecere__com__Instance * dataType;
238 } __attribute__ ((gcc_struct));
240 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__SerialBuffer;
242 struct __ecereNameSpace__ecere__com__SerialBuffer
244 unsigned char * _buffer;
248 } __attribute__ ((gcc_struct));
250 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__DataValue;
252 struct __ecereNameSpace__ecere__com__DataValue
267 } __attribute__ ((gcc_struct)) __anon1;
268 } __attribute__ ((gcc_struct));
270 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__ClassTemplateArgument;
272 struct __ecereNameSpace__ecere__com__ClassTemplateArgument
278 const char * dataTypeString;
279 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
280 } __attribute__ ((gcc_struct)) __anon1;
281 struct __ecereNameSpace__ecere__com__DataValue expression;
284 const char * memberString;
287 struct __ecereNameSpace__ecere__com__DataMember * member;
288 struct __ecereNameSpace__ecere__com__Property * prop;
289 struct __ecereNameSpace__ecere__com__Method * method;
290 } __attribute__ ((gcc_struct)) __anon1;
291 } __attribute__ ((gcc_struct)) __anon2;
292 } __attribute__ ((gcc_struct)) __anon1;
293 } __attribute__ ((gcc_struct));
295 typedef __builtin_va_list va_list;
297 static struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__TreePrintStyle;
299 extern int vsprintf(char * , const char * , __builtin_va_list);
301 extern size_t strlen(const char * );
303 void __ecereNameSpace__ecere__sys__strcatf(char * string, const char * format, ...)
307 __builtin_va_start(args, format);
308 vsprintf(string + strlen(string), format, args);
309 __builtin_va_end(args);
312 static struct __ecereNameSpace__ecere__com__Property * __ecereProp___ecereNameSpace__ecere__sys__BTNode_prev, * __ecerePropM___ecereNameSpace__ecere__sys__BTNode_prev;
314 static struct __ecereNameSpace__ecere__com__Property * __ecereProp___ecereNameSpace__ecere__sys__BTNode_next, * __ecerePropM___ecereNameSpace__ecere__sys__BTNode_next;
316 static struct __ecereNameSpace__ecere__com__Property * __ecereProp___ecereNameSpace__ecere__sys__BTNode_count, * __ecerePropM___ecereNameSpace__ecere__sys__BTNode_count;
318 static struct __ecereNameSpace__ecere__com__Property * __ecereProp___ecereNameSpace__ecere__sys__BTNode_balanceFactor, * __ecerePropM___ecereNameSpace__ecere__sys__BTNode_balanceFactor;
320 void __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(struct __ecereNameSpace__ecere__com__Instance * this, struct __ecereNameSpace__ecere__com__Class * class, const void * data);
322 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_bool;
324 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_uint;
326 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_OnSerialize(struct __ecereNameSpace__ecere__com__Class * class, struct __ecereNameSpace__ecere__sys__BTNode * this, struct __ecereNameSpace__ecere__com__Instance * channel)
328 if((struct __ecereNameSpace__ecere__sys__BTNode *)this)
330 unsigned int __internalValue000;
331 unsigned int truth = 1;
333 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(channel, __ecereClass_bool, &truth);
334 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(channel, __ecereClass_uint, __extension__ ({
335 __internalValue000 = (unsigned int)this->key;
338 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(channel, __ecereClass___ecereNameSpace__ecere__sys__BTNode, this->left);
339 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(channel, __ecereClass___ecereNameSpace__ecere__sys__BTNode, this->right);
343 unsigned int nothing = 0;
345 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(channel, __ecereClass_uint, ¬hing);
349 extern void * __ecereNameSpace__ecere__com__eInstance_New(struct __ecereNameSpace__ecere__com__Class * _class);
351 void __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Unserialize(struct __ecereNameSpace__ecere__com__Instance * this, struct __ecereNameSpace__ecere__com__Class * class, void * * data);
353 int __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_depthProp(struct __ecereNameSpace__ecere__sys__BTNode * this);
355 static struct __ecereNameSpace__ecere__com__Property * __ecereProp___ecereNameSpace__ecere__sys__BTNode_depthProp, * __ecerePropM___ecereNameSpace__ecere__sys__BTNode_depthProp;
357 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_OnUnserialize(struct __ecereNameSpace__ecere__com__Class * class, struct __ecereNameSpace__ecere__sys__BTNode ** this, struct __ecereNameSpace__ecere__com__Instance * channel)
361 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Unserialize(channel, __ecereClass_bool, &truth);
364 (*this) = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass___ecereNameSpace__ecere__sys__BTNode);
368 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Unserialize(channel, __ecereClass_uint, &k);
371 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Unserialize(channel, __ecereClass___ecereNameSpace__ecere__sys__BTNode, &(*this)->left);
374 (*this)->left->parent = *(struct __ecereNameSpace__ecere__sys__BTNode **)this;
376 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Unserialize(channel, __ecereClass___ecereNameSpace__ecere__sys__BTNode, &(*this)->right);
379 (*this)->right->parent = *(struct __ecereNameSpace__ecere__sys__BTNode **)this;
381 (*this)->depth = __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_depthProp((*(struct __ecereNameSpace__ecere__sys__BTNode **)this));
384 (*this) = (((void *)0));
387 struct __ecereNameSpace__ecere__sys__BTNode * __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_maximum(struct __ecereNameSpace__ecere__sys__BTNode * this);
389 static struct __ecereNameSpace__ecere__com__Property * __ecereProp___ecereNameSpace__ecere__sys__BTNode_maximum, * __ecerePropM___ecereNameSpace__ecere__sys__BTNode_maximum;
391 struct __ecereNameSpace__ecere__sys__BTNode * __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_prev(struct __ecereNameSpace__ecere__sys__BTNode * this)
394 return __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_maximum(this->left);
397 if(this->parent && this == this->parent->right)
405 struct __ecereNameSpace__ecere__sys__BTNode * __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_minimum(struct __ecereNameSpace__ecere__sys__BTNode * this);
407 static struct __ecereNameSpace__ecere__com__Property * __ecereProp___ecereNameSpace__ecere__sys__BTNode_minimum, * __ecerePropM___ecereNameSpace__ecere__sys__BTNode_minimum;
409 struct __ecereNameSpace__ecere__sys__BTNode * __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_next(struct __ecereNameSpace__ecere__sys__BTNode * this)
411 struct __ecereNameSpace__ecere__sys__BTNode * right = this->right;
414 return __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_minimum(right);
417 struct __ecereNameSpace__ecere__sys__BTNode * parent = this->parent;
419 if(parent && this == parent->left)
424 return (((void *)0));
427 struct __ecereNameSpace__ecere__sys__BTNode * __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_minimum(struct __ecereNameSpace__ecere__sys__BTNode * this)
434 struct __ecereNameSpace__ecere__sys__BTNode * __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_maximum(struct __ecereNameSpace__ecere__sys__BTNode * this)
441 int __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_count(struct __ecereNameSpace__ecere__sys__BTNode * this)
443 return 1 + (this->left ? __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_count(this->left) : 0) + (this->right ? __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_count(this->right) : 0);
446 int __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_depthProp(struct __ecereNameSpace__ecere__sys__BTNode * this)
448 int leftDepth = this->left ? (__ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_depthProp(this->left) + 1) : 0;
449 int rightDepth = this->right ? (__ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_depthProp(this->right) + 1) : 0;
451 return ((leftDepth > rightDepth) ? leftDepth : rightDepth);
454 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Free(struct __ecereNameSpace__ecere__sys__BTNode * this, void (* FreeKey)(void * key))
457 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Free(this->left, FreeKey);
459 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Free(this->right, FreeKey);
461 FreeKey((void *)this->key);
462 ((this ? (__ecereClass___ecereNameSpace__ecere__sys__BTNode->Destructor ? __ecereClass___ecereNameSpace__ecere__sys__BTNode->Destructor((void *)this) : 0, __ecereNameSpace__ecere__com__eSystem_Delete(this)) : 0), this = 0);
465 unsigned int __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Add(struct __ecereNameSpace__ecere__sys__BTNode * this, struct __ecereNameSpace__ecere__sys__BinaryTree * tree, struct __ecereNameSpace__ecere__sys__BTNode * node)
467 uintptr_t newKey = node->key;
471 int result = tree->CompareKey(tree, newKey, this->key);
487 struct __ecereNameSpace__ecere__sys__BTNode * n;
489 for(n = this; n; n = n->parent)
491 int __simpleStruct0, __simpleStruct1;
492 int newDepth = (__simpleStruct0 = n->left ? (n->left->depth + 1) : 0, __simpleStruct1 = n->right ? (n->right->depth + 1) : 0, (__simpleStruct0 > __simpleStruct1) ? __simpleStruct0 : __simpleStruct1);
494 if(newDepth == n->depth)
512 struct __ecereNameSpace__ecere__sys__BTNode * n;
514 for(n = this; n; n = n->parent)
516 int __simpleStruct0, __simpleStruct1;
517 int newDepth = (__simpleStruct0 = n->left ? (n->left->depth + 1) : 0, __simpleStruct1 = n->right ? (n->right->depth + 1) : 0, (__simpleStruct0 > __simpleStruct1) ? __simpleStruct0 : __simpleStruct1);
519 if(newDepth == n->depth)
530 unsigned int __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindNode(struct __ecereNameSpace__ecere__sys__BTNode * this, struct __ecereNameSpace__ecere__sys__BTNode * node)
534 else if(this->left && __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindNode(this->left, node))
536 else if(this->right && __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindNode(this->right, node))
541 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Find(struct __ecereNameSpace__ecere__sys__BTNode * this, struct __ecereNameSpace__ecere__sys__BinaryTree * tree, uintptr_t key)
545 int result = tree->CompareKey(tree, key, this->key);
557 extern int strcmp(const char * , const char * );
559 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindString(struct __ecereNameSpace__ecere__sys__BTNode * this, const char * key)
566 result = strcmp(key, (const char *)this->key);
567 else if(key && !this->key)
569 else if(!key && this->key)
583 extern int strncmp(const char * , const char * , size_t n);
585 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindPrefix(struct __ecereNameSpace__ecere__sys__BTNode * this, const char * key)
587 struct __ecereNameSpace__ecere__sys__BTNode * subString = (((void *)0));
588 int len = key ? strlen(key) : 0;
595 result = strcmp(key, (const char *)this->key);
596 else if(key && !this->key)
598 else if(!key && this->key)
604 if(!strncmp(key, (const char *)this->key, len))
619 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindAll(struct __ecereNameSpace__ecere__sys__BTNode * this, uintptr_t key)
621 struct __ecereNameSpace__ecere__sys__BTNode * result = (((void *)0));
625 if(!result && this->left)
626 result = __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindAll(this->left, key);
627 if(!result && this->right)
628 result = __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindAll(this->right, key);
632 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_RemoveSwap(struct __ecereNameSpace__ecere__sys__BTNode * this, struct __ecereNameSpace__ecere__sys__BTNode * swap)
636 swap->left->parent = swap->parent;
637 if(swap == swap->parent->left)
638 swap->parent->left = swap->left;
639 else if(swap == swap->parent->right)
640 swap->parent->right = swap->left;
641 swap->left = (((void *)0));
645 swap->right->parent = swap->parent;
646 if(swap == swap->parent->left)
647 swap->parent->left = swap->right;
648 else if(swap == swap->parent->right)
649 swap->parent->right = swap->right;
650 swap->right = (((void *)0));
652 if(swap == swap->parent->left)
653 swap->parent->left = (((void *)0));
654 else if(swap == swap->parent->right)
655 swap->parent->right = (((void *)0));
657 struct __ecereNameSpace__ecere__sys__BTNode * n;
659 for(n = swap->parent; n; n = n->parent)
661 int __simpleStruct0, __simpleStruct1;
662 int newDepth = (__simpleStruct0 = n->left ? (n->left->depth + 1) : 0, __simpleStruct1 = n->right ? (n->right->depth + 1) : 0, (__simpleStruct0 > __simpleStruct1) ? __simpleStruct0 : __simpleStruct1);
664 if(newDepth == n->depth)
672 swap->left = this->left;
674 this->left->parent = swap;
677 swap->right = this->right;
679 this->right->parent = swap;
681 swap->parent = this->parent;
682 this->left = (((void *)0));
683 this->right = (((void *)0));
686 if(this == this->parent->left)
687 this->parent->left = swap;
688 else if(this == this->parent->right)
689 this->parent->right = swap;
693 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Rebalance();
695 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_RemoveSwapLeft(struct __ecereNameSpace__ecere__sys__BTNode * this)
697 struct __ecereNameSpace__ecere__sys__BTNode * swap = this->left ? __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_maximum(this->left) : this->right;
698 struct __ecereNameSpace__ecere__sys__BTNode * swapParent = (((void *)0));
702 swapParent = swap->parent;
703 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_RemoveSwap(this, swap);
707 if(this == this->parent->left)
708 this->parent->left = (((void *)0));
709 else if(this == this->parent->right)
710 this->parent->right = (((void *)0));
713 struct __ecereNameSpace__ecere__sys__BTNode * n;
715 for(n = swap ? swap : this->parent; n; n = n->parent)
717 int __simpleStruct0, __simpleStruct1;
718 int newDepth = (__simpleStruct0 = n->left ? (n->left->depth + 1) : 0, __simpleStruct1 = n->right ? (n->right->depth + 1) : 0, (__simpleStruct0 > __simpleStruct1) ? __simpleStruct0 : __simpleStruct1);
720 if(newDepth == n->depth && n != swap)
725 if(swapParent && swapParent != this)
726 return __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Rebalance(swapParent);
728 return __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Rebalance(swap);
729 else if(this->parent)
730 return __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Rebalance(this->parent);
732 return (((void *)0));
735 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_RemoveSwapRight(struct __ecereNameSpace__ecere__sys__BTNode * this)
737 struct __ecereNameSpace__ecere__sys__BTNode * result;
738 struct __ecereNameSpace__ecere__sys__BTNode * swap = this->right ? __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_minimum(this->right) : this->left;
739 struct __ecereNameSpace__ecere__sys__BTNode * swapParent = (((void *)0));
743 swapParent = swap->parent;
744 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_RemoveSwap(this, swap);
748 if(this == this->parent->left)
749 this->parent->left = (((void *)0));
750 else if(this == this->parent->right)
751 this->parent->right = (((void *)0));
754 struct __ecereNameSpace__ecere__sys__BTNode * n;
756 for(n = swap ? swap : this->parent; n; n = n->parent)
758 int __simpleStruct0, __simpleStruct1;
759 int newDepth = (__simpleStruct0 = n->left ? (n->left->depth + 1) : 0, __simpleStruct1 = n->right ? (n->right->depth + 1) : 0, (__simpleStruct0 > __simpleStruct1) ? __simpleStruct0 : __simpleStruct1);
761 if(newDepth == n->depth && n != swap)
766 if(swapParent && swapParent != this)
767 result = __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Rebalance(swapParent);
769 result = __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Rebalance(swap);
770 else if(this->parent)
771 result = __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Rebalance(this->parent);
773 result = (((void *)0));
777 int __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_balanceFactor(struct __ecereNameSpace__ecere__sys__BTNode * this)
779 int leftDepth = this->left ? (this->left->depth + 1) : 0;
780 int rightDepth = this->right ? (this->right->depth + 1) : 0;
782 return rightDepth - leftDepth;
785 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_DoubleRotateRight();
787 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_SingleRotateRight();
789 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_DoubleRotateLeft();
791 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_SingleRotateLeft();
793 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Rebalance(struct __ecereNameSpace__ecere__sys__BTNode * this)
797 int factor = __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_balanceFactor(this);
801 if(__ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_balanceFactor(this->left) == 1)
802 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_DoubleRotateRight(this);
804 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_SingleRotateRight(this);
808 if(__ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_balanceFactor(this->right) == -1)
809 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_DoubleRotateLeft(this);
811 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_SingleRotateLeft(this);
820 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_SingleRotateRight(struct __ecereNameSpace__ecere__sys__BTNode * this)
822 int __simpleStruct2, __simpleStruct3;
823 int __simpleStruct0, __simpleStruct1;
827 if(this == this->parent->left)
828 this->parent->left = this->left;
829 else if(this == this->parent->right)
830 this->parent->right = this->left;
832 this->left->parent = this->parent;
833 this->parent = this->left;
834 this->left = this->parent->right;
836 this->left->parent = this;
837 this->parent->right = this;
838 this->depth = (__simpleStruct0 = this->left ? (this->left->depth + 1) : 0, __simpleStruct1 = this->right ? (this->right->depth + 1) : 0, (__simpleStruct0 > __simpleStruct1) ? __simpleStruct0 : __simpleStruct1);
839 this->parent->depth = (__simpleStruct2 = this->parent->left ? (this->parent->left->depth + 1) : 0, __simpleStruct3 = this->parent->right ? (this->parent->right->depth + 1) : 0, (__simpleStruct2 > __simpleStruct3) ? __simpleStruct2 : __simpleStruct3);
841 struct __ecereNameSpace__ecere__sys__BTNode * n;
843 for(n = this->parent->parent; n; n = n->parent)
845 int __simpleStruct0, __simpleStruct1;
846 int newDepth = (__simpleStruct0 = n->left ? (n->left->depth + 1) : 0, __simpleStruct1 = n->right ? (n->right->depth + 1) : 0, (__simpleStruct0 > __simpleStruct1) ? __simpleStruct0 : __simpleStruct1);
848 if(newDepth == n->depth)
855 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_SingleRotateLeft(struct __ecereNameSpace__ecere__sys__BTNode * this)
857 int __simpleStruct2, __simpleStruct3;
858 int __simpleStruct0, __simpleStruct1;
862 if(this == this->parent->right)
863 this->parent->right = this->right;
864 else if(this == this->parent->left)
865 this->parent->left = this->right;
867 this->right->parent = this->parent;
868 this->parent = this->right;
869 this->right = this->parent->left;
871 this->right->parent = this;
872 this->parent->left = this;
873 this->depth = (__simpleStruct0 = this->left ? (this->left->depth + 1) : 0, __simpleStruct1 = this->right ? (this->right->depth + 1) : 0, (__simpleStruct0 > __simpleStruct1) ? __simpleStruct0 : __simpleStruct1);
874 this->parent->depth = (__simpleStruct2 = this->parent->left ? (this->parent->left->depth + 1) : 0, __simpleStruct3 = this->parent->right ? (this->parent->right->depth + 1) : 0, (__simpleStruct2 > __simpleStruct3) ? __simpleStruct2 : __simpleStruct3);
876 struct __ecereNameSpace__ecere__sys__BTNode * n;
878 for(n = this->parent->parent; n; n = n->parent)
880 int __simpleStruct0, __simpleStruct1;
881 int newDepth = (__simpleStruct0 = n->left ? (n->left->depth + 1) : 0, __simpleStruct1 = n->right ? (n->right->depth + 1) : 0, (__simpleStruct0 > __simpleStruct1) ? __simpleStruct0 : __simpleStruct1);
883 if(newDepth == n->depth)
890 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_DoubleRotateRight(struct __ecereNameSpace__ecere__sys__BTNode * this)
892 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_SingleRotateLeft(this->left);
893 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_SingleRotateRight(this);
896 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_DoubleRotateLeft(struct __ecereNameSpace__ecere__sys__BTNode * this)
898 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_SingleRotateRight(this->right);
899 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_SingleRotateLeft(this);
902 extern char * strcat(char * , const char * );
904 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_PrintDepth(struct __ecereNameSpace__ecere__sys__BTNode * this, char * output, int wantedDepth, int curDepth, int maxDepth, unsigned int last);
906 char * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Print(struct __ecereNameSpace__ecere__sys__BTNode * this, char * output, int tps)
915 __ecereNameSpace__ecere__sys__strcatf(output, "%d ", this->key);
917 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Print(this->left, output, tps);
919 __ecereNameSpace__ecere__sys__strcatf(output, "%d ", this->key);
921 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Print(this->right, output, tps);
923 __ecereNameSpace__ecere__sys__strcatf(output, "%d ", this->key);
928 int maxDepth = this->depth;
931 for(curDepth = 0; curDepth <= maxDepth; curDepth++)
935 for(c = 0; c < ((1 << (maxDepth - curDepth)) - 1) * 4 / 2; c++)
937 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_PrintDepth(this, output, curDepth, 0, maxDepth, 1);
938 strcat(output, "\n");
943 return (((void *)0));
946 extern int sprintf(char * , const char * , ...);
948 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_PrintDepth(struct __ecereNameSpace__ecere__sys__BTNode * this, char * output, int wantedDepth, int curDepth, int maxDepth, unsigned int last)
952 if(wantedDepth == curDepth)
954 char nodeString[10] = "";
958 sprintf(nodeString, "%d", (int)this->key);
959 len = strlen(nodeString);
960 for(c = 0; c < (4 - len) / 2; c++)
963 strcat(output, nodeString);
964 for(c = len; c < 4; c++)
966 if(curDepth && !last)
968 for(c = 0; c < ((1 << (maxDepth - curDepth)) - 1) * 4; c++)
972 else if(curDepth <= maxDepth)
974 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_PrintDepth((this ? this->left : (struct __ecereNameSpace__ecere__sys__BTNode *)(((void *)0))), output, wantedDepth, curDepth + 1, maxDepth, last && this && !this->right);
975 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_PrintDepth((this ? this->right : (struct __ecereNameSpace__ecere__sys__BTNode *)(((void *)0))), output, wantedDepth, curDepth + 1, maxDepth, last);
979 extern int printf(const char * , ...);
981 unsigned int __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Check(struct __ecereNameSpace__ecere__sys__BTNode * this, struct __ecereNameSpace__ecere__sys__BinaryTree * tree)
983 unsigned int valid = 1;
984 int leftHeight = this->left ? __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_depthProp(this->left) + 1 : 0;
985 int rightHeight = this->right ? __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_depthProp(this->right) + 1 : 0;
986 int diffHeight = rightHeight - leftHeight;
990 if(this->left->parent != this)
992 printf("Parent not set properly at node %d\n", (int)this->left->key);
995 valid *= __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Check(this->left, tree);
999 if(this->right->parent != this)
1001 printf("Parent not set properly at node %d\n", (int)this->right->key);
1004 valid *= __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Check(this->right, tree);
1006 if(this->depth != __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_depthProp(this))
1008 printf("Depth value at node %d (%d) doesn't match depth property (%d)\n", (int)this->key, this->depth, __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_depthProp(this));
1009 valid = (unsigned int)0;
1011 if(diffHeight < -1 || diffHeight > 1)
1013 valid = (unsigned int)0;
1014 printf("Height difference is %d at node %d\n", diffHeight, (int)this->key);
1016 if(diffHeight != __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_balanceFactor(this))
1018 valid = (unsigned int)0;
1019 printf("Height difference %d doesnt match balance-factor of %d at node %d\n", diffHeight, __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_balanceFactor(this), (int)this->key);
1021 if(this->left && tree->CompareKey(tree, this->left->key, this->key) > 0)
1024 printf("Node %d is *smaller* than left subtree %d\n", (int)this->key, (int)this->left->key);
1026 if(this->right && tree->CompareKey(tree, this->right->key, this->key) < 0)
1029 printf("Node %d is *greater* than right subtree %d\n", (int)this->key, (int)this->right->key);
1034 struct __ecereNameSpace__ecere__sys__StringBTNode
1037 struct __ecereNameSpace__ecere__sys__StringBTNode * parent, * left, * right;
1039 } __attribute__ ((gcc_struct));
1041 static struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__StringBTNode;
1043 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_String;
1045 void __ecereMethod___ecereNameSpace__ecere__sys__StringBTNode_OnSerialize(struct __ecereNameSpace__ecere__com__Class * class, struct __ecereNameSpace__ecere__sys__StringBTNode * this, struct __ecereNameSpace__ecere__com__Instance * channel)
1047 if((struct __ecereNameSpace__ecere__sys__StringBTNode *)this)
1049 unsigned int truth = 1;
1051 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(channel, __ecereClass_bool, &truth);
1052 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(channel, __ecereClass_String, this->key);
1053 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(channel, __ecereClass___ecereNameSpace__ecere__sys__StringBTNode, this->left);
1054 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(channel, __ecereClass___ecereNameSpace__ecere__sys__StringBTNode, this->right);
1058 unsigned int nothing = 0;
1060 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(channel, __ecereClass_uint, ¬hing);
1064 void __ecereMethod___ecereNameSpace__ecere__sys__StringBTNode_OnUnserialize(struct __ecereNameSpace__ecere__com__Class * class, struct __ecereNameSpace__ecere__sys__StringBTNode ** this, struct __ecereNameSpace__ecere__com__Instance * channel)
1068 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Unserialize(channel, __ecereClass_bool, &truth);
1071 (*this) = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass___ecereNameSpace__ecere__sys__StringBTNode);
1072 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Unserialize(channel, __ecereClass_String, &(*this)->key);
1073 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Unserialize(channel, __ecereClass___ecereNameSpace__ecere__sys__StringBTNode, &(*this)->left);
1076 (*this)->left->parent = *(struct __ecereNameSpace__ecere__sys__StringBTNode **)this;
1078 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Unserialize(channel, __ecereClass___ecereNameSpace__ecere__sys__StringBTNode, &(*this)->right);
1081 (*this)->right->parent = *(struct __ecereNameSpace__ecere__sys__StringBTNode **)this;
1083 (*this)->depth = __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_depthProp(((struct __ecereNameSpace__ecere__sys__BTNode *)*(struct __ecereNameSpace__ecere__sys__StringBTNode **)this));
1086 (*this) = (((void *)0));
1089 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);
1091 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__NameSpace;
1093 struct __ecereNameSpace__ecere__com__NameSpace
1096 struct __ecereNameSpace__ecere__com__NameSpace * btParent;
1097 struct __ecereNameSpace__ecere__com__NameSpace * left;
1098 struct __ecereNameSpace__ecere__com__NameSpace * right;
1100 struct __ecereNameSpace__ecere__com__NameSpace * parent;
1101 struct __ecereNameSpace__ecere__sys__BinaryTree nameSpaces;
1102 struct __ecereNameSpace__ecere__sys__BinaryTree classes;
1103 struct __ecereNameSpace__ecere__sys__BinaryTree defines;
1104 struct __ecereNameSpace__ecere__sys__BinaryTree functions;
1105 } __attribute__ ((gcc_struct));
1107 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Module;
1109 struct __ecereNameSpace__ecere__com__Module
1111 struct __ecereNameSpace__ecere__com__Instance * application;
1112 struct __ecereNameSpace__ecere__sys__OldList classes;
1113 struct __ecereNameSpace__ecere__sys__OldList defines;
1114 struct __ecereNameSpace__ecere__sys__OldList functions;
1115 struct __ecereNameSpace__ecere__sys__OldList modules;
1116 struct __ecereNameSpace__ecere__com__Instance * prev;
1117 struct __ecereNameSpace__ecere__com__Instance * next;
1123 struct __ecereNameSpace__ecere__com__NameSpace privateNameSpace;
1124 struct __ecereNameSpace__ecere__com__NameSpace publicNameSpace;
1125 } __attribute__ ((gcc_struct));
1127 extern struct __ecereNameSpace__ecere__com__Instance * __thisModule;
1129 extern void __ecereNameSpace__ecere__com__eEnum_AddFixedValue(struct __ecereNameSpace__ecere__com__Class * _class, const char * string, long long value);
1131 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__GlobalFunction;
1133 struct __ecereNameSpace__ecere__com__GlobalFunction;
1135 extern struct __ecereNameSpace__ecere__com__GlobalFunction * __ecereNameSpace__ecere__com__eSystem_RegisterFunction(const char * name, const char * type, void * func, struct __ecereNameSpace__ecere__com__Instance * module, int declMode);
1137 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);
1139 extern struct __ecereNameSpace__ecere__com__DataMember * __ecereNameSpace__ecere__com__eClass_AddDataMember(struct __ecereNameSpace__ecere__com__Class * _class, const char * name, const char * type, unsigned int size, unsigned int alignment, int declMode);
1141 extern struct __ecereNameSpace__ecere__com__Property * __ecereNameSpace__ecere__com__eClass_AddProperty(struct __ecereNameSpace__ecere__com__Class * _class, const char * name, const char * dataType, void * setStmt, void * getStmt, int declMode);
1143 void __ecereRegisterModule_BTNode(struct __ecereNameSpace__ecere__com__Instance * module)
1145 struct __ecereNameSpace__ecere__com__Class __attribute__((unused)) * class;
1147 class = __ecereNameSpace__ecere__com__eSystem_RegisterClass(4, "ecere::sys::TreePrintStyle", 0, 0, 0, 0, 0, module, 4, 1);
1148 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application && class)
1149 __ecereClass___ecereNameSpace__ecere__sys__TreePrintStyle = class;
1150 __ecereNameSpace__ecere__com__eEnum_AddFixedValue(class, "inOrder", 0);
1151 __ecereNameSpace__ecere__com__eEnum_AddFixedValue(class, "postOrder", 1);
1152 __ecereNameSpace__ecere__com__eEnum_AddFixedValue(class, "preOrder", 2);
1153 __ecereNameSpace__ecere__com__eEnum_AddFixedValue(class, "depthOrder", 3);
1154 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ecere::sys::strcatf", "void ecere::sys::strcatf(char * string, const char * format, ...)", __ecereNameSpace__ecere__sys__strcatf, module, 4);
1155 class = __ecereNameSpace__ecere__com__eSystem_RegisterClass(5, "ecere::sys::BTNode", 0, sizeof(struct __ecereNameSpace__ecere__sys__BTNode), 0, 0, 0, module, 4, 1);
1156 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application && class)
1157 __ecereClass___ecereNameSpace__ecere__sys__BTNode = class;
1158 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "OnSerialize", 0, __ecereMethod___ecereNameSpace__ecere__sys__BTNode_OnSerialize, 1);
1159 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "OnUnserialize", 0, __ecereMethod___ecereNameSpace__ecere__sys__BTNode_OnUnserialize, 1);
1160 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "FindPrefix", "ecere::sys::BTNode FindPrefix(const char * key)", __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindPrefix, 1);
1161 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "FindString", "ecere::sys::BTNode FindString(const char * key)", __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindString, 1);
1162 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "key", "uintptr", arch_PointerSize, arch_PointerSize, 1);
1163 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "parent", "ecere::sys::BTNode", arch_PointerSize, arch_PointerSize, 1);
1164 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "left", "ecere::sys::BTNode", arch_PointerSize, arch_PointerSize, 1);
1165 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "right", "ecere::sys::BTNode", arch_PointerSize, arch_PointerSize, 1);
1166 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "depth", "int", 4, 4, 1);
1167 __ecerePropM___ecereNameSpace__ecere__sys__BTNode_prev = __ecereNameSpace__ecere__com__eClass_AddProperty(class, "prev", "ecere::sys::BTNode", 0, __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_prev, 1);
1168 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application)
1169 __ecereProp___ecereNameSpace__ecere__sys__BTNode_prev = __ecerePropM___ecereNameSpace__ecere__sys__BTNode_prev, __ecerePropM___ecereNameSpace__ecere__sys__BTNode_prev = (void *)0;
1170 __ecerePropM___ecereNameSpace__ecere__sys__BTNode_next = __ecereNameSpace__ecere__com__eClass_AddProperty(class, "next", "ecere::sys::BTNode", 0, __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_next, 1);
1171 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application)
1172 __ecereProp___ecereNameSpace__ecere__sys__BTNode_next = __ecerePropM___ecereNameSpace__ecere__sys__BTNode_next, __ecerePropM___ecereNameSpace__ecere__sys__BTNode_next = (void *)0;
1173 __ecerePropM___ecereNameSpace__ecere__sys__BTNode_minimum = __ecereNameSpace__ecere__com__eClass_AddProperty(class, "minimum", "ecere::sys::BTNode", 0, __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_minimum, 1);
1174 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application)
1175 __ecereProp___ecereNameSpace__ecere__sys__BTNode_minimum = __ecerePropM___ecereNameSpace__ecere__sys__BTNode_minimum, __ecerePropM___ecereNameSpace__ecere__sys__BTNode_minimum = (void *)0;
1176 __ecerePropM___ecereNameSpace__ecere__sys__BTNode_maximum = __ecereNameSpace__ecere__com__eClass_AddProperty(class, "maximum", "ecere::sys::BTNode", 0, __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_maximum, 1);
1177 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application)
1178 __ecereProp___ecereNameSpace__ecere__sys__BTNode_maximum = __ecerePropM___ecereNameSpace__ecere__sys__BTNode_maximum, __ecerePropM___ecereNameSpace__ecere__sys__BTNode_maximum = (void *)0;
1179 __ecerePropM___ecereNameSpace__ecere__sys__BTNode_count = __ecereNameSpace__ecere__com__eClass_AddProperty(class, "count", "int", 0, __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_count, 1);
1180 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application)
1181 __ecereProp___ecereNameSpace__ecere__sys__BTNode_count = __ecerePropM___ecereNameSpace__ecere__sys__BTNode_count, __ecerePropM___ecereNameSpace__ecere__sys__BTNode_count = (void *)0;
1182 __ecerePropM___ecereNameSpace__ecere__sys__BTNode_depthProp = __ecereNameSpace__ecere__com__eClass_AddProperty(class, "depthProp", "int", 0, __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_depthProp, 1);
1183 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application)
1184 __ecereProp___ecereNameSpace__ecere__sys__BTNode_depthProp = __ecerePropM___ecereNameSpace__ecere__sys__BTNode_depthProp, __ecerePropM___ecereNameSpace__ecere__sys__BTNode_depthProp = (void *)0;
1185 __ecerePropM___ecereNameSpace__ecere__sys__BTNode_balanceFactor = __ecereNameSpace__ecere__com__eClass_AddProperty(class, "balanceFactor", "int", 0, __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_balanceFactor, 2);
1186 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application)
1187 __ecereProp___ecereNameSpace__ecere__sys__BTNode_balanceFactor = __ecerePropM___ecereNameSpace__ecere__sys__BTNode_balanceFactor, __ecerePropM___ecereNameSpace__ecere__sys__BTNode_balanceFactor = (void *)0;
1189 class->fixed = (unsigned int)1;
1190 class = __ecereNameSpace__ecere__com__eSystem_RegisterClass(5, "ecere::sys::StringBTNode", 0, sizeof(struct __ecereNameSpace__ecere__sys__StringBTNode), 0, 0, 0, module, 4, 1);
1191 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application && class)
1192 __ecereClass___ecereNameSpace__ecere__sys__StringBTNode = class;
1193 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "OnSerialize", 0, __ecereMethod___ecereNameSpace__ecere__sys__StringBTNode_OnSerialize, 1);
1194 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "OnUnserialize", 0, __ecereMethod___ecereNameSpace__ecere__sys__StringBTNode_OnUnserialize, 1);
1195 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "key", "String", arch_PointerSize, arch_PointerSize, 1);
1196 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "parent", "ecere::sys::StringBTNode", arch_PointerSize, arch_PointerSize, 1);
1197 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "left", "ecere::sys::StringBTNode", arch_PointerSize, arch_PointerSize, 1);
1198 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "right", "ecere::sys::StringBTNode", arch_PointerSize, arch_PointerSize, 1);
1199 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "depth", "int", 4, 4, 1);
1201 class->fixed = (unsigned int)1;
1204 void __ecereUnregisterModule_BTNode(struct __ecereNameSpace__ecere__com__Instance * module)
1207 __ecerePropM___ecereNameSpace__ecere__sys__BTNode_prev = (void *)0;
1208 __ecerePropM___ecereNameSpace__ecere__sys__BTNode_next = (void *)0;
1209 __ecerePropM___ecereNameSpace__ecere__sys__BTNode_minimum = (void *)0;
1210 __ecerePropM___ecereNameSpace__ecere__sys__BTNode_maximum = (void *)0;
1211 __ecerePropM___ecereNameSpace__ecere__sys__BTNode_count = (void *)0;
1212 __ecerePropM___ecereNameSpace__ecere__sys__BTNode_depthProp = (void *)0;
1213 __ecerePropM___ecereNameSpace__ecere__sys__BTNode_balanceFactor = (void *)0;