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