a08900e412b3eda5564cf4844c5dccac7499b676
[sdk] / compiler / bootstrap / ecere / bootstrap / BinaryTree.c
1 /* Code generated from eC source file: BinaryTree.ec */
2 #if defined(__GNUC__)
3 typedef long long int64;
4 typedef unsigned long long uint64;
5 #ifndef _WIN32
6 #define __declspec(x)
7 #endif
8 #elif defined(__TINYC__)
9 #include <stdarg.h>
10 #define __builtin_va_list va_list
11 #define __builtin_va_start va_start
12 #define __builtin_va_end va_end
13 #ifdef _WIN32
14 #define strcasecmp stricmp
15 #define strncasecmp strnicmp
16 #define __declspec(x) __attribute__((x))
17 #else
18 #define __declspec(x)
19 #endif
20 typedef long long int64;
21 typedef unsigned long long uint64;
22 #else
23 typedef __int64 int64;
24 typedef unsigned __int64 uint64;
25 #endif
26 #ifdef __BIG_ENDIAN__
27 #define __ENDIAN_PAD(x) (8 - (x))
28 #else
29 #define __ENDIAN_PAD(x) 0
30 #endif
31 #include <stdint.h>
32 #include <sys/types.h>
33
34 #if /*defined(_W64) || */(defined(__WORDSIZE) && __WORDSIZE == 8) || defined(__x86_64__)
35 #define _64BIT 1
36 #else
37 #define _64BIT 0
38 #endif
39
40 #define arch_PointerSize                  sizeof(void *)
41 #define structSize_Instance               (_64BIT ? 24 : 12)
42
43 extern void *  __ecereNameSpace__ecere__com__eSystem_New(unsigned int size);
44
45 extern void *  __ecereNameSpace__ecere__com__eSystem_New0(unsigned int size);
46
47 extern void *  __ecereNameSpace__ecere__com__eSystem_Renew(void *  memory, unsigned int size);
48
49 extern void *  __ecereNameSpace__ecere__com__eSystem_Renew0(void *  memory, unsigned int size);
50
51 extern void __ecereNameSpace__ecere__com__eSystem_Delete(void *  memory);
52
53 struct __ecereNameSpace__ecere__sys__BTNode
54 {
55 uintptr_t key;
56 struct __ecereNameSpace__ecere__sys__BTNode * parent;
57 struct __ecereNameSpace__ecere__sys__BTNode * left;
58 struct __ecereNameSpace__ecere__sys__BTNode * right;
59 int depth;
60 } __attribute__ ((gcc_struct));
61
62 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__BTNode;
63
64 struct __ecereNameSpace__ecere__sys__BinaryTree
65 {
66 struct __ecereNameSpace__ecere__sys__BTNode * root;
67 int count;
68 int (* CompareKey)(struct __ecereNameSpace__ecere__sys__BinaryTree * tree, uintptr_t a, uintptr_t b);
69 void (* FreeKey)(void * key);
70 } __attribute__ ((gcc_struct));
71
72 static struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__BinaryTree;
73
74 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__OldList;
75
76 struct __ecereNameSpace__ecere__sys__OldList
77 {
78 void *  first;
79 void *  last;
80 int count;
81 unsigned int offset;
82 unsigned int circ;
83 } __attribute__ ((gcc_struct));
84
85 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Class;
86
87 struct __ecereNameSpace__ecere__com__Class
88 {
89 struct __ecereNameSpace__ecere__com__Class * prev;
90 struct __ecereNameSpace__ecere__com__Class * next;
91 const char *  name;
92 int offset;
93 int structSize;
94 int (* *  _vTbl)();
95 int vTblSize;
96 int (*  Constructor)(struct __ecereNameSpace__ecere__com__Instance *);
97 void (*  Destructor)(struct __ecereNameSpace__ecere__com__Instance *);
98 int offsetClass;
99 int sizeClass;
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;
107 int memberID;
108 int startMemberID;
109 int type;
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;
114 int typeSize;
115 int defaultAlignment;
116 void (*  Initialize)();
117 int memberOffset;
118 struct __ecereNameSpace__ecere__sys__OldList selfWatchers;
119 const char *  designerClass;
120 unsigned int noExpansion;
121 const char *  defaultProperty;
122 unsigned int comRedefinition;
123 int count;
124 int isRemote;
125 unsigned int internalDecl;
126 void *  data;
127 unsigned int computeSize;
128 int structAlignment;
129 int destructionWatchOffset;
130 unsigned int fixed;
131 struct __ecereNameSpace__ecere__sys__OldList delayedCPValues;
132 int inheritanceAccess;
133 const char *  fullName;
134 void *  symbol;
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;
140 int numParams;
141 unsigned int isInstanceClass;
142 unsigned int byValueSystemClass;
143 } __attribute__ ((gcc_struct));
144
145 extern long long __ecereNameSpace__ecere__com__eClass_GetProperty(struct __ecereNameSpace__ecere__com__Class * _class, const char *  name);
146
147 extern void __ecereNameSpace__ecere__com__eClass_SetProperty(struct __ecereNameSpace__ecere__com__Class * _class, const char *  name, long long value);
148
149 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Property;
150
151 struct __ecereNameSpace__ecere__com__Property
152 {
153 struct __ecereNameSpace__ecere__com__Property * prev;
154 struct __ecereNameSpace__ecere__com__Property * next;
155 const char *  name;
156 unsigned int isProperty;
157 int memberAccess;
158 int id;
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 * );
166 void *  data;
167 void *  symbol;
168 int vid;
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));
176
177 extern void __ecereNameSpace__ecere__com__eInstance_FireSelfWatchers(struct __ecereNameSpace__ecere__com__Instance * instance, struct __ecereNameSpace__ecere__com__Property * _property);
178
179 extern void __ecereNameSpace__ecere__com__eInstance_SetMethod(struct __ecereNameSpace__ecere__com__Instance * instance, const char *  name, void *  function);
180
181 extern void __ecereNameSpace__ecere__com__eInstance_IncRef(struct __ecereNameSpace__ecere__com__Instance * instance);
182
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);
184
185 extern void __ecereNameSpace__ecere__com__eInstance_Watch(void *  instance, struct __ecereNameSpace__ecere__com__Property * _property, void *  object, void (*  callback)(void * , void * ));
186
187 extern void __ecereNameSpace__ecere__com__eInstance_FireWatchers(struct __ecereNameSpace__ecere__com__Instance * instance, struct __ecereNameSpace__ecere__com__Property * _property);
188
189 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Instance;
190
191 struct __ecereNameSpace__ecere__com__Instance
192 {
193 int (* *  _vTbl)();
194 struct __ecereNameSpace__ecere__com__Class * _class;
195 int _refCount;
196 } __attribute__ ((gcc_struct));
197
198 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__DataMember;
199
200 struct __ecereNameSpace__ecere__com__DataMember
201 {
202 struct __ecereNameSpace__ecere__com__DataMember * prev;
203 struct __ecereNameSpace__ecere__com__DataMember * next;
204 const char *  name;
205 unsigned int isProperty;
206 int memberAccess;
207 int id;
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;
212 int type;
213 int offset;
214 int memberID;
215 struct __ecereNameSpace__ecere__sys__OldList members;
216 struct __ecereNameSpace__ecere__sys__BinaryTree membersAlpha;
217 int memberOffset;
218 int structAlignment;
219 } __attribute__ ((gcc_struct));
220
221 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Method;
222
223 struct __ecereNameSpace__ecere__com__Method
224 {
225 const char *  name;
226 struct __ecereNameSpace__ecere__com__Method * parent;
227 struct __ecereNameSpace__ecere__com__Method * left;
228 struct __ecereNameSpace__ecere__com__Method * right;
229 int depth;
230 int (*  function)();
231 int vid;
232 int type;
233 struct __ecereNameSpace__ecere__com__Class * _class;
234 void *  symbol;
235 const char *  dataTypeString;
236 struct __ecereNameSpace__ecere__com__Instance * dataType;
237 int memberAccess;
238 } __attribute__ ((gcc_struct));
239
240 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__SerialBuffer;
241
242 struct __ecereNameSpace__ecere__com__SerialBuffer
243 {
244 unsigned char *  _buffer;
245 unsigned int count;
246 unsigned int _size;
247 unsigned int pos;
248 } __attribute__ ((gcc_struct));
249
250 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__DataValue;
251
252 struct __ecereNameSpace__ecere__com__DataValue
253 {
254 union
255 {
256 char c;
257 unsigned char uc;
258 short s;
259 unsigned short us;
260 int i;
261 unsigned int ui;
262 void *  p;
263 float f;
264 double d;
265 long long i64;
266 uint64 ui64;
267 } __attribute__ ((gcc_struct)) __anon1;
268 } __attribute__ ((gcc_struct));
269
270 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__ClassTemplateArgument;
271
272 struct __ecereNameSpace__ecere__com__ClassTemplateArgument
273 {
274 union
275 {
276 struct
277 {
278 const char *  dataTypeString;
279 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
280 } __attribute__ ((gcc_struct)) __anon1;
281 struct __ecereNameSpace__ecere__com__DataValue expression;
282 struct
283 {
284 const char *  memberString;
285 union
286 {
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));
294
295 __attribute__((unused)) static struct __ecereNameSpace__ecere__sys__BinaryTree __ecereNameSpace__ecere__sys__dummy;
296
297 static struct __ecereNameSpace__ecere__com__Property * __ecereProp___ecereNameSpace__ecere__sys__BinaryTree_first, * __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_first;
298
299 static struct __ecereNameSpace__ecere__com__Property * __ecereProp___ecereNameSpace__ecere__sys__BinaryTree_last, * __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_last;
300
301 void __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(struct __ecereNameSpace__ecere__com__Instance * this, struct __ecereNameSpace__ecere__com__Class * class, const void * data);
302
303 void __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_OnSerialize(struct __ecereNameSpace__ecere__com__Class * class, struct __ecereNameSpace__ecere__sys__BinaryTree * this, struct __ecereNameSpace__ecere__com__Instance * channel)
304 {
305 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(channel, __ecereClass___ecereNameSpace__ecere__sys__BTNode, this->root);
306 }
307
308 void __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Unserialize(struct __ecereNameSpace__ecere__com__Instance * this, struct __ecereNameSpace__ecere__com__Class * class, void * *  data);
309
310 int __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_count(struct __ecereNameSpace__ecere__sys__BTNode * this);
311
312 extern struct __ecereNameSpace__ecere__com__Property ** __ecereProp___ecereNameSpace__ecere__sys__BTNode_count;
313
314 void __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_OnUnserialize(struct __ecereNameSpace__ecere__com__Class * class, struct __ecereNameSpace__ecere__sys__BinaryTree * this, struct __ecereNameSpace__ecere__com__Instance * channel)
315 {
316 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Unserialize(channel, __ecereClass___ecereNameSpace__ecere__sys__BTNode, &(*this).root);
317 (*this).count = (*this).root ? __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_count((*this).root) : 0;
318 }
319
320 int __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_CompareInt(struct __ecereNameSpace__ecere__sys__BinaryTree * this, uintptr_t a, uintptr_t b)
321 {
322 return (a > b) ? 1 : ((a < b) ? -1 : 0);
323 }
324
325 extern int strcmp(const char * , const char * );
326
327 int __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_CompareString(struct __ecereNameSpace__ecere__sys__BinaryTree * this, const char * a, const char * b)
328 {
329 return (a && b) ? strcmp(a, b) : -1;
330 }
331
332 void __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FreeString(char * string)
333 {
334 (__ecereNameSpace__ecere__com__eSystem_Delete(string), string = 0);
335 }
336
337 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Free(struct __ecereNameSpace__ecere__sys__BTNode * this, void (*  FreeKey)(void *  key));
338
339 void __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Free(struct __ecereNameSpace__ecere__sys__BinaryTree * this)
340 {
341 if(this->root)
342 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Free(this->root, this->FreeKey);
343 this->root = (((void *)0));
344 this->count = 0;
345 }
346
347 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);
348
349 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Rebalance();
350
351 unsigned int __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Add(struct __ecereNameSpace__ecere__sys__BinaryTree * this, struct __ecereNameSpace__ecere__sys__BTNode * node)
352 {
353 if(!this->CompareKey)
354 this->CompareKey = __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_CompareInt;
355 if(!this->root)
356 this->root = node;
357 else if(__ecereMethod___ecereNameSpace__ecere__sys__BTNode_Add(this->root, this, node))
358 this->root = __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Rebalance(node);
359 else
360 return 0x0;
361 this->count++;
362 return 0x1;
363 }
364
365 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);
366
367 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Find(struct __ecereNameSpace__ecere__sys__BinaryTree * this, uintptr_t key)
368 {
369 if(!this->CompareKey)
370 this->CompareKey = __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_CompareInt;
371 return this->root ? __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Find(this->root, this, key) : (((void *)0));
372 }
373
374 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindString(struct __ecereNameSpace__ecere__sys__BTNode * this, const char *  key);
375
376 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FindString(struct __ecereNameSpace__ecere__sys__BinaryTree * this, const char * key)
377 {
378 return this->root ? __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindString(this->root, key) : (((void *)0));
379 }
380
381 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindPrefix(struct __ecereNameSpace__ecere__sys__BTNode * this, const char *  key);
382
383 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FindPrefix(struct __ecereNameSpace__ecere__sys__BinaryTree * this, const char * key)
384 {
385 return this->root ? __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindPrefix(this->root, key) : (((void *)0));
386 }
387
388 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindAll(struct __ecereNameSpace__ecere__sys__BTNode * this, uintptr_t key);
389
390 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FindAll(struct __ecereNameSpace__ecere__sys__BinaryTree * this, uintptr_t key)
391 {
392 return this->root ? __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindAll(this->root, key) : (((void *)0));
393 }
394
395 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_RemoveSwapRight();
396
397 void __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Remove(struct __ecereNameSpace__ecere__sys__BinaryTree * this, struct __ecereNameSpace__ecere__sys__BTNode * node)
398 {
399 struct __ecereNameSpace__ecere__sys__BTNode * parent = node->parent;
400
401 if(parent || this->root == node)
402 {
403 this->root = __ecereMethod___ecereNameSpace__ecere__sys__BTNode_RemoveSwapRight(node);
404 this->count--;
405 node->parent = (((void *)0));
406 }
407 }
408
409 void __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Delete(struct __ecereNameSpace__ecere__sys__BinaryTree * this, struct __ecereNameSpace__ecere__sys__BTNode * node)
410 {
411 void * voidNode = node;
412
413 __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Remove(this, node);
414 (__ecereNameSpace__ecere__com__eSystem_Delete(voidNode), voidNode = 0);
415 }
416
417 char *  __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Print(struct __ecereNameSpace__ecere__sys__BTNode * this, char *  output, int tps);
418
419 char * __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Print(struct __ecereNameSpace__ecere__sys__BinaryTree * this, char * output, int tps)
420 {
421 output[0] = (char)0;
422 if(this->root)
423 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Print(this->root, output, tps);
424 return output;
425 }
426
427 unsigned int __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Check(struct __ecereNameSpace__ecere__sys__BTNode * this, struct __ecereNameSpace__ecere__sys__BinaryTree * tree);
428
429 unsigned int __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Check(struct __ecereNameSpace__ecere__sys__BinaryTree * this)
430 {
431 return this->root ? __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Check(this->root, this) : 0x1;
432 }
433
434 struct __ecereNameSpace__ecere__sys__BTNode * __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_minimum(struct __ecereNameSpace__ecere__sys__BTNode * this);
435
436 extern struct __ecereNameSpace__ecere__com__Property ** __ecereProp___ecereNameSpace__ecere__sys__BTNode_minimum;
437
438 struct __ecereNameSpace__ecere__sys__BTNode * __ecereProp___ecereNameSpace__ecere__sys__BinaryTree_Get_first(struct __ecereNameSpace__ecere__sys__BinaryTree * this)
439 {
440 return this->root ? __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_minimum(this->root) : (((void *)0));
441 }
442
443 struct __ecereNameSpace__ecere__sys__BTNode * __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_maximum(struct __ecereNameSpace__ecere__sys__BTNode * this);
444
445 extern struct __ecereNameSpace__ecere__com__Property ** __ecereProp___ecereNameSpace__ecere__sys__BTNode_maximum;
446
447 struct __ecereNameSpace__ecere__sys__BTNode * __ecereProp___ecereNameSpace__ecere__sys__BinaryTree_Get_last(struct __ecereNameSpace__ecere__sys__BinaryTree * this)
448 {
449 return this->root ? __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_maximum(this->root) : (((void *)0));
450 }
451
452 struct __ecereNameSpace__ecere__sys__StringBinaryTree
453 {
454 struct __ecereNameSpace__ecere__sys__BTNode * root;
455 int count;
456 int (*  CompareKey)(struct __ecereNameSpace__ecere__sys__BinaryTree * tree, uintptr_t a, uintptr_t b);
457 void (*  FreeKey)(void *  key);
458 } __attribute__ ((gcc_struct));
459
460 static struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__StringBinaryTree;
461
462 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__StringBTNode;
463
464 void __ecereMethod___ecereNameSpace__ecere__sys__StringBinaryTree_OnSerialize(struct __ecereNameSpace__ecere__com__Class * class, struct __ecereNameSpace__ecere__sys__StringBinaryTree * this, struct __ecereNameSpace__ecere__com__Instance * channel)
465 {
466 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(channel, __ecereClass___ecereNameSpace__ecere__sys__StringBTNode, (struct __ecereNameSpace__ecere__sys__StringBTNode *)this->root);
467 }
468
469 void __ecereMethod___ecereNameSpace__ecere__sys__StringBinaryTree_OnUnserialize(struct __ecereNameSpace__ecere__com__Class * class, struct __ecereNameSpace__ecere__sys__StringBinaryTree * this, struct __ecereNameSpace__ecere__com__Instance * channel)
470 {
471 struct __ecereNameSpace__ecere__sys__StringBTNode * root = (((void *)0));
472
473 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Unserialize(channel, __ecereClass___ecereNameSpace__ecere__sys__StringBTNode, &root);
474 (*this).root = (struct __ecereNameSpace__ecere__sys__BTNode *)root;
475 (*this).count = root ? __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_count((*this).root) : 0;
476 }
477
478 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);
479
480 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__NameSpace;
481
482 struct __ecereNameSpace__ecere__com__NameSpace
483 {
484 const char *  name;
485 struct __ecereNameSpace__ecere__com__NameSpace *  btParent;
486 struct __ecereNameSpace__ecere__com__NameSpace *  left;
487 struct __ecereNameSpace__ecere__com__NameSpace *  right;
488 int depth;
489 struct __ecereNameSpace__ecere__com__NameSpace *  parent;
490 struct __ecereNameSpace__ecere__sys__BinaryTree nameSpaces;
491 struct __ecereNameSpace__ecere__sys__BinaryTree classes;
492 struct __ecereNameSpace__ecere__sys__BinaryTree defines;
493 struct __ecereNameSpace__ecere__sys__BinaryTree functions;
494 } __attribute__ ((gcc_struct));
495
496 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Module;
497
498 struct __ecereNameSpace__ecere__com__Module
499 {
500 struct __ecereNameSpace__ecere__com__Instance * application;
501 struct __ecereNameSpace__ecere__sys__OldList classes;
502 struct __ecereNameSpace__ecere__sys__OldList defines;
503 struct __ecereNameSpace__ecere__sys__OldList functions;
504 struct __ecereNameSpace__ecere__sys__OldList modules;
505 struct __ecereNameSpace__ecere__com__Instance * prev;
506 struct __ecereNameSpace__ecere__com__Instance * next;
507 const char *  name;
508 void *  library;
509 void *  Unload;
510 int importType;
511 int origImportType;
512 struct __ecereNameSpace__ecere__com__NameSpace privateNameSpace;
513 struct __ecereNameSpace__ecere__com__NameSpace publicNameSpace;
514 } __attribute__ ((gcc_struct));
515
516 extern struct __ecereNameSpace__ecere__com__Instance * __thisModule;
517
518 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);
519
520 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);
521
522 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);
523
524 void __ecereRegisterModule_BinaryTree(struct __ecereNameSpace__ecere__com__Instance * module)
525 {
526 struct __ecereNameSpace__ecere__com__Class * class;
527
528 class = __ecereNameSpace__ecere__com__eSystem_RegisterClass(1, "ecere::sys::BinaryTree", 0, sizeof(struct __ecereNameSpace__ecere__sys__BinaryTree), 0, 0, 0, module, 4, 1);
529 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application && class)
530 __ecereClass___ecereNameSpace__ecere__sys__BinaryTree = class;
531 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "OnSerialize", 0, __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_OnSerialize, 1);
532 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "OnUnserialize", 0, __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_OnUnserialize, 1);
533 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Add", "bool Add(ecere::sys::BTNode node)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Add, 1);
534 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Check", "bool Check()", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Check, 1);
535 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "CompareInt", "int CompareInt(uintptr a, uintptr b)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_CompareInt, 1);
536 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "CompareString", "int CompareString(const char * a, const char * b)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_CompareString, 1);
537 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Delete", "void Delete(ecere::sys::BTNode node)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Delete, 1);
538 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Find", "ecere::sys::BTNode Find(uintptr key)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Find, 1);
539 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "FindAll", "ecere::sys::BTNode FindAll(uintptr key)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FindAll, 1);
540 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "FindPrefix", "ecere::sys::BTNode FindPrefix(const char * key)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FindPrefix, 1);
541 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "FindString", "ecere::sys::BTNode FindString(const char * key)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FindString, 1);
542 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Free", "void Free()", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Free, 1);
543 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "FreeString", "void ::FreeString(char * string)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FreeString, 1);
544 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Print", "char * Print(char * output, ecere::sys::TreePrintStyle tps)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Print, 1);
545 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Remove", "void Remove(ecere::sys::BTNode node)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Remove, 1);
546 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "root", "ecere::sys::BTNode", arch_PointerSize, arch_PointerSize, 1);
547 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "count", "int", 4, 4, 1);
548 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "CompareKey", "int (*)(ecere::sys::BinaryTree tree, uintptr a, uintptr b)", arch_PointerSize, arch_PointerSize, 1);
549 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "FreeKey", "void (*)(void * key)", arch_PointerSize, arch_PointerSize, 1);
550 __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_first = __ecereNameSpace__ecere__com__eClass_AddProperty(class, "first", "ecere::sys::BTNode", 0, __ecereProp___ecereNameSpace__ecere__sys__BinaryTree_Get_first, 1);
551 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application)
552 __ecereProp___ecereNameSpace__ecere__sys__BinaryTree_first = __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_first, __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_first = (void *)0;
553 __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_last = __ecereNameSpace__ecere__com__eClass_AddProperty(class, "last", "ecere::sys::BTNode", 0, __ecereProp___ecereNameSpace__ecere__sys__BinaryTree_Get_last, 1);
554 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application)
555 __ecereProp___ecereNameSpace__ecere__sys__BinaryTree_last = __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_last, __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_last = (void *)0;
556 class = __ecereNameSpace__ecere__com__eSystem_RegisterClass(1, "ecere::sys::StringBinaryTree", "ecere::sys::BinaryTree", sizeof(struct __ecereNameSpace__ecere__sys__StringBinaryTree) - sizeof(struct __ecereNameSpace__ecere__sys__BinaryTree), 0, 0, 0, module, 4, 1);
557 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application && class)
558 __ecereClass___ecereNameSpace__ecere__sys__StringBinaryTree = class;
559 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "OnSerialize", 0, __ecereMethod___ecereNameSpace__ecere__sys__StringBinaryTree_OnSerialize, 1);
560 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "OnUnserialize", 0, __ecereMethod___ecereNameSpace__ecere__sys__StringBinaryTree_OnUnserialize, 1);
561 }
562
563 void __ecereUnregisterModule_BinaryTree(struct __ecereNameSpace__ecere__com__Instance * module)
564 {
565
566 __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_first = (void *)0;
567 __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_last = (void *)0;
568 }
569