wip II
[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 struct __ecereNameSpace__ecere__sys__BTNode
52 {
53 uintptr_t key;
54 struct __ecereNameSpace__ecere__sys__BTNode * parent;
55 struct __ecereNameSpace__ecere__sys__BTNode * left;
56 struct __ecereNameSpace__ecere__sys__BTNode * right;
57 int depth;
58 } __attribute__ ((gcc_struct));
59
60 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__BTNode;
61
62 struct __ecereNameSpace__ecere__sys__BinaryTree
63 {
64 struct __ecereNameSpace__ecere__sys__BTNode * root;
65 int count;
66 int (* CompareKey)(struct __ecereNameSpace__ecere__sys__BinaryTree * tree, uintptr_t a, uintptr_t b);
67 void (* FreeKey)(void * key);
68 } __attribute__ ((gcc_struct));
69
70 static struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__BinaryTree;
71
72 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__OldList;
73
74 struct __ecereNameSpace__ecere__sys__OldList
75 {
76 void *  first;
77 void *  last;
78 int count;
79 unsigned int offset;
80 unsigned int circ;
81 } __attribute__ ((gcc_struct));
82
83 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Class;
84
85 struct __ecereNameSpace__ecere__com__Class
86 {
87 struct __ecereNameSpace__ecere__com__Class * prev;
88 struct __ecereNameSpace__ecere__com__Class * next;
89 char *  name;
90 int offset;
91 int structSize;
92 int (* *  _vTbl)();
93 int vTblSize;
94 int (*  Constructor)(struct __ecereNameSpace__ecere__com__Instance *);
95 void (*  Destructor)(struct __ecereNameSpace__ecere__com__Instance *);
96 int offsetClass;
97 int sizeClass;
98 struct __ecereNameSpace__ecere__com__Class * base;
99 struct __ecereNameSpace__ecere__sys__BinaryTree methods;
100 struct __ecereNameSpace__ecere__sys__BinaryTree members;
101 struct __ecereNameSpace__ecere__sys__BinaryTree prop;
102 struct __ecereNameSpace__ecere__sys__OldList membersAndProperties;
103 struct __ecereNameSpace__ecere__sys__BinaryTree classProperties;
104 struct __ecereNameSpace__ecere__sys__OldList derivatives;
105 int memberID;
106 int startMemberID;
107 int type;
108 struct __ecereNameSpace__ecere__com__Instance * module;
109 struct __ecereNameSpace__ecere__com__NameSpace *  nameSpace;
110 char *  dataTypeString;
111 struct __ecereNameSpace__ecere__com__Instance * dataType;
112 int typeSize;
113 int defaultAlignment;
114 void (*  Initialize)();
115 int memberOffset;
116 struct __ecereNameSpace__ecere__sys__OldList selfWatchers;
117 char *  designerClass;
118 unsigned int noExpansion;
119 char *  defaultProperty;
120 unsigned int comRedefinition;
121 int count;
122 unsigned int isRemote;
123 unsigned int internalDecl;
124 void *  data;
125 unsigned int computeSize;
126 int structAlignment;
127 int destructionWatchOffset;
128 unsigned int fixed;
129 struct __ecereNameSpace__ecere__sys__OldList delayedCPValues;
130 int inheritanceAccess;
131 char *  fullName;
132 void *  symbol;
133 struct __ecereNameSpace__ecere__sys__OldList conversions;
134 struct __ecereNameSpace__ecere__sys__OldList templateParams;
135 struct __ecereNameSpace__ecere__com__ClassTemplateArgument *  templateArgs;
136 struct __ecereNameSpace__ecere__com__Class * templateClass;
137 struct __ecereNameSpace__ecere__sys__OldList templatized;
138 int numParams;
139 unsigned int isInstanceClass;
140 unsigned int byValueSystemClass;
141 } __attribute__ ((gcc_struct));
142
143 extern long long __ecereNameSpace__ecere__com__eClass_GetProperty(struct __ecereNameSpace__ecere__com__Class * _class, char *  name);
144
145 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Instance;
146
147 struct __ecereNameSpace__ecere__com__Instance
148 {
149 int (* *  _vTbl)();
150 struct __ecereNameSpace__ecere__com__Class * _class;
151 int _refCount;
152 } __attribute__ ((gcc_struct));
153
154 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Property;
155
156 struct __ecereNameSpace__ecere__com__Property
157 {
158 struct __ecereNameSpace__ecere__com__Property * prev;
159 struct __ecereNameSpace__ecere__com__Property * next;
160 char *  name;
161 unsigned int isProperty;
162 int memberAccess;
163 int id;
164 struct __ecereNameSpace__ecere__com__Class * _class;
165 char *  dataTypeString;
166 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
167 struct __ecereNameSpace__ecere__com__Instance * dataType;
168 void (*  Set)(void * , int);
169 int (*  Get)(void * );
170 unsigned int (*  IsSet)(void * );
171 void *  data;
172 void *  symbol;
173 int vid;
174 unsigned int conversion;
175 unsigned int watcherOffset;
176 char *  category;
177 unsigned int compiled;
178 unsigned int selfWatchable;
179 unsigned int isWatchable;
180 } __attribute__ ((gcc_struct));
181
182 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__DataMember;
183
184 struct __ecereNameSpace__ecere__com__DataMember
185 {
186 struct __ecereNameSpace__ecere__com__DataMember * prev;
187 struct __ecereNameSpace__ecere__com__DataMember * next;
188 char *  name;
189 unsigned int isProperty;
190 int memberAccess;
191 int id;
192 struct __ecereNameSpace__ecere__com__Class * _class;
193 char *  dataTypeString;
194 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
195 struct __ecereNameSpace__ecere__com__Instance * dataType;
196 int type;
197 int offset;
198 int memberID;
199 struct __ecereNameSpace__ecere__sys__OldList members;
200 struct __ecereNameSpace__ecere__sys__BinaryTree membersAlpha;
201 int memberOffset;
202 int structAlignment;
203 } __attribute__ ((gcc_struct));
204
205 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Method;
206
207 struct __ecereNameSpace__ecere__com__Method
208 {
209 char *  name;
210 struct __ecereNameSpace__ecere__com__Method * parent;
211 struct __ecereNameSpace__ecere__com__Method * left;
212 struct __ecereNameSpace__ecere__com__Method * right;
213 int depth;
214 int (*  function)();
215 int vid;
216 int type;
217 struct __ecereNameSpace__ecere__com__Class * _class;
218 void *  symbol;
219 char *  dataTypeString;
220 struct __ecereNameSpace__ecere__com__Instance * dataType;
221 int memberAccess;
222 } __attribute__ ((gcc_struct));
223
224 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__SerialBuffer;
225
226 struct __ecereNameSpace__ecere__com__SerialBuffer
227 {
228 unsigned char *  _buffer;
229 unsigned int count;
230 unsigned int _size;
231 unsigned int pos;
232 } __attribute__ ((gcc_struct));
233
234 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__DataValue;
235
236 struct __ecereNameSpace__ecere__com__DataValue
237 {
238 union
239 {
240 char c;
241 unsigned char uc;
242 short s;
243 unsigned short us;
244 int i;
245 unsigned int ui;
246 void *  p;
247 float f;
248 double d;
249 long long i64;
250 uint64 ui64;
251 } __attribute__ ((gcc_struct));
252 } __attribute__ ((gcc_struct));
253
254 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__ClassTemplateArgument;
255
256 struct __ecereNameSpace__ecere__com__ClassTemplateArgument
257 {
258 union
259 {
260 struct
261 {
262 char *  dataTypeString;
263 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
264 } __attribute__ ((gcc_struct));
265 struct __ecereNameSpace__ecere__com__DataValue expression;
266 struct
267 {
268 char *  memberString;
269 union
270 {
271 struct __ecereNameSpace__ecere__com__DataMember * member;
272 struct __ecereNameSpace__ecere__com__Property * prop;
273 struct __ecereNameSpace__ecere__com__Method * method;
274 } __attribute__ ((gcc_struct));
275 } __attribute__ ((gcc_struct));
276 } __attribute__ ((gcc_struct));
277 } __attribute__ ((gcc_struct));
278
279 static struct __ecereNameSpace__ecere__sys__BinaryTree __ecereNameSpace__ecere__sys__dummy;
280
281 static struct __ecereNameSpace__ecere__com__Property * __ecereProp___ecereNameSpace__ecere__sys__BinaryTree_first, * __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_first;
282
283 static struct __ecereNameSpace__ecere__com__Property * __ecereProp___ecereNameSpace__ecere__sys__BinaryTree_last, * __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_last;
284
285 void __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(struct __ecereNameSpace__ecere__com__Instance * this, struct __ecereNameSpace__ecere__com__Class * class, void * data);
286
287 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)
288 {
289 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(channel, __ecereClass___ecereNameSpace__ecere__sys__BTNode, this->root);
290 }
291
292 void __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Unserialize(struct __ecereNameSpace__ecere__com__Instance * this, struct __ecereNameSpace__ecere__com__Class * class, void * *  data);
293
294 int __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_count(struct __ecereNameSpace__ecere__sys__BTNode * this);
295
296 extern struct __ecereNameSpace__ecere__com__Property ** __ecereProp___ecereNameSpace__ecere__sys__BTNode_count;
297
298 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)
299 {
300 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Unserialize(channel, __ecereClass___ecereNameSpace__ecere__sys__BTNode, &(*this).root);
301 (*this).count = (*this).root ? __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_count((*this).root) : 0;
302 }
303
304 int __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_CompareInt(struct __ecereNameSpace__ecere__sys__BinaryTree * this, uintptr_t a, uintptr_t b)
305 {
306 return (a > b) ? 1 : ((a < b) ? -1 : 0);
307 }
308
309 extern int strcmp(const char * , const char * );
310
311 int __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_CompareString(struct __ecereNameSpace__ecere__sys__BinaryTree * this, char * a, char * b)
312 {
313 return (a && b) ? strcmp(a, b) : -1;
314 }
315
316 void __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FreeString(char * string)
317 {
318 (__ecereNameSpace__ecere__com__eSystem_Delete(string), string = 0);
319 }
320
321 void __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Free(struct __ecereNameSpace__ecere__sys__BTNode * this, void (*  FreeKey)(void *  key));
322
323 void __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Free(struct __ecereNameSpace__ecere__sys__BinaryTree * this)
324 {
325 if(this->root)
326 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Free(this->root, this->FreeKey);
327 this->root = (((void *)0));
328 this->count = 0;
329 }
330
331 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);
332
333 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Rebalance();
334
335 unsigned int __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Add(struct __ecereNameSpace__ecere__sys__BinaryTree * this, struct __ecereNameSpace__ecere__sys__BTNode * node)
336 {
337 if(!this->CompareKey)
338 this->CompareKey = __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_CompareInt;
339 if(!this->root)
340 this->root = node;
341 else if(__ecereMethod___ecereNameSpace__ecere__sys__BTNode_Add(this->root, this, node))
342 this->root = __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Rebalance(node);
343 else
344 return 0x0;
345 this->count++;
346 return 0x1;
347 }
348
349 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);
350
351 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Find(struct __ecereNameSpace__ecere__sys__BinaryTree * this, uintptr_t key)
352 {
353 if(!this->CompareKey)
354 this->CompareKey = __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_CompareInt;
355 return this->root ? __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Find(this->root, this, key) : (((void *)0));
356 }
357
358 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindString(struct __ecereNameSpace__ecere__sys__BTNode * this, char *  key);
359
360 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FindString(struct __ecereNameSpace__ecere__sys__BinaryTree * this, char * key)
361 {
362 return this->root ? __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindString(this->root, key) : (((void *)0));
363 }
364
365 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindPrefix(struct __ecereNameSpace__ecere__sys__BTNode * this, char *  key);
366
367 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FindPrefix(struct __ecereNameSpace__ecere__sys__BinaryTree * this, char * key)
368 {
369 return this->root ? __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindPrefix(this->root, key) : (((void *)0));
370 }
371
372 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindAll(struct __ecereNameSpace__ecere__sys__BTNode * this, uintptr_t key);
373
374 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FindAll(struct __ecereNameSpace__ecere__sys__BinaryTree * this, uintptr_t key)
375 {
376 return this->root ? __ecereMethod___ecereNameSpace__ecere__sys__BTNode_FindAll(this->root, key) : (((void *)0));
377 }
378
379 struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BTNode_RemoveSwapRight();
380
381 void __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Remove(struct __ecereNameSpace__ecere__sys__BinaryTree * this, struct __ecereNameSpace__ecere__sys__BTNode * node)
382 {
383 struct __ecereNameSpace__ecere__sys__BTNode * parent = node->parent;
384
385 if(parent || this->root == node)
386 {
387 this->root = __ecereMethod___ecereNameSpace__ecere__sys__BTNode_RemoveSwapRight(node);
388 this->count--;
389 node->parent = (((void *)0));
390 }
391 }
392
393 void __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Delete(struct __ecereNameSpace__ecere__sys__BinaryTree * this, struct __ecereNameSpace__ecere__sys__BTNode * node)
394 {
395 void * voidNode = node;
396
397 __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Remove(this, node);
398 (__ecereNameSpace__ecere__com__eSystem_Delete(voidNode), voidNode = 0);
399 }
400
401 char *  __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Print(struct __ecereNameSpace__ecere__sys__BTNode * this, char *  output, int tps);
402
403 char * __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Print(struct __ecereNameSpace__ecere__sys__BinaryTree * this, char * output, int tps)
404 {
405 output[0] = (char)0;
406 if(this->root)
407 __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Print(this->root, output, tps);
408 return output;
409 }
410
411 unsigned int __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Check(struct __ecereNameSpace__ecere__sys__BTNode * this, struct __ecereNameSpace__ecere__sys__BinaryTree * tree);
412
413 unsigned int __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Check(struct __ecereNameSpace__ecere__sys__BinaryTree * this)
414 {
415 return this->root ? __ecereMethod___ecereNameSpace__ecere__sys__BTNode_Check(this->root, this) : 0x1;
416 }
417
418 struct __ecereNameSpace__ecere__sys__BTNode * __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_minimum(struct __ecereNameSpace__ecere__sys__BTNode * this);
419
420 extern struct __ecereNameSpace__ecere__com__Property ** __ecereProp___ecereNameSpace__ecere__sys__BTNode_minimum;
421
422 struct __ecereNameSpace__ecere__sys__BTNode * __ecereProp___ecereNameSpace__ecere__sys__BinaryTree_Get_first(struct __ecereNameSpace__ecere__sys__BinaryTree * this)
423 {
424 return this->root ? __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_minimum(this->root) : (((void *)0));
425 }
426
427 struct __ecereNameSpace__ecere__sys__BTNode * __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_maximum(struct __ecereNameSpace__ecere__sys__BTNode * this);
428
429 extern struct __ecereNameSpace__ecere__com__Property ** __ecereProp___ecereNameSpace__ecere__sys__BTNode_maximum;
430
431 struct __ecereNameSpace__ecere__sys__BTNode * __ecereProp___ecereNameSpace__ecere__sys__BinaryTree_Get_last(struct __ecereNameSpace__ecere__sys__BinaryTree * this)
432 {
433 return this->root ? __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_maximum(this->root) : (((void *)0));
434 }
435
436 struct __ecereNameSpace__ecere__sys__StringBinaryTree
437 {
438 struct __ecereNameSpace__ecere__sys__BTNode * root;
439 int count;
440 int (*  CompareKey)(struct __ecereNameSpace__ecere__sys__BinaryTree * tree, uintptr_t a, uintptr_t b);
441 void (*  FreeKey)(void *  key);
442 } __attribute__ ((gcc_struct));
443
444 static struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__StringBinaryTree;
445
446 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__sys__StringBTNode;
447
448 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)
449 {
450 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Serialize(channel, __ecereClass___ecereNameSpace__ecere__sys__StringBTNode, (struct __ecereNameSpace__ecere__sys__StringBTNode *)this->root);
451 }
452
453 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)
454 {
455 struct __ecereNameSpace__ecere__sys__StringBTNode * root = (((void *)0));
456
457 __ecereMethod___ecereNameSpace__ecere__com__IOChannel_Unserialize(channel, __ecereClass___ecereNameSpace__ecere__sys__StringBTNode, &root);
458 (*this).root = (struct __ecereNameSpace__ecere__sys__BTNode *)root;
459 (*this).count = root ? __ecereProp___ecereNameSpace__ecere__sys__BTNode_Get_count((*this).root) : 0;
460 }
461
462 extern struct __ecereNameSpace__ecere__com__Class * __ecereNameSpace__ecere__com__eSystem_RegisterClass(int type, char *  name, char *  baseName, int size, int sizeClass, unsigned int (*  Constructor)(void * ), void (*  Destructor)(void * ), struct __ecereNameSpace__ecere__com__Instance * module, int declMode, int inheritanceAccess);
463
464 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__NameSpace;
465
466 struct __ecereNameSpace__ecere__com__NameSpace
467 {
468 char *  name;
469 struct __ecereNameSpace__ecere__com__NameSpace *  btParent;
470 struct __ecereNameSpace__ecere__com__NameSpace *  left;
471 struct __ecereNameSpace__ecere__com__NameSpace *  right;
472 int depth;
473 struct __ecereNameSpace__ecere__com__NameSpace *  parent;
474 struct __ecereNameSpace__ecere__sys__BinaryTree nameSpaces;
475 struct __ecereNameSpace__ecere__sys__BinaryTree classes;
476 struct __ecereNameSpace__ecere__sys__BinaryTree defines;
477 struct __ecereNameSpace__ecere__sys__BinaryTree functions;
478 } __attribute__ ((gcc_struct));
479
480 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Module;
481
482 struct __ecereNameSpace__ecere__com__Module
483 {
484 struct __ecereNameSpace__ecere__com__Instance * application;
485 struct __ecereNameSpace__ecere__sys__OldList classes;
486 struct __ecereNameSpace__ecere__sys__OldList defines;
487 struct __ecereNameSpace__ecere__sys__OldList functions;
488 struct __ecereNameSpace__ecere__sys__OldList modules;
489 struct __ecereNameSpace__ecere__com__Instance * prev;
490 struct __ecereNameSpace__ecere__com__Instance * next;
491 char *  name;
492 void *  library;
493 void *  Unload;
494 int importType;
495 int origImportType;
496 struct __ecereNameSpace__ecere__com__NameSpace privateNameSpace;
497 struct __ecereNameSpace__ecere__com__NameSpace publicNameSpace;
498 } __attribute__ ((gcc_struct));
499
500 extern struct __ecereNameSpace__ecere__com__Instance * __thisModule;
501
502 extern struct __ecereNameSpace__ecere__com__Method * __ecereNameSpace__ecere__com__eClass_AddMethod(struct __ecereNameSpace__ecere__com__Class * _class, char *  name, char *  type, void *  function, int declMode);
503
504 extern struct __ecereNameSpace__ecere__com__DataMember * __ecereNameSpace__ecere__com__eClass_AddDataMember(struct __ecereNameSpace__ecere__com__Class * _class, char *  name, char *  type, unsigned int size, unsigned int alignment, int declMode);
505
506 extern struct __ecereNameSpace__ecere__com__Property * __ecereNameSpace__ecere__com__eClass_AddProperty(struct __ecereNameSpace__ecere__com__Class * _class, char *  name, char *  dataType, void *  setStmt, void *  getStmt, int declMode);
507
508 void __ecereRegisterModule_BinaryTree(struct __ecereNameSpace__ecere__com__Instance * module)
509 {
510 struct __ecereNameSpace__ecere__com__Class * class;
511
512 class = __ecereNameSpace__ecere__com__eSystem_RegisterClass(1, "ecere::sys::BinaryTree", 0, sizeof(struct __ecereNameSpace__ecere__sys__BinaryTree), 0, 0, 0, module, 4, 1);
513 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application && class)
514 __ecereClass___ecereNameSpace__ecere__sys__BinaryTree = class;
515 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "OnSerialize", 0, __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_OnSerialize, 1);
516 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "OnUnserialize", 0, __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_OnUnserialize, 1);
517 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Add", "bool Add(ecere::sys::BTNode node)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Add, 1);
518 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Check", "bool Check()", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Check, 1);
519 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "CompareInt", "int CompareInt(uintptr a, uintptr b)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_CompareInt, 1);
520 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "CompareString", "int CompareString(char * a, char * b)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_CompareString, 1);
521 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Delete", "void Delete(ecere::sys::BTNode node)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Delete, 1);
522 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Find", "ecere::sys::BTNode Find(uintptr key)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Find, 1);
523 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "FindAll", "ecere::sys::BTNode FindAll(uintptr key)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FindAll, 1);
524 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "FindPrefix", "ecere::sys::BTNode FindPrefix(char * key)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FindPrefix, 1);
525 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "FindString", "ecere::sys::BTNode FindString(char * key)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FindString, 1);
526 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Free", "void Free()", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Free, 1);
527 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "FreeString", "void ::FreeString(char * string)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FreeString, 1);
528 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Print", "char * Print(char * output, ecere::sys::TreePrintStyle tps)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Print, 1);
529 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "Remove", "void Remove(ecere::sys::BTNode node)", __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Remove, 1);
530 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "root", "ecere::sys::BTNode", arch_PointerSize, arch_PointerSize, 1);
531 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "count", "int", 4, 4, 1);
532 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "CompareKey", "int (*)(ecere::sys::BinaryTree tree, uintptr a, uintptr b)", arch_PointerSize, arch_PointerSize, 1);
533 __ecereNameSpace__ecere__com__eClass_AddDataMember(class, "FreeKey", "void (*)(void * key)", arch_PointerSize, arch_PointerSize, 1);
534 __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);
535 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application)
536 __ecereProp___ecereNameSpace__ecere__sys__BinaryTree_first = __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_first, __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_first = (void *)0;
537 __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);
538 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application)
539 __ecereProp___ecereNameSpace__ecere__sys__BinaryTree_last = __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_last, __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_last = (void *)0;
540 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);
541 if(((struct __ecereNameSpace__ecere__com__Module *)(((char *)module + structSize_Instance)))->application == ((struct __ecereNameSpace__ecere__com__Module *)(((char *)__thisModule + structSize_Instance)))->application && class)
542 __ecereClass___ecereNameSpace__ecere__sys__StringBinaryTree = class;
543 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "OnSerialize", 0, __ecereMethod___ecereNameSpace__ecere__sys__StringBinaryTree_OnSerialize, 1);
544 __ecereNameSpace__ecere__com__eClass_AddMethod(class, "OnUnserialize", 0, __ecereMethod___ecereNameSpace__ecere__sys__StringBinaryTree_OnUnserialize, 1);
545 }
546
547 void __ecereUnregisterModule_BinaryTree(struct __ecereNameSpace__ecere__com__Instance * module)
548 {
549
550 __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_first = (void *)0;
551 __ecerePropM___ecereNameSpace__ecere__sys__BinaryTree_last = (void *)0;
552 }
553