compiler/libec: (#307, #70) Warning on undeclared class; Overriding namespaces
[sdk] / compiler / bootstrap / libec / bootstrap / pass16.c
1 /* Code generated from eC source file: pass16.ec */
2 #if defined(_WIN32)
3 #define __runtimePlatform 1
4 #elif defined(__APPLE__)
5 #define __runtimePlatform 3
6 #else
7 #define __runtimePlatform 2
8 #endif
9 #if defined(__GNUC__)
10 typedef long long int64;
11 typedef unsigned long long uint64;
12 #ifndef _WIN32
13 #define __declspec(x)
14 #endif
15 #elif defined(__TINYC__)
16 #include <stdarg.h>
17 #define __builtin_va_list va_list
18 #define __builtin_va_start va_start
19 #define __builtin_va_end va_end
20 #ifdef _WIN32
21 #define strcasecmp stricmp
22 #define strncasecmp strnicmp
23 #define __declspec(x) __attribute__((x))
24 #else
25 #define __declspec(x)
26 #endif
27 typedef long long int64;
28 typedef unsigned long long uint64;
29 #else
30 typedef __int64 int64;
31 typedef unsigned __int64 uint64;
32 #endif
33 #ifdef __BIG_ENDIAN__
34 #define __ENDIAN_PAD(x) (8 - (x))
35 #else
36 #define __ENDIAN_PAD(x) 0
37 #endif
38 #include <stdint.h>
39 #include <sys/types.h>
40 enum yytokentype
41 {
42 IDENTIFIER = 258, CONSTANT = 259, STRING_LITERAL = 260, SIZEOF = 261, PTR_OP = 262, INC_OP = 263, DEC_OP = 264, LEFT_OP = 265, RIGHT_OP = 266, LE_OP = 267, GE_OP = 268, EQ_OP = 269, NE_OP = 270, AND_OP = 271, OR_OP = 272, MUL_ASSIGN = 273, DIV_ASSIGN = 274, MOD_ASSIGN = 275, ADD_ASSIGN = 276, SUB_ASSIGN = 277, LEFT_ASSIGN = 278, RIGHT_ASSIGN = 279, AND_ASSIGN = 280, XOR_ASSIGN = 281, OR_ASSIGN = 282, TYPE_NAME = 283, TYPEDEF = 284, EXTERN = 285, STATIC = 286, AUTO = 287, REGISTER = 288, CHAR = 289, SHORT = 290, INT = 291, UINT = 292, INT64 = 293, LONG = 294, SIGNED = 295, UNSIGNED = 296, FLOAT = 297, DOUBLE = 298, CONST = 299, VOLATILE = 300, VOID = 301, VALIST = 302, STRUCT = 303, UNION = 304, ENUM = 305, ELLIPSIS = 306, CASE = 307, DEFAULT = 308, IF = 309, SWITCH = 310, WHILE = 311, DO = 312, FOR = 313, GOTO = 314, CONTINUE = 315, BREAK = 316, RETURN = 317, IFX = 318, ELSE = 319, CLASS = 320, THISCLASS = 321, CLASS_NAME = 322, PROPERTY = 323, SETPROP = 324, GETPROP = 325, NEWOP = 326, RENEW = 327, DELETE = 328, EXT_DECL = 329, EXT_STORAGE = 330, IMPORT = 331, DEFINE = 332, VIRTUAL = 333, ATTRIB = 334, PUBLIC = 335, PRIVATE = 336, TYPED_OBJECT = 337, ANY_OBJECT = 338, _INCREF = 339, EXTENSION = 340, ASM = 341, TYPEOF = 342, WATCH = 343, STOPWATCHING = 344, FIREWATCHERS = 345, WATCHABLE = 346, CLASS_DESIGNER = 347, CLASS_NO_EXPANSION = 348, CLASS_FIXED = 349, ISPROPSET = 350, CLASS_DEFAULT_PROPERTY = 351, PROPERTY_CATEGORY = 352, CLASS_DATA = 353, CLASS_PROPERTY = 354, SUBCLASS = 355, NAMESPACE = 356, NEW0OP = 357, RENEW0 = 358, VAARG = 359, DBTABLE = 360, DBFIELD = 361, DBINDEX = 362, DATABASE_OPEN = 363, ALIGNOF = 364, ATTRIB_DEP = 365, __ATTRIB = 366, BOOL = 367, _BOOL = 368, _COMPLEX = 369, _IMAGINARY = 370, RESTRICT = 371, THREAD = 372, WIDE_STRING_LITERAL = 373
43 };
44
45 extern unsigned int inCompiler;
46
47 extern const char *  outputFile;
48
49 static int declTempCount;
50
51 struct __ecereNameSpace__ecere__sys__OldList
52 {
53 void *  first;
54 void *  last;
55 int count;
56 unsigned int offset;
57 unsigned int circ;
58 } __attribute__ ((gcc_struct));
59
60 struct __ecereNameSpace__ecere__sys__BTNode;
61
62 struct __ecereNameSpace__ecere__com__DataValue
63 {
64 union
65 {
66 char c;
67 unsigned char uc;
68 short s;
69 unsigned short us;
70 int i;
71 unsigned int ui;
72 void *  p;
73 float f;
74 double d;
75 long long i64;
76 uint64 ui64;
77 } __attribute__ ((gcc_struct)) __anon1;
78 } __attribute__ ((gcc_struct));
79
80 struct __ecereNameSpace__ecere__com__SerialBuffer
81 {
82 unsigned char *  _buffer;
83 unsigned int count;
84 unsigned int _size;
85 unsigned int pos;
86 } __attribute__ ((gcc_struct));
87
88 extern void *  __ecereNameSpace__ecere__com__eSystem_New(unsigned int size);
89
90 extern void *  __ecereNameSpace__ecere__com__eSystem_New0(unsigned int size);
91
92 extern void *  __ecereNameSpace__ecere__com__eSystem_Renew(void *  memory, unsigned int size);
93
94 extern void *  __ecereNameSpace__ecere__com__eSystem_Renew0(void *  memory, unsigned int size);
95
96 extern void __ecereNameSpace__ecere__com__eSystem_Delete(void *  memory);
97
98 struct Pointer;
99
100 struct TypeName;
101
102 struct Attrib;
103
104 struct ExtDecl;
105
106 struct Attribute;
107
108 struct TemplateParameter;
109
110 struct TemplateArgument;
111
112 struct TemplateDatatype;
113
114 struct DBTableEntry;
115
116 struct DBIndexItem;
117
118 struct DBTableDef;
119
120 struct CodePosition
121 {
122 int line;
123 int charPos;
124 int pos;
125 int included;
126 } __attribute__ ((gcc_struct));
127
128 extern char *  __ecereNameSpace__ecere__sys__GetLastDirectory(const char *  string, char *  output);
129
130 extern unsigned int __ecereNameSpace__ecere__sys__StripExtension(char *  string);
131
132 extern void FixModuleName(char *  moduleName);
133
134 extern int sprintf(char * , const char * , ...);
135
136 extern void *  memcpy(void * , const void * , size_t size);
137
138 extern char *  __ecereNameSpace__ecere__sys__CopyString(const char *  string);
139
140 extern char *  strcpy(char * , const char * );
141
142 extern void FullClassNameCat(char *  output, const char *  className, unsigned int includeTemplateParams);
143
144 struct __ecereNameSpace__ecere__com__LinkList
145 {
146 void * first;
147 void * last;
148 int count;
149 } __attribute__ ((gcc_struct));
150
151 extern int strcmp(const char * , const char * );
152
153 extern void Compiler_Error(const char *  format, ...);
154
155 extern const char *  __ecereNameSpace__ecere__GetTranslatedString(const char * name, const char *  string, const char *  stringAndContext);
156
157 struct __ecereNameSpace__ecere__com__LinkElement
158 {
159 void * prev;
160 void * next;
161 } __attribute__ ((gcc_struct));
162
163 struct __ecereNameSpace__ecere__com__GlobalFunction;
164
165 struct __ecereNameSpace__ecere__com__IteratorPointer;
166
167 extern struct __ecereNameSpace__ecere__sys__OldList *  MkList(void);
168
169 extern void ListAdd(struct __ecereNameSpace__ecere__sys__OldList * list, void *  item);
170
171 extern struct __ecereNameSpace__ecere__sys__OldList *  ast;
172
173 extern struct __ecereNameSpace__ecere__sys__OldList *  MkListOne(void *  item);
174
175 extern void FreeList(struct __ecereNameSpace__ecere__sys__OldList * list, void (*  FreeFunction)(void * ));
176
177 extern void ListAddFront(struct __ecereNameSpace__ecere__sys__OldList * list, void *  item);
178
179 void __ecereMethod___ecereNameSpace__ecere__sys__OldList_Clear(struct __ecereNameSpace__ecere__sys__OldList * this);
180
181 void __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add(struct __ecereNameSpace__ecere__sys__OldList * this, void *  item);
182
183 void __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove(struct __ecereNameSpace__ecere__sys__OldList * this, void *  item);
184
185 unsigned int __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert(struct __ecereNameSpace__ecere__sys__OldList * this, void *  prevItem, void *  item);
186
187 void __ecereMethod___ecereNameSpace__ecere__sys__OldList_Free(struct __ecereNameSpace__ecere__sys__OldList * this, void (*  freeFn)(void * ));
188
189 extern struct Pointer * MkPointer(struct __ecereNameSpace__ecere__sys__OldList * qualifiers, struct Pointer * pointer);
190
191 struct Location
192 {
193 struct CodePosition start;
194 struct CodePosition end;
195 } __attribute__ ((gcc_struct));
196
197 extern struct Location yylloc;
198
199 struct External;
200
201 extern struct External * curExternal;
202
203 static struct External * createInstancesExternal;
204
205 static struct External * destroyInstancesExternal;
206
207 extern struct External * DeclareStruct(struct External * neededBy, const char *  name, unsigned int skipNoHead, unsigned int needDereference);
208
209 struct TopoEdge
210 {
211 struct __ecereNameSpace__ecere__com__LinkElement in;
212 struct __ecereNameSpace__ecere__com__LinkElement out;
213 struct External * from;
214 struct External * to;
215 unsigned int breakable;
216 } __attribute__ ((gcc_struct));
217
218 struct Statement;
219
220 static struct Statement * curCompound;
221
222 static struct Statement * createInstancesBody;
223
224 static struct Statement * destroyInstancesBody;
225
226 extern struct Statement * MkCompoundStmt(struct __ecereNameSpace__ecere__sys__OldList * declarations, struct __ecereNameSpace__ecere__sys__OldList * statements);
227
228 extern struct Statement * MkExpressionStmt(struct __ecereNameSpace__ecere__sys__OldList * expressions);
229
230 struct Context;
231
232 extern struct Context * globalContext;
233
234 extern struct Context * curContext;
235
236 extern struct Context * PushContext(void);
237
238 extern void PopContext(struct Context * ctx);
239
240 struct ModuleImport;
241
242 extern struct ModuleImport * mainModule;
243
244 struct ModuleImport
245 {
246 struct ModuleImport * prev;
247 struct ModuleImport * next;
248 char *  name;
249 struct __ecereNameSpace__ecere__sys__OldList classes;
250 struct __ecereNameSpace__ecere__sys__OldList functions;
251 int importType;
252 int importAccess;
253 } __attribute__ ((gcc_struct));
254
255 struct Expression;
256
257 extern struct Expression * CopyExpression(struct Expression * exp);
258
259 extern struct Expression * MkExpConstant(const char *  string);
260
261 extern struct Expression * MkExpOp(struct Expression * exp1, int op, struct Expression * exp2);
262
263 extern void ProcessExpressionType(struct Expression * exp);
264
265 extern struct Expression * MkExpBrackets(struct __ecereNameSpace__ecere__sys__OldList * expressions);
266
267 extern struct Expression * MkExpCast(struct TypeName * typeName, struct Expression * expression);
268
269 extern struct Expression * MkExpCall(struct Expression * expression, struct __ecereNameSpace__ecere__sys__OldList * arguments);
270
271 extern void FreeExpression(struct Expression * exp);
272
273 extern struct Expression * QMkExpId(const char *  id);
274
275 extern void CheckTemplateTypes(struct Expression * exp);
276
277 static void ProcessExpression(struct Expression *  exp);
278
279 void ProcessExpressionInstPass(struct Expression * exp)
280 {
281 ProcessExpression(exp);
282 }
283
284 struct Declaration;
285
286 extern struct Declaration * MkDeclaration(struct __ecereNameSpace__ecere__sys__OldList * specifiers, struct __ecereNameSpace__ecere__sys__OldList * initDeclarators);
287
288 extern struct External * MkExternalDeclaration(struct Declaration * declaration);
289
290 static struct Declaration * curDecl;
291
292 struct __ecereNameSpace__ecere__com__Class;
293
294 struct __ecereNameSpace__ecere__com__Instance
295 {
296 void * *  _vTbl;
297 struct __ecereNameSpace__ecere__com__Class * _class;
298 int _refCount;
299 } __attribute__ ((gcc_struct));
300
301 extern long long __ecereNameSpace__ecere__com__eClass_GetProperty(struct __ecereNameSpace__ecere__com__Class * _class, const char *  name);
302
303 extern void __ecereNameSpace__ecere__com__eClass_SetProperty(struct __ecereNameSpace__ecere__com__Class * _class, const char *  name, long long value);
304
305 extern void *  __ecereNameSpace__ecere__com__eInstance_New(struct __ecereNameSpace__ecere__com__Class * _class);
306
307 extern void __ecereNameSpace__ecere__com__eInstance_SetMethod(struct __ecereNameSpace__ecere__com__Instance * instance, const char *  name, void *  function);
308
309 extern void __ecereNameSpace__ecere__com__eInstance_IncRef(struct __ecereNameSpace__ecere__com__Instance * instance);
310
311 int __ecereVMethodID___ecereNameSpace__ecere__com__Container_Remove;
312
313 int __ecereVMethodID___ecereNameSpace__ecere__com__Container_GetNext;
314
315 int __ecereVMethodID___ecereNameSpace__ecere__com__Container_Add;
316
317 struct __ecereNameSpace__ecere__com__Property;
318
319 extern void __ecereNameSpace__ecere__com__eInstance_FireSelfWatchers(struct __ecereNameSpace__ecere__com__Instance * instance, struct __ecereNameSpace__ecere__com__Property * _property);
320
321 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);
322
323 extern void __ecereNameSpace__ecere__com__eInstance_Watch(void *  instance, struct __ecereNameSpace__ecere__com__Property * _property, void *  object, void (*  callback)(void * , void * ));
324
325 extern void __ecereNameSpace__ecere__com__eInstance_FireWatchers(struct __ecereNameSpace__ecere__com__Instance * instance, struct __ecereNameSpace__ecere__com__Property * _property);
326
327 extern void DeclareProperty(struct External * neededBy, struct __ecereNameSpace__ecere__com__Property * prop, char *  setName, char *  getName);
328
329 struct Specifier;
330
331 extern struct Specifier * MkSpecifier(int specifier);
332
333 extern struct Specifier * MkSpecifierName(const char *  name);
334
335 extern struct Specifier * CopySpecifier(struct Specifier * spec);
336
337 extern struct Expression * MkExpClassSize(struct Specifier * _class);
338
339 struct Identifier;
340
341 struct Statement
342 {
343 struct Statement * prev;
344 struct Statement * next;
345 struct Location loc;
346 int type;
347 union
348 {
349 struct __ecereNameSpace__ecere__sys__OldList *  expressions;
350 struct
351 {
352 struct Identifier * id;
353 struct Statement * stmt;
354 } __attribute__ ((gcc_struct)) labeled;
355 struct
356 {
357 struct Expression * exp;
358 struct Statement * stmt;
359 } __attribute__ ((gcc_struct)) caseStmt;
360 struct
361 {
362 struct __ecereNameSpace__ecere__sys__OldList * declarations;
363 struct __ecereNameSpace__ecere__sys__OldList * statements;
364 struct Context * context;
365 unsigned int isSwitch;
366 } __attribute__ ((gcc_struct)) compound;
367 struct
368 {
369 struct __ecereNameSpace__ecere__sys__OldList * exp;
370 struct Statement * stmt;
371 struct Statement * elseStmt;
372 } __attribute__ ((gcc_struct)) ifStmt;
373 struct
374 {
375 struct __ecereNameSpace__ecere__sys__OldList * exp;
376 struct Statement * stmt;
377 } __attribute__ ((gcc_struct)) switchStmt;
378 struct
379 {
380 struct __ecereNameSpace__ecere__sys__OldList * exp;
381 struct Statement * stmt;
382 } __attribute__ ((gcc_struct)) whileStmt;
383 struct
384 {
385 struct __ecereNameSpace__ecere__sys__OldList * exp;
386 struct Statement * stmt;
387 } __attribute__ ((gcc_struct)) doWhile;
388 struct
389 {
390 struct Statement * init;
391 struct Statement * check;
392 struct __ecereNameSpace__ecere__sys__OldList * increment;
393 struct Statement * stmt;
394 } __attribute__ ((gcc_struct)) forStmt;
395 struct
396 {
397 struct Identifier * id;
398 } __attribute__ ((gcc_struct)) gotoStmt;
399 struct
400 {
401 struct Specifier * spec;
402 char * statements;
403 struct __ecereNameSpace__ecere__sys__OldList * inputFields;
404 struct __ecereNameSpace__ecere__sys__OldList * outputFields;
405 struct __ecereNameSpace__ecere__sys__OldList * clobberedFields;
406 } __attribute__ ((gcc_struct)) asmStmt;
407 struct
408 {
409 struct Expression * watcher;
410 struct Expression * object;
411 struct __ecereNameSpace__ecere__sys__OldList * watches;
412 } __attribute__ ((gcc_struct)) _watch;
413 struct
414 {
415 struct Identifier * id;
416 struct __ecereNameSpace__ecere__sys__OldList * exp;
417 struct __ecereNameSpace__ecere__sys__OldList * filter;
418 struct Statement * stmt;
419 } __attribute__ ((gcc_struct)) forEachStmt;
420 struct Declaration * decl;
421 } __attribute__ ((gcc_struct)) __anon1;
422 } __attribute__ ((gcc_struct));
423
424 extern struct Identifier * MkIdentifier(const char *  string);
425
426 extern struct Expression * MkExpMember(struct Expression * expression, struct Identifier * member);
427
428 extern struct Expression * MkExpIdentifier(struct Identifier * id);
429
430 extern struct Specifier * MkStructOrUnion(int type, struct Identifier * id, struct __ecereNameSpace__ecere__sys__OldList * definitions);
431
432 extern struct Identifier * CopyIdentifier(struct Identifier * id);
433
434 struct Type;
435
436 struct __ecereNameSpace__ecere__com__Property
437 {
438 struct __ecereNameSpace__ecere__com__Property * prev;
439 struct __ecereNameSpace__ecere__com__Property * next;
440 const char *  name;
441 unsigned int isProperty;
442 int memberAccess;
443 int id;
444 struct __ecereNameSpace__ecere__com__Class * _class;
445 const char *  dataTypeString;
446 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
447 struct Type * dataType;
448 void (*  Set)(void * , int);
449 int (*  Get)(void * );
450 unsigned int (*  IsSet)(void * );
451 void *  data;
452 void *  symbol;
453 int vid;
454 unsigned int conversion;
455 unsigned int watcherOffset;
456 const char *  category;
457 unsigned int compiled;
458 unsigned int selfWatchable;
459 unsigned int isWatchable;
460 } __attribute__ ((gcc_struct));
461
462 extern void FreeType(struct Type * type);
463
464 extern struct Type * MkClassType(const char *  name);
465
466 extern void CopyTypeInto(struct Type * type, struct Type * src);
467
468 extern struct Type * ProcessTypeString(const char *  string, unsigned int staticMethod);
469
470 struct Initializer;
471
472 struct Initializer
473 {
474 struct Initializer * prev;
475 struct Initializer * next;
476 struct Location loc;
477 int type;
478 union
479 {
480 struct Expression * exp;
481 struct __ecereNameSpace__ecere__sys__OldList *  list;
482 } __attribute__ ((gcc_struct)) __anon1;
483 unsigned int isConstant;
484 struct Identifier * id;
485 } __attribute__ ((gcc_struct));
486
487 extern void FreeInitializer(struct Initializer * initializer);
488
489 extern struct Initializer * MkInitializerList(struct __ecereNameSpace__ecere__sys__OldList * list);
490
491 extern struct Initializer * MkInitializerAssignment(struct Expression * exp);
492
493 struct Symbol;
494
495 struct Specifier
496 {
497 struct Specifier * prev;
498 struct Specifier * next;
499 struct Location loc;
500 int type;
501 union
502 {
503 int specifier;
504 struct
505 {
506 struct ExtDecl * extDecl;
507 char *  name;
508 struct Symbol * symbol;
509 struct __ecereNameSpace__ecere__sys__OldList *  templateArgs;
510 struct Specifier * nsSpec;
511 } __attribute__ ((gcc_struct)) __anon1;
512 struct
513 {
514 struct Identifier * id;
515 struct __ecereNameSpace__ecere__sys__OldList *  list;
516 struct __ecereNameSpace__ecere__sys__OldList *  baseSpecs;
517 struct __ecereNameSpace__ecere__sys__OldList *  definitions;
518 unsigned int addNameSpace;
519 struct Context * ctx;
520 struct ExtDecl * extDeclStruct;
521 } __attribute__ ((gcc_struct)) __anon2;
522 struct Expression * expression;
523 struct Specifier * _class;
524 struct TemplateParameter * templateParameter;
525 } __attribute__ ((gcc_struct)) __anon1;
526 } __attribute__ ((gcc_struct));
527
528 struct Identifier
529 {
530 struct Identifier * prev;
531 struct Identifier * next;
532 struct Location loc;
533 struct Symbol * classSym;
534 struct Specifier * _class;
535 char *  string;
536 struct Identifier * badID;
537 } __attribute__ ((gcc_struct));
538
539 extern struct Symbol * FindClass(const char *  name);
540
541 extern struct Specifier * _MkSpecifierName(const char *  name, struct Symbol * symbol, struct __ecereNameSpace__ecere__sys__OldList * templateArgs);
542
543 extern struct Type * MkClassTypeSymbol(struct Symbol * symbol);
544
545 extern void FreeSymbol(struct Symbol * symbol);
546
547 struct Instantiation;
548
549 struct Instantiation
550 {
551 struct Instantiation * prev;
552 struct Instantiation * next;
553 struct Location loc;
554 struct Specifier * _class;
555 struct Expression * exp;
556 struct __ecereNameSpace__ecere__sys__OldList *  members;
557 struct Symbol * symbol;
558 unsigned int fullSet;
559 unsigned int isConstant;
560 unsigned char *  data;
561 struct Location nameLoc;
562 struct Location insideLoc;
563 unsigned int built;
564 } __attribute__ ((gcc_struct));
565
566 struct Declaration
567 {
568 struct Declaration * prev;
569 struct Declaration * next;
570 struct Location loc;
571 int type;
572 union
573 {
574 struct
575 {
576 struct __ecereNameSpace__ecere__sys__OldList *  specifiers;
577 struct __ecereNameSpace__ecere__sys__OldList *  declarators;
578 } __attribute__ ((gcc_struct)) __anon1;
579 struct Instantiation * inst;
580 struct
581 {
582 struct Identifier * id;
583 struct Expression * exp;
584 } __attribute__ ((gcc_struct)) __anon2;
585 } __attribute__ ((gcc_struct)) __anon1;
586 struct Specifier * extStorage;
587 struct Symbol * symbol;
588 int declMode;
589 } __attribute__ ((gcc_struct));
590
591 extern struct Declaration * MkDeclarationInst(struct Instantiation * inst);
592
593 extern struct Instantiation * MkInstantiation(struct Specifier * _class, struct Expression * exp, struct __ecereNameSpace__ecere__sys__OldList * members);
594
595 extern void FreeInstance(struct Instantiation * inst);
596
597 extern struct Expression * MkExpInstance(struct Instantiation * inst);
598
599 struct __ecereNameSpace__ecere__com__Method;
600
601 struct __ecereNameSpace__ecere__com__Method
602 {
603 const char *  name;
604 struct __ecereNameSpace__ecere__com__Method * parent;
605 struct __ecereNameSpace__ecere__com__Method * left;
606 struct __ecereNameSpace__ecere__com__Method * right;
607 int depth;
608 int (*  function)();
609 int vid;
610 int type;
611 struct __ecereNameSpace__ecere__com__Class * _class;
612 void *  symbol;
613 const char *  dataTypeString;
614 struct Type * dataType;
615 int memberAccess;
616 } __attribute__ ((gcc_struct));
617
618 struct Type
619 {
620 struct Type * prev;
621 struct Type * next;
622 int refCount;
623 union
624 {
625 struct Symbol * _class;
626 struct
627 {
628 struct __ecereNameSpace__ecere__sys__OldList members;
629 char *  enumName;
630 } __attribute__ ((gcc_struct)) __anon1;
631 struct
632 {
633 struct Type * returnType;
634 struct __ecereNameSpace__ecere__sys__OldList params;
635 struct Symbol * thisClass;
636 unsigned int staticMethod;
637 struct TemplateParameter * thisClassTemplate;
638 } __attribute__ ((gcc_struct)) __anon2;
639 struct
640 {
641 struct __ecereNameSpace__ecere__com__Method * method;
642 struct __ecereNameSpace__ecere__com__Class * methodClass;
643 struct __ecereNameSpace__ecere__com__Class * usedClass;
644 } __attribute__ ((gcc_struct)) __anon3;
645 struct
646 {
647 struct Type * arrayType;
648 int arraySize;
649 struct Expression * arraySizeExp;
650 unsigned int freeExp;
651 struct Symbol * enumClass;
652 } __attribute__ ((gcc_struct)) __anon4;
653 struct Type * type;
654 struct TemplateParameter * templateParameter;
655 } __attribute__ ((gcc_struct)) __anon1;
656 int kind;
657 unsigned int size;
658 char *  name;
659 char *  typeName;
660 struct __ecereNameSpace__ecere__com__Class * thisClassFrom;
661 int classObjectType;
662 int alignment;
663 unsigned int offset;
664 int bitFieldCount;
665 int count;
666 unsigned int isSigned : 1;
667 unsigned int constant : 1;
668 unsigned int truth : 1;
669 unsigned int byReference : 1;
670 unsigned int extraParam : 1;
671 unsigned int directClassAccess : 1;
672 unsigned int computing : 1;
673 unsigned int keepCast : 1;
674 unsigned int passAsTemplate : 1;
675 unsigned int dllExport : 1;
676 unsigned int attrStdcall : 1;
677 unsigned int declaredWithStruct : 1;
678 unsigned int typedByReference : 1;
679 unsigned int casted : 1;
680 unsigned int pointerAlignment : 1;
681 } __attribute__ ((gcc_struct));
682
683 extern void ProcessMethodType(struct __ecereNameSpace__ecere__com__Method * method);
684
685 struct Declarator;
686
687 extern struct Declarator * MkDeclaratorFunction(struct Declarator * declarator, struct __ecereNameSpace__ecere__sys__OldList * parameters);
688
689 extern struct Declarator * MkDeclaratorIdentifier(struct Identifier * id);
690
691 struct Expression
692 {
693 struct Expression * prev;
694 struct Expression * next;
695 struct Location loc;
696 int type;
697 union
698 {
699 struct
700 {
701 char *  constant;
702 struct Identifier * identifier;
703 } __attribute__ ((gcc_struct)) __anon1;
704 struct Statement * compound;
705 struct Instantiation * instance;
706 struct
707 {
708 char *  string;
709 unsigned int intlString;
710 unsigned int wideString;
711 } __attribute__ ((gcc_struct)) __anon2;
712 struct __ecereNameSpace__ecere__sys__OldList *  list;
713 struct
714 {
715 struct __ecereNameSpace__ecere__sys__OldList * specifiers;
716 struct Declarator * decl;
717 } __attribute__ ((gcc_struct)) _classExp;
718 struct
719 {
720 struct Identifier * id;
721 } __attribute__ ((gcc_struct)) classData;
722 struct
723 {
724 struct Expression * exp;
725 struct __ecereNameSpace__ecere__sys__OldList * arguments;
726 struct Location argLoc;
727 } __attribute__ ((gcc_struct)) call;
728 struct
729 {
730 struct Expression * exp;
731 struct __ecereNameSpace__ecere__sys__OldList * index;
732 } __attribute__ ((gcc_struct)) index;
733 struct
734 {
735 struct Expression * exp;
736 struct Identifier * member;
737 int memberType;
738 unsigned int thisPtr;
739 } __attribute__ ((gcc_struct)) member;
740 struct
741 {
742 int op;
743 struct Expression * exp1;
744 struct Expression * exp2;
745 } __attribute__ ((gcc_struct)) op;
746 struct TypeName * typeName;
747 struct Specifier * _class;
748 struct
749 {
750 struct TypeName * typeName;
751 struct Expression * exp;
752 } __attribute__ ((gcc_struct)) cast;
753 struct
754 {
755 struct Expression * cond;
756 struct __ecereNameSpace__ecere__sys__OldList * exp;
757 struct Expression * elseExp;
758 } __attribute__ ((gcc_struct)) cond;
759 struct
760 {
761 struct TypeName * typeName;
762 struct Expression * size;
763 } __attribute__ ((gcc_struct)) _new;
764 struct
765 {
766 struct TypeName * typeName;
767 struct Expression * size;
768 struct Expression * exp;
769 } __attribute__ ((gcc_struct)) _renew;
770 struct
771 {
772 char * table;
773 struct Identifier * id;
774 } __attribute__ ((gcc_struct)) db;
775 struct
776 {
777 struct Expression * ds;
778 struct Expression * name;
779 } __attribute__ ((gcc_struct)) dbopen;
780 struct
781 {
782 struct TypeName * typeName;
783 struct Initializer * initializer;
784 } __attribute__ ((gcc_struct)) initializer;
785 struct
786 {
787 struct Expression * exp;
788 struct TypeName * typeName;
789 } __attribute__ ((gcc_struct)) vaArg;
790 } __attribute__ ((gcc_struct)) __anon1;
791 unsigned int debugValue;
792 struct __ecereNameSpace__ecere__com__DataValue val;
793 uint64 address;
794 unsigned int hasAddress;
795 struct Type * expType;
796 struct Type * destType;
797 unsigned int usage;
798 int tempCount;
799 unsigned int byReference;
800 unsigned int isConstant;
801 unsigned int addedThis;
802 unsigned int needCast;
803 unsigned int thisPtr;
804 unsigned int opDestType;
805 unsigned int needTemplateCast;
806 } __attribute__ ((gcc_struct));
807
808 extern struct Declarator * SpecDeclFromString(const char *  string, struct __ecereNameSpace__ecere__sys__OldList *  specs, struct Declarator * baseDecl);
809
810 extern struct TypeName * MkTypeName(struct __ecereNameSpace__ecere__sys__OldList * qualifiers, struct Declarator * declarator);
811
812 extern struct TypeName * QMkClass(const char *  spec, struct Declarator * decl);
813
814 extern struct Declarator * MkDeclaratorPointer(struct Pointer * pointer, struct Declarator * declarator);
815
816 struct Declarator
817 {
818 struct Declarator * prev;
819 struct Declarator * next;
820 struct Location loc;
821 int type;
822 struct Symbol * symbol;
823 struct Declarator * declarator;
824 union
825 {
826 struct Identifier * identifier;
827 struct
828 {
829 struct Expression * exp;
830 struct Expression * posExp;
831 struct Attrib * attrib;
832 } __attribute__ ((gcc_struct)) structDecl;
833 struct
834 {
835 struct Expression * exp;
836 struct Specifier * enumClass;
837 } __attribute__ ((gcc_struct)) array;
838 struct
839 {
840 struct __ecereNameSpace__ecere__sys__OldList * parameters;
841 } __attribute__ ((gcc_struct)) function;
842 struct
843 {
844 struct Pointer * pointer;
845 } __attribute__ ((gcc_struct)) pointer;
846 struct
847 {
848 struct ExtDecl * extended;
849 } __attribute__ ((gcc_struct)) extended;
850 } __attribute__ ((gcc_struct)) __anon1;
851 } __attribute__ ((gcc_struct));
852
853 static void ProcessInitializer(struct Initializer * init)
854 {
855 switch(init->type)
856 {
857 case 0:
858 init->__anon1.exp->usage = (init->__anon1.exp->usage & ~0x1) | (((unsigned int)(1)) << 0);
859 ProcessExpression(init->__anon1.exp);
860 break;
861 case 1:
862 {
863 struct Initializer * i;
864
865 for(i = (*init->__anon1.list).first; i; i = i->next)
866 ProcessInitializer(i);
867 break;
868 }
869 }
870 }
871
872 struct ClassImport;
873
874 struct Symbol
875 {
876 char *  string;
877 struct Symbol * parent;
878 struct Symbol * left;
879 struct Symbol * right;
880 int depth;
881 struct Type * type;
882 union
883 {
884 struct __ecereNameSpace__ecere__com__Method * method;
885 struct __ecereNameSpace__ecere__com__Property * _property;
886 struct __ecereNameSpace__ecere__com__Class * registered;
887 } __attribute__ ((gcc_struct)) __anon1;
888 unsigned int notYetDeclared;
889 union
890 {
891 struct
892 {
893 struct External * pointerExternal;
894 struct External * structExternal;
895 } __attribute__ ((gcc_struct)) __anon1;
896 struct
897 {
898 struct External * externalGet;
899 struct External * externalSet;
900 struct External * externalPtr;
901 struct External * externalIsSet;
902 } __attribute__ ((gcc_struct)) __anon2;
903 struct
904 {
905 struct External * methodExternal;
906 struct External * methodCodeExternal;
907 } __attribute__ ((gcc_struct)) __anon3;
908 } __attribute__ ((gcc_struct)) __anon2;
909 unsigned int imported;
910 unsigned int declaredStructSym;
911 struct __ecereNameSpace__ecere__com__Class * _class;
912 unsigned int declaredStruct;
913 unsigned int needConstructor;
914 unsigned int needDestructor;
915 char *  constructorName;
916 char *  structName;
917 char *  className;
918 char *  destructorName;
919 struct ModuleImport * module;
920 struct ClassImport * _import;
921 struct Location nameLoc;
922 unsigned int isParam;
923 unsigned int isRemote;
924 unsigned int isStruct;
925 unsigned int fireWatchersDone;
926 int declaring;
927 unsigned int classData;
928 unsigned int isStatic;
929 char *  shortName;
930 struct __ecereNameSpace__ecere__sys__OldList *  templateParams;
931 struct __ecereNameSpace__ecere__sys__OldList templatedClasses;
932 struct Context * ctx;
933 int isIterator;
934 struct Expression * propCategory;
935 unsigned int mustRegister;
936 } __attribute__ ((gcc_struct));
937
938 struct ClassImport
939 {
940 struct ClassImport * prev;
941 struct ClassImport * next;
942 char *  name;
943 struct __ecereNameSpace__ecere__sys__OldList methods;
944 struct __ecereNameSpace__ecere__sys__OldList properties;
945 unsigned int itself;
946 int isRemote;
947 } __attribute__ ((gcc_struct));
948
949 struct MembersInit;
950
951 extern struct MembersInit * MkMembersInitList(struct __ecereNameSpace__ecere__sys__OldList * dataMembers);
952
953 struct __ecereNameSpace__ecere__sys__BinaryTree;
954
955 struct __ecereNameSpace__ecere__sys__BinaryTree
956 {
957 struct __ecereNameSpace__ecere__sys__BTNode * root;
958 int count;
959 int (*  CompareKey)(struct __ecereNameSpace__ecere__sys__BinaryTree * tree, uintptr_t a, uintptr_t b);
960 void (*  FreeKey)(void *  key);
961 } __attribute__ ((gcc_struct));
962
963 unsigned int __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Add(struct __ecereNameSpace__ecere__sys__BinaryTree * this, struct __ecereNameSpace__ecere__sys__BTNode * node);
964
965 void __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Remove(struct __ecereNameSpace__ecere__sys__BinaryTree * this, struct __ecereNameSpace__ecere__sys__BTNode * node);
966
967 struct FunctionDefinition;
968
969 extern struct FunctionDefinition * _MkFunction(struct __ecereNameSpace__ecere__sys__OldList * specifiers, struct Declarator * declarator, struct __ecereNameSpace__ecere__sys__OldList * declarationList, unsigned int errorOnOmit);
970
971 extern void ProcessFunctionBody(struct FunctionDefinition * func, struct Statement * body);
972
973 extern struct External * MkExternalFunction(struct FunctionDefinition * function);
974
975 struct FunctionDefinition
976 {
977 struct FunctionDefinition * prev;
978 struct FunctionDefinition * next;
979 struct Location loc;
980 struct __ecereNameSpace__ecere__sys__OldList *  specifiers;
981 struct Declarator * declarator;
982 struct __ecereNameSpace__ecere__sys__OldList *  declarations;
983 struct Statement * body;
984 struct __ecereNameSpace__ecere__com__Class * _class;
985 struct __ecereNameSpace__ecere__sys__OldList attached;
986 int declMode;
987 struct Type * type;
988 struct Symbol * propSet;
989 int tempCount;
990 unsigned int propertyNoThis;
991 } __attribute__ ((gcc_struct));
992
993 struct PropertyWatch;
994
995 struct PropertyWatch
996 {
997 struct PropertyWatch * prev;
998 struct PropertyWatch * next;
999 struct Location loc;
1000 struct Statement * compound;
1001 struct __ecereNameSpace__ecere__sys__OldList *  properties;
1002 unsigned int deleteWatch;
1003 } __attribute__ ((gcc_struct));
1004
1005 struct InitDeclarator;
1006
1007 extern struct InitDeclarator * MkInitDeclarator(struct Declarator * declarator, struct Initializer * initializer);
1008
1009 extern struct Declaration * QMkDeclaration(const char *  name, struct InitDeclarator * initDecl);
1010
1011 struct InitDeclarator
1012 {
1013 struct InitDeclarator * prev;
1014 struct InitDeclarator * next;
1015 struct Location loc;
1016 struct Declarator * declarator;
1017 struct Initializer * initializer;
1018 } __attribute__ ((gcc_struct));
1019
1020 struct __ecereNameSpace__ecere__com__DataMember;
1021
1022 struct __ecereNameSpace__ecere__com__ClassTemplateArgument
1023 {
1024 union
1025 {
1026 struct
1027 {
1028 const char *  dataTypeString;
1029 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
1030 } __attribute__ ((gcc_struct)) __anon1;
1031 struct __ecereNameSpace__ecere__com__DataValue expression;
1032 struct
1033 {
1034 const char *  memberString;
1035 union
1036 {
1037 struct __ecereNameSpace__ecere__com__DataMember * member;
1038 struct __ecereNameSpace__ecere__com__Property * prop;
1039 struct __ecereNameSpace__ecere__com__Method * method;
1040 } __attribute__ ((gcc_struct)) __anon1;
1041 } __attribute__ ((gcc_struct)) __anon2;
1042 } __attribute__ ((gcc_struct)) __anon1;
1043 } __attribute__ ((gcc_struct));
1044
1045 struct __ecereNameSpace__ecere__com__DataMember
1046 {
1047 struct __ecereNameSpace__ecere__com__DataMember * prev;
1048 struct __ecereNameSpace__ecere__com__DataMember * next;
1049 const char *  name;
1050 unsigned int isProperty;
1051 int memberAccess;
1052 int id;
1053 struct __ecereNameSpace__ecere__com__Class * _class;
1054 const char *  dataTypeString;
1055 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
1056 struct Type * dataType;
1057 int type;
1058 int offset;
1059 int memberID;
1060 struct __ecereNameSpace__ecere__sys__OldList members;
1061 struct __ecereNameSpace__ecere__sys__BinaryTree membersAlpha;
1062 int memberOffset;
1063 short structAlignment;
1064 short pointerAlignment;
1065 } __attribute__ ((gcc_struct));
1066
1067 extern void __ecereNameSpace__ecere__com__eClass_FindNextMember(struct __ecereNameSpace__ecere__com__Class * _class, struct __ecereNameSpace__ecere__com__Class **  curClass, struct __ecereNameSpace__ecere__com__DataMember **  curMember, struct __ecereNameSpace__ecere__com__DataMember **  subMemberStack, int *  subMemberStackPos);
1068
1069 struct __ecereNameSpace__ecere__com__Module;
1070
1071 extern struct __ecereNameSpace__ecere__com__Property * __ecereNameSpace__ecere__com__eClass_FindProperty(struct __ecereNameSpace__ecere__com__Class * _class, const char *  name, struct __ecereNameSpace__ecere__com__Instance * module);
1072
1073 extern struct __ecereNameSpace__ecere__com__Instance * privateModule;
1074
1075 extern struct __ecereNameSpace__ecere__com__DataMember * __ecereNameSpace__ecere__com__eClass_FindDataMember(struct __ecereNameSpace__ecere__com__Class * _class, const char *  name, struct __ecereNameSpace__ecere__com__Instance * module, struct __ecereNameSpace__ecere__com__DataMember **  subMemberStack, int *  subMemberStackPos);
1076
1077 extern struct __ecereNameSpace__ecere__com__Method * __ecereNameSpace__ecere__com__eClass_FindMethod(struct __ecereNameSpace__ecere__com__Class * _class, const char *  name, struct __ecereNameSpace__ecere__com__Instance * module);
1078
1079 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);
1080
1081 struct Enumerator;
1082
1083 struct Enumerator
1084 {
1085 struct Enumerator * prev;
1086 struct Enumerator * next;
1087 struct Location loc;
1088 struct Identifier * id;
1089 struct Expression * exp;
1090 } __attribute__ ((gcc_struct));
1091
1092 struct AsmField;
1093
1094 struct AsmField
1095 {
1096 struct AsmField * prev;
1097 struct AsmField * next;
1098 struct Location loc;
1099 char *  command;
1100 struct Expression * expression;
1101 struct Identifier * symbolic;
1102 } __attribute__ ((gcc_struct));
1103
1104 struct __ecereNameSpace__ecere__com__BitMember;
1105
1106 struct __ecereNameSpace__ecere__com__BitMember
1107 {
1108 struct __ecereNameSpace__ecere__com__BitMember * prev;
1109 struct __ecereNameSpace__ecere__com__BitMember * next;
1110 const char *  name;
1111 unsigned int isProperty;
1112 int memberAccess;
1113 int id;
1114 struct __ecereNameSpace__ecere__com__Class * _class;
1115 const char *  dataTypeString;
1116 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
1117 struct Type * dataType;
1118 int type;
1119 int size;
1120 int pos;
1121 uint64 mask;
1122 } __attribute__ ((gcc_struct));
1123
1124 struct MemberInit;
1125
1126 struct MemberInit
1127 {
1128 struct MemberInit * prev;
1129 struct MemberInit * next;
1130 struct Location loc;
1131 struct Location realLoc;
1132 struct __ecereNameSpace__ecere__sys__OldList *  identifiers;
1133 struct Initializer * initializer;
1134 unsigned int used;
1135 unsigned int variable;
1136 unsigned int takeOutExp;
1137 } __attribute__ ((gcc_struct));
1138
1139 extern struct MemberInit * MkMemberInit(struct __ecereNameSpace__ecere__sys__OldList * ids, struct Initializer * initializer);
1140
1141 static void ProcessMemberInitData(struct MemberInit * member)
1142 {
1143 if(member->initializer)
1144 ProcessInitializer(member->initializer);
1145 }
1146
1147 struct ClassDefinition;
1148
1149 struct Context
1150 {
1151 struct Context * parent;
1152 struct __ecereNameSpace__ecere__sys__BinaryTree types;
1153 struct __ecereNameSpace__ecere__sys__BinaryTree classes;
1154 struct __ecereNameSpace__ecere__sys__BinaryTree symbols;
1155 struct __ecereNameSpace__ecere__sys__BinaryTree structSymbols;
1156 int nextID;
1157 int simpleID;
1158 struct __ecereNameSpace__ecere__sys__BinaryTree templateTypes;
1159 struct ClassDefinition * classDef;
1160 unsigned int templateTypesOnly;
1161 unsigned int hasNameSpace;
1162 } __attribute__ ((gcc_struct));
1163
1164 struct External
1165 {
1166 struct External * prev;
1167 struct External * next;
1168 struct Location loc;
1169 int type;
1170 struct Symbol * symbol;
1171 union
1172 {
1173 struct FunctionDefinition * function;
1174 struct ClassDefinition * _class;
1175 struct Declaration * declaration;
1176 char *  importString;
1177 struct Identifier * id;
1178 struct DBTableDef * table;
1179 } __attribute__ ((gcc_struct)) __anon1;
1180 int importType;
1181 struct External * fwdDecl;
1182 struct __ecereNameSpace__ecere__com__Instance * outgoing;
1183 struct __ecereNameSpace__ecere__com__Instance * incoming;
1184 int nonBreakableIncoming;
1185 } __attribute__ ((gcc_struct));
1186
1187 struct ClassDefinition
1188 {
1189 struct ClassDefinition * prev;
1190 struct ClassDefinition * next;
1191 struct Location loc;
1192 struct Specifier * _class;
1193 struct __ecereNameSpace__ecere__sys__OldList *  baseSpecs;
1194 struct __ecereNameSpace__ecere__sys__OldList *  definitions;
1195 struct Symbol * symbol;
1196 struct Location blockStart;
1197 struct Location nameLoc;
1198 int declMode;
1199 unsigned int deleteWatchable;
1200 } __attribute__ ((gcc_struct));
1201
1202 void __ecereMethod_External_CreateUniqueEdge(struct External * this, struct External * from, unsigned int soft);
1203
1204 void __ecereMethod_External_CreateEdge(struct External * this, struct External * from, unsigned int soft);
1205
1206 struct ClassFunction;
1207
1208 struct MembersInit
1209 {
1210 struct MembersInit * prev;
1211 struct MembersInit * next;
1212 struct Location loc;
1213 int type;
1214 union
1215 {
1216 struct __ecereNameSpace__ecere__sys__OldList *  dataMembers;
1217 struct ClassFunction * function;
1218 } __attribute__ ((gcc_struct)) __anon1;
1219 } __attribute__ ((gcc_struct));
1220
1221 struct ClassFunction
1222 {
1223 struct ClassFunction * prev;
1224 struct ClassFunction * next;
1225 struct Location loc;
1226 struct __ecereNameSpace__ecere__sys__OldList *  specifiers;
1227 struct Declarator * declarator;
1228 struct __ecereNameSpace__ecere__sys__OldList *  declarations;
1229 struct Statement * body;
1230 struct __ecereNameSpace__ecere__com__Class * _class;
1231 struct __ecereNameSpace__ecere__sys__OldList attached;
1232 int declMode;
1233 struct Type * type;
1234 struct Symbol * propSet;
1235 unsigned int isVirtual;
1236 unsigned int isConstructor;
1237 unsigned int isDestructor;
1238 unsigned int dontMangle;
1239 int id;
1240 int idCode;
1241 } __attribute__ ((gcc_struct));
1242
1243 static unsigned int ProcessInstMembers_SimpleMemberEnsure(struct __ecereNameSpace__ecere__com__DataMember * parentMember, struct Instantiation * inst, struct Expression * instExp, struct __ecereNameSpace__ecere__sys__OldList * list, unsigned int zeroOut)
1244 {
1245 struct Symbol * classSym = inst->_class->__anon1.__anon1.symbol;
1246 unsigned int fullSet = 1;
1247 struct __ecereNameSpace__ecere__com__DataMember * dataMember;
1248
1249 for(dataMember = parentMember->members.first; dataMember; dataMember = dataMember->next)
1250 {
1251 if(!dataMember->isProperty)
1252 {
1253 if(!dataMember->name && (dataMember->type == 1 || dataMember->type == 2))
1254 {
1255 if(!ProcessInstMembers_SimpleMemberEnsure(dataMember, inst, instExp, list, zeroOut))
1256 fullSet = 0;
1257 }
1258 else
1259 {
1260 unsigned int memberFilled = 0;
1261
1262 if(inst->members && (*inst->members).first)
1263 {
1264 struct __ecereNameSpace__ecere__com__Class * curClass = (((void *)0));
1265 struct __ecereNameSpace__ecere__com__DataMember * curMember = (((void *)0));
1266 struct __ecereNameSpace__ecere__com__DataMember * subMemberStack[256];
1267 int subMemberStackPos = 0;
1268 struct MembersInit * members;
1269
1270 for(members = (*inst->members).first; members; members = members->next)
1271 {
1272 if(members->type == 0)
1273 {
1274 struct MemberInit * member = (((void *)0));
1275
1276 for(member = (*members->__anon1.dataMembers).first; member; member = member->next)
1277 {
1278 if(member->identifiers)
1279 {
1280 struct Identifier * firstID = (*member->identifiers).first;
1281 struct __ecereNameSpace__ecere__com__DataMember * _subMemberStack[256];
1282 int _subMemberStackPos = 0;
1283 struct __ecereNameSpace__ecere__com__DataMember * thisMember = (struct __ecereNameSpace__ecere__com__DataMember *)__ecereNameSpace__ecere__com__eClass_FindProperty(classSym->__anon1.registered, firstID->string, privateModule);
1284
1285 if(!thisMember)
1286 thisMember = __ecereNameSpace__ecere__com__eClass_FindDataMember(classSym->__anon1.registered, firstID->string, privateModule, _subMemberStack, &_subMemberStackPos);
1287 if(thisMember)
1288 {
1289 if(thisMember && thisMember->memberAccess == 1)
1290 {
1291 curMember = thisMember;
1292 curClass = curMember->_class;
1293 memcpy(subMemberStack, _subMemberStack, sizeof(struct __ecereNameSpace__ecere__com__DataMember *) * _subMemberStackPos);
1294 subMemberStackPos = _subMemberStackPos;
1295 }
1296 if(!firstID->next && thisMember == dataMember)
1297 {
1298 memberFilled = 1;
1299 break;
1300 }
1301 }
1302 }
1303 else
1304 {
1305 __ecereNameSpace__ecere__com__eClass_FindNextMember(classSym->__anon1.registered, &curClass, &curMember, subMemberStack, &subMemberStackPos);
1306 if(curMember == dataMember)
1307 {
1308 memberFilled = 1;
1309 break;
1310 }
1311 }
1312 }
1313 if(memberFilled)
1314 break;
1315 }
1316 if(memberFilled)
1317 break;
1318 }
1319 }
1320 if(!memberFilled)
1321 {
1322 if(zeroOut)
1323 {
1324 struct Expression * instExpCopy = CopyExpression(instExp);
1325 struct Expression * memberExp;
1326 struct Expression * setExp;
1327 struct Expression * value = MkExpConstant("0");
1328
1329 memberExp = MkExpMember(instExpCopy, MkIdentifier(dataMember->name));
1330 memberExp->__anon1.member.memberType = 3;
1331 value->usage = (value->usage & ~0x1) | (((unsigned int)(1)) << 0);
1332 setExp = MkExpOp(memberExp, '=', value);
1333 value->loc = inst->loc;
1334 setExp->loc = inst->loc;
1335 FreeType(instExpCopy->expType);
1336 instExpCopy->expType = instExp->expType;
1337 if(instExp->expType)
1338 instExp->expType->refCount++;
1339 ProcessExpressionType(setExp);
1340 ProcessExpression(setExp);
1341 ListAdd(list, setExp);
1342 }
1343 fullSet = 0;
1344 }
1345 }
1346 }
1347 }
1348 return fullSet;
1349 }
1350
1351 struct PropertyDef;
1352
1353 struct PropertyDef
1354 {
1355 struct PropertyDef * prev;
1356 struct PropertyDef * next;
1357 struct Location loc;
1358 struct __ecereNameSpace__ecere__sys__OldList *  specifiers;
1359 struct Declarator * declarator;
1360 struct Identifier * id;
1361 struct Statement * getStmt;
1362 struct Statement * setStmt;
1363 struct Statement * issetStmt;
1364 struct Symbol * symbol;
1365 struct Expression * category;
1366 struct
1367 {
1368 unsigned int conversion : 1;
1369 unsigned int isWatchable : 1;
1370 unsigned int isDBProp : 1;
1371 } __attribute__ ((gcc_struct)) __anon1;
1372 } __attribute__ ((gcc_struct));
1373
1374 struct __ecereNameSpace__ecere__com__NameSpace;
1375
1376 struct __ecereNameSpace__ecere__com__NameSpace
1377 {
1378 const char *  name;
1379 struct __ecereNameSpace__ecere__com__NameSpace *  btParent;
1380 struct __ecereNameSpace__ecere__com__NameSpace *  left;
1381 struct __ecereNameSpace__ecere__com__NameSpace *  right;
1382 int depth;
1383 struct __ecereNameSpace__ecere__com__NameSpace *  parent;
1384 struct __ecereNameSpace__ecere__sys__BinaryTree nameSpaces;
1385 struct __ecereNameSpace__ecere__sys__BinaryTree classes;
1386 struct __ecereNameSpace__ecere__sys__BinaryTree defines;
1387 struct __ecereNameSpace__ecere__sys__BinaryTree functions;
1388 } __attribute__ ((gcc_struct));
1389
1390 struct __ecereNameSpace__ecere__com__Class
1391 {
1392 struct __ecereNameSpace__ecere__com__Class * prev;
1393 struct __ecereNameSpace__ecere__com__Class * next;
1394 const char *  name;
1395 int offset;
1396 int structSize;
1397 void * *  _vTbl;
1398 int vTblSize;
1399 unsigned int (*  Constructor)(void * );
1400 void (*  Destructor)(void * );
1401 int offsetClass;
1402 int sizeClass;
1403 struct __ecereNameSpace__ecere__com__Class * base;
1404 struct __ecereNameSpace__ecere__sys__BinaryTree methods;
1405 struct __ecereNameSpace__ecere__sys__BinaryTree members;
1406 struct __ecereNameSpace__ecere__sys__BinaryTree prop;
1407 struct __ecereNameSpace__ecere__sys__OldList membersAndProperties;
1408 struct __ecereNameSpace__ecere__sys__BinaryTree classProperties;
1409 struct __ecereNameSpace__ecere__sys__OldList derivatives;
1410 int memberID;
1411 int startMemberID;
1412 int type;
1413 struct __ecereNameSpace__ecere__com__Instance * module;
1414 struct __ecereNameSpace__ecere__com__NameSpace *  nameSpace;
1415 const char *  dataTypeString;
1416 struct Type * dataType;
1417 int typeSize;
1418 int defaultAlignment;
1419 void (*  Initialize)();
1420 int memberOffset;
1421 struct __ecereNameSpace__ecere__sys__OldList selfWatchers;
1422 const char *  designerClass;
1423 unsigned int noExpansion;
1424 const char *  defaultProperty;
1425 unsigned int comRedefinition;
1426 int count;
1427 int isRemote;
1428 unsigned int internalDecl;
1429 void *  data;
1430 unsigned int computeSize;
1431 short structAlignment;
1432 short pointerAlignment;
1433 int destructionWatchOffset;
1434 unsigned int fixed;
1435 struct __ecereNameSpace__ecere__sys__OldList delayedCPValues;
1436 int inheritanceAccess;
1437 const char *  fullName;
1438 void *  symbol;
1439 struct __ecereNameSpace__ecere__sys__OldList conversions;
1440 struct __ecereNameSpace__ecere__sys__OldList templateParams;
1441 struct __ecereNameSpace__ecere__com__ClassTemplateArgument *  templateArgs;
1442 struct __ecereNameSpace__ecere__com__Class * templateClass;
1443 struct __ecereNameSpace__ecere__sys__OldList templatized;
1444 int numParams;
1445 unsigned int isInstanceClass;
1446 unsigned int byValueSystemClass;
1447 } __attribute__ ((gcc_struct));
1448
1449 struct __ecereNameSpace__ecere__com__Application
1450 {
1451 int argc;
1452 const char * *  argv;
1453 int exitCode;
1454 unsigned int isGUIApp;
1455 struct __ecereNameSpace__ecere__sys__OldList allModules;
1456 char *  parsedCommand;
1457 struct __ecereNameSpace__ecere__com__NameSpace systemNameSpace;
1458 } __attribute__ ((gcc_struct));
1459
1460 static unsigned int ProcessInstMembers(struct Instantiation * inst, struct Expression * instExp, struct __ecereNameSpace__ecere__sys__OldList * list, unsigned int zeroOut)
1461 {
1462 struct MembersInit * members;
1463 struct Symbol * classSym = inst->_class->__anon1.__anon1.symbol;
1464 unsigned int fullSet = 1, convert = 0;
1465
1466 if(classSym && classSym->__anon1.registered && classSym->__anon1.registered->type == 2)
1467 {
1468 struct Expression * exp = (((void *)0));
1469
1470 if(inst->members && (*inst->members).first)
1471 {
1472 struct __ecereNameSpace__ecere__com__Class * _class = (((void *)0));
1473
1474 while(_class != classSym->__anon1.registered)
1475 {
1476 struct __ecereNameSpace__ecere__com__BitMember * bitMember = (((void *)0));
1477 struct __ecereNameSpace__ecere__com__Class * lastClass = _class;
1478
1479 for(_class = classSym->__anon1.registered; _class->base != lastClass && _class->base->type != 1000; _class = _class->base)
1480 ;
1481 for(bitMember = _class->membersAndProperties.first; bitMember; bitMember = bitMember->next)
1482 {
1483 struct __ecereNameSpace__ecere__com__BitMember * curMember = (((void *)0));
1484 struct __ecereNameSpace__ecere__com__Class * curClass = (((void *)0));
1485 struct __ecereNameSpace__ecere__com__DataMember * subMemberStack[256];
1486 int subMemberStackPos = 0;
1487 struct MemberInit * member = (((void *)0));
1488 unsigned int found = 0;
1489
1490 for(members = (*inst->members).first; members; members = members->next)
1491 {
1492 if(members->type == 0)
1493 {
1494 for(member = (*members->__anon1.dataMembers).first; member; member = member->next)
1495 {
1496 if(member->identifiers)
1497 {
1498 struct Identifier * firstID = (*member->identifiers).first;
1499 struct __ecereNameSpace__ecere__com__DataMember * _subMemberStack[256];
1500 int _subMemberStackPos = 0;
1501 struct __ecereNameSpace__ecere__com__BitMember * thisMember = (struct __ecereNameSpace__ecere__com__BitMember *)__ecereNameSpace__ecere__com__eClass_FindDataMember(_class, firstID->string, privateModule, _subMemberStack, &_subMemberStackPos);
1502
1503 if(!thisMember)
1504 {
1505 thisMember = (struct __ecereNameSpace__ecere__com__BitMember *)__ecereNameSpace__ecere__com__eClass_FindProperty(_class, firstID->string, privateModule);
1506 }
1507 if(thisMember && thisMember->memberAccess == 1)
1508 {
1509 curMember = thisMember;
1510 curClass = curMember->_class;
1511 memcpy(subMemberStack, _subMemberStack, sizeof(struct __ecereNameSpace__ecere__com__DataMember *) * _subMemberStackPos);
1512 subMemberStackPos = _subMemberStackPos;
1513 }
1514 if(thisMember == bitMember)
1515 {
1516 found = 1;
1517 break;
1518 }
1519 }
1520 else
1521 {
1522 __ecereNameSpace__ecere__com__eClass_FindNextMember(classSym->__anon1.registered, &curClass, (struct __ecereNameSpace__ecere__com__DataMember **)&curMember, subMemberStack, &subMemberStackPos);
1523 if(curMember == bitMember)
1524 {
1525 found = 1;
1526 break;
1527 }
1528 }
1529 }
1530 }
1531 if(found)
1532 break;
1533 }
1534 if(member)
1535 {
1536 if(!bitMember->isProperty)
1537 {
1538 struct Expression * part = (((void *)0));
1539 struct __ecereNameSpace__ecere__sys__OldList * specs = MkList();
1540 struct Declarator * decl;
1541
1542 decl = SpecDeclFromString(_class->dataTypeString, specs, (((void *)0)));
1543 ProcessInitializer(member->initializer);
1544 if(member->initializer && member->initializer->type == 0)
1545 {
1546 if(bitMember->pos)
1547 {
1548 char pos[10];
1549
1550 sprintf(pos, "%d", bitMember->pos);
1551 part = MkExpBrackets(MkListOne(MkExpOp(MkExpBrackets(MkListOne(MkExpCast(MkTypeName(specs, decl), MkExpBrackets(MkListOne(member->initializer->__anon1.exp))))), LEFT_OP, MkExpConstant(pos))));
1552 }
1553 else
1554 part = MkExpBrackets(MkListOne(MkExpCast(MkTypeName(specs, decl), MkExpBrackets(MkListOne(member->initializer->__anon1.exp)))));
1555 member->initializer->__anon1.exp = (((void *)0));
1556 FreeInitializer(member->initializer);
1557 member->initializer = (((void *)0));
1558 }
1559 if(exp)
1560 exp = MkExpOp(exp, '|', part);
1561 else
1562 exp = part;
1563 }
1564 else
1565 {
1566 char setName[1024], getName[1024];
1567
1568 DeclareProperty(curExternal, (struct __ecereNameSpace__ecere__com__Property *)bitMember, setName, getName);
1569 if(member->initializer && member->initializer->type == 0)
1570 {
1571 exp = MkExpCall(MkExpIdentifier(MkIdentifier(setName)), MkListOne(member->initializer->__anon1.exp));
1572 member->initializer->__anon1.exp = (((void *)0));
1573 FreeInitializer(member->initializer);
1574 member->initializer = (((void *)0));
1575 }
1576 }
1577 }
1578 }
1579 }
1580 }
1581 if(exp)
1582 exp = MkExpBrackets(MkListOne(exp));
1583 else
1584 exp = MkExpConstant("0");
1585 exp->expType = MkClassType(classSym->string);
1586 ProcessExpression(exp);
1587 ListAdd(list, exp);
1588 }
1589 else if(classSym && classSym->__anon1.registered && classSym->__anon1.registered->type == 3)
1590 {
1591 struct __ecereNameSpace__ecere__com__Class * _class = classSym->__anon1.registered;
1592 struct Expression * exp = (((void *)0));
1593
1594 if(inst->members && (*inst->members).first)
1595 {
1596 struct MemberInit * member = (((void *)0));
1597 struct __ecereNameSpace__ecere__com__Property * prop = (((void *)0));
1598 unsigned int found = 0;
1599
1600 for(members = (*inst->members).first; members; members = members->next)
1601 {
1602 if(members->type == 0)
1603 {
1604 for(member = (*members->__anon1.dataMembers).first; member; member = member->next)
1605 {
1606 if(member->identifiers)
1607 {
1608 struct Identifier * firstID = (*member->identifiers).first;
1609
1610 prop = __ecereNameSpace__ecere__com__eClass_FindProperty(_class, firstID->string, privateModule);
1611 if(prop)
1612 {
1613 found = 1;
1614 break;
1615 }
1616 prop = (((void *)0));
1617 }
1618 else
1619 {
1620 found = 1;
1621 break;
1622 }
1623 }
1624 }
1625 if(found)
1626 break;
1627 }
1628 if(member)
1629 {
1630 if(prop)
1631 {
1632 char setName[1024], getName[1024];
1633
1634 DeclareProperty(curExternal, prop, setName, getName);
1635 if(member->initializer && member->initializer->type == 0)
1636 {
1637 exp = MkExpCall(MkExpIdentifier(MkIdentifier(setName)), MkListOne(member->initializer->__anon1.exp));
1638 member->initializer->__anon1.exp = (((void *)0));
1639 FreeInitializer(member->initializer);
1640 member->initializer = (((void *)0));
1641 }
1642 }
1643 else
1644 {
1645 ProcessInitializer(member->initializer);
1646 if(member->initializer && member->initializer->type == 0)
1647 {
1648 exp = MkExpCast(QMkClass(_class->fullName, (((void *)0))), MkExpBrackets(MkListOne(member->initializer->__anon1.exp)));
1649 member->initializer->__anon1.exp = (((void *)0));
1650 FreeInitializer(member->initializer);
1651 member->initializer = (((void *)0));
1652 }
1653 }
1654 }
1655 }
1656 if(exp)
1657 exp = MkExpBrackets(MkListOne(exp));
1658 else
1659 exp = MkExpConstant("0");
1660 ProcessExpression(exp);
1661 ListAdd(list, exp);
1662 }
1663 else if(classSym && classSym->__anon1.registered)
1664 {
1665 if(classSym->__anon1.registered->type == 1)
1666 {
1667 struct __ecereNameSpace__ecere__com__Class * _class = (((void *)0));
1668
1669 while(_class != classSym->__anon1.registered)
1670 {
1671 struct __ecereNameSpace__ecere__com__DataMember * dataMember;
1672 struct __ecereNameSpace__ecere__com__Class * lastClass = _class;
1673
1674 for(_class = classSym->__anon1.registered; _class->base != lastClass && _class->base->type != 1000; _class = _class->base)
1675 ;
1676 if(_class->structSize != _class->memberOffset)
1677 fullSet = 0;
1678 for(dataMember = _class->membersAndProperties.first; dataMember; dataMember = dataMember->next)
1679 {
1680 if(!dataMember->isProperty)
1681 {
1682 if(!dataMember->name && (dataMember->type == 1 || dataMember->type == 2))
1683 {
1684 if(!ProcessInstMembers_SimpleMemberEnsure(dataMember, inst, instExp, list, zeroOut))
1685 fullSet = 0;
1686 }
1687 else
1688 {
1689 unsigned int memberFilled = 0;
1690
1691 if(inst->members && (*inst->members).first)
1692 {
1693 struct __ecereNameSpace__ecere__com__Class * curClass = (((void *)0));
1694 struct __ecereNameSpace__ecere__com__DataMember * curMember = (((void *)0));
1695 struct __ecereNameSpace__ecere__com__DataMember * subMemberStack[256];
1696 int subMemberStackPos = 0;
1697
1698 for(members = (*inst->members).first; members; members = members->next)
1699 {
1700 if(members->type == 0 && members->__anon1.dataMembers)
1701 {
1702 struct MemberInit * member = (((void *)0));
1703
1704 for(member = (*members->__anon1.dataMembers).first; member; member = member->next)
1705 {
1706 if(member->identifiers)
1707 {
1708 struct __ecereNameSpace__ecere__com__DataMember * _subMemberStack[256];
1709 int _subMemberStackPos = 0;
1710 struct Identifier * firstID = (*member->identifiers).first;
1711 struct __ecereNameSpace__ecere__com__DataMember * thisMember = (struct __ecereNameSpace__ecere__com__DataMember *)__ecereNameSpace__ecere__com__eClass_FindProperty(classSym->__anon1.registered, firstID->string, privateModule);
1712
1713 if(!thisMember)
1714 thisMember = __ecereNameSpace__ecere__com__eClass_FindDataMember(classSym->__anon1.registered, firstID->string, privateModule, _subMemberStack, &_subMemberStackPos);
1715 if(thisMember)
1716 {
1717 if(thisMember->memberAccess == 1)
1718 {
1719 curMember = thisMember;
1720 curClass = curMember->_class;
1721 memcpy(subMemberStack, _subMemberStack, sizeof(struct __ecereNameSpace__ecere__com__DataMember *) * _subMemberStackPos);
1722 subMemberStackPos = _subMemberStackPos;
1723 }
1724 if(!firstID->next && curMember == dataMember)
1725 {
1726 memberFilled = 1;
1727 break;
1728 }
1729 }
1730 }
1731 else
1732 {
1733 __ecereNameSpace__ecere__com__eClass_FindNextMember(classSym->__anon1.registered, &curClass, &curMember, subMemberStack, &subMemberStackPos);
1734 if(curMember == dataMember)
1735 {
1736 memberFilled = 1;
1737 break;
1738 }
1739 }
1740 }
1741 if(memberFilled)
1742 break;
1743 }
1744 if(memberFilled)
1745 break;
1746 }
1747 }
1748 if(!memberFilled)
1749 {
1750 if(zeroOut)
1751 {
1752 struct Expression * instExpCopy = CopyExpression(instExp);
1753 struct Expression * memberExp;
1754 struct Expression * setExp;
1755 struct Expression * value = MkExpConstant("0");
1756
1757 memberExp = MkExpMember(instExpCopy, MkIdentifier(dataMember->name));
1758 memberExp->__anon1.member.memberType = 3;
1759 value->usage = (value->usage & ~0x1) | (((unsigned int)(1)) << 0);
1760 setExp = MkExpOp(memberExp, '=', value);
1761 value->loc = inst->loc;
1762 setExp->loc = inst->loc;
1763 FreeType(instExpCopy->expType);
1764 instExpCopy->expType = instExp->expType;
1765 if(instExp->expType)
1766 instExp->expType->refCount++;
1767 ProcessExpressionType(setExp);
1768 ProcessExpression(setExp);
1769 ListAdd(list, setExp);
1770 }
1771 fullSet = 0;
1772 }
1773 }
1774 }
1775 }
1776 }
1777 }
1778 if(inst->members && (*inst->members).first)
1779 {
1780 struct __ecereNameSpace__ecere__com__Class * curClass = (((void *)0));
1781 struct __ecereNameSpace__ecere__com__DataMember * curMember = (((void *)0));
1782 struct __ecereNameSpace__ecere__com__DataMember * subMemberStack[256];
1783 int subMemberStackPos = 0;
1784
1785 for(members = (*inst->members).first; members; members = members->next)
1786 {
1787 if(members->type == 0 && members->__anon1.dataMembers)
1788 {
1789 struct MemberInit * member = (((void *)0));
1790 struct __ecereNameSpace__ecere__com__Method * method = (((void *)0));
1791
1792 for(member = (*members->__anon1.dataMembers).first; member; member = member->next)
1793 {
1794 struct Identifier * ident = (((void *)0));
1795 struct __ecereNameSpace__ecere__com__DataMember * thisMember = (((void *)0));
1796
1797 if(member->identifiers)
1798 {
1799 struct __ecereNameSpace__ecere__com__DataMember * _subMemberStack[256];
1800 int _subMemberStackPos = 0;
1801 struct Identifier * firstID = (*member->identifiers).first;
1802
1803 thisMember = (struct __ecereNameSpace__ecere__com__DataMember *)__ecereNameSpace__ecere__com__eClass_FindProperty(classSym->__anon1.registered, firstID->string, privateModule);
1804 if(!thisMember)
1805 thisMember = __ecereNameSpace__ecere__com__eClass_FindDataMember(classSym->__anon1.registered, firstID->string, privateModule, _subMemberStack, &_subMemberStackPos);
1806 ident = firstID;
1807 if(thisMember)
1808 {
1809 if(thisMember->memberAccess == 1)
1810 {
1811 curMember = thisMember;
1812 curClass = curMember->_class;
1813 memcpy(subMemberStack, _subMemberStack, sizeof(struct __ecereNameSpace__ecere__com__DataMember *) * _subMemberStackPos);
1814 subMemberStackPos = _subMemberStackPos;
1815 }
1816 }
1817 else if(classSym->__anon1.registered->type != 1)
1818 {
1819 method = __ecereNameSpace__ecere__com__eClass_FindMethod(classSym->__anon1.registered, ident->string, privateModule);
1820 if(!method || method->type != 1)
1821 method = (((void *)0));
1822 }
1823 }
1824 else
1825 {
1826 __ecereNameSpace__ecere__com__eClass_FindNextMember(classSym->__anon1.registered, &curClass, &curMember, subMemberStack, &subMemberStackPos);
1827 thisMember = curMember;
1828 }
1829 if(instExp && (thisMember || method))
1830 {
1831 struct Expression * instExpCopy = CopyExpression(instExp);
1832 struct Expression * setExp = (((void *)0));
1833
1834 instExpCopy->tempCount = instExp->tempCount;
1835 if(!ident)
1836 ident = MkIdentifier(thisMember->name);
1837 if(ident)
1838 {
1839 struct Expression * memberExp;
1840 unsigned int freeMemberExp = 0;
1841
1842 if(thisMember && thisMember->isProperty && ((struct __ecereNameSpace__ecere__com__Property *)thisMember)->conversion)
1843 convert = 1;
1844 if(member->identifiers && (*member->identifiers).count > 1)
1845 {
1846 struct Identifier * id = (*member->identifiers).first;
1847
1848 memberExp = MkExpMember(instExpCopy, id);
1849 for(id = id->next; id; id = id->next)
1850 memberExp = MkExpMember(memberExp, id);
1851 }
1852 else
1853 memberExp = MkExpMember(instExpCopy, ident);
1854 if(member->initializer && member->initializer->type == 0 && member->initializer->__anon1.exp)
1855 {
1856 member->initializer->__anon1.exp->usage = (member->initializer->__anon1.exp->usage & ~0x1) | (((unsigned int)(1)) << 0);
1857 setExp = MkExpOp(memberExp, '=', member->initializer->__anon1.exp);
1858 member->initializer->__anon1.exp = (((void *)0));
1859 FreeInitializer(member->initializer);
1860 member->initializer = (((void *)0));
1861 }
1862 else
1863 {
1864 freeMemberExp = 1;
1865 }
1866 memberExp->loc = inst->loc;
1867 if(member->identifiers)
1868 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Clear((&*member->identifiers));
1869 if(setExp)
1870 setExp->loc = inst->loc;
1871 FreeType(instExpCopy->expType);
1872 instExpCopy->expType = instExp->expType;
1873 if(instExp->expType)
1874 instExp->expType->refCount++;
1875 if(setExp)
1876 {
1877 ProcessExpressionType(setExp);
1878 ProcessExpression(setExp);
1879 ListAdd(list, setExp);
1880 }
1881 if(freeMemberExp)
1882 FreeExpression(memberExp);
1883 }
1884 }
1885 }
1886 }
1887 }
1888 }
1889 }
1890 return fullSet || convert;
1891 }
1892
1893 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_Context;
1894
1895 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_ClassImport;
1896
1897 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_Type;
1898
1899 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_Initializer;
1900
1901 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_Symbol;
1902
1903 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_Expression;
1904
1905 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_Declaration;
1906
1907 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__LinkList;
1908
1909 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_TopoEdge;
1910
1911 struct __ecereNameSpace__ecere__com__Module
1912 {
1913 struct __ecereNameSpace__ecere__com__Instance * application;
1914 struct __ecereNameSpace__ecere__sys__OldList classes;
1915 struct __ecereNameSpace__ecere__sys__OldList defines;
1916 struct __ecereNameSpace__ecere__sys__OldList functions;
1917 struct __ecereNameSpace__ecere__sys__OldList modules;
1918 struct __ecereNameSpace__ecere__com__Instance * prev;
1919 struct __ecereNameSpace__ecere__com__Instance * next;
1920 const char *  name;
1921 void *  library;
1922 void *  Unload;
1923 int importType;
1924 int origImportType;
1925 struct __ecereNameSpace__ecere__com__NameSpace privateNameSpace;
1926 struct __ecereNameSpace__ecere__com__NameSpace publicNameSpace;
1927 } __attribute__ ((gcc_struct));
1928
1929 static void CreateInstancesBody()
1930 {
1931 if(inCompiler && !createInstancesBody)
1932 {
1933 char registerName[1024], moduleName[274];
1934 struct __ecereNameSpace__ecere__sys__OldList * specifiers;
1935 struct Declarator * declarator;
1936
1937 createInstancesBody = MkCompoundStmt((((void *)0)), MkList());
1938 createInstancesBody->__anon1.compound.context = __extension__ ({
1939 struct Context * __ecereInstance1 = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Context);
1940
1941 __ecereInstance1->parent = globalContext, __ecereInstance1;
1942 });
1943 specifiers = MkList();
1944 ListAdd(specifiers, MkSpecifier(VOID));
1945 __ecereNameSpace__ecere__sys__GetLastDirectory(outputFile, moduleName);
1946 __ecereNameSpace__ecere__sys__StripExtension(moduleName);
1947 FixModuleName(moduleName);
1948 sprintf(registerName, "__ecereCreateModuleInstances_%s", moduleName);
1949 declarator = MkDeclaratorFunction(MkDeclaratorIdentifier(MkIdentifier(registerName)), (((void *)0)));
1950 {
1951 struct FunctionDefinition * function = _MkFunction(specifiers, declarator, (((void *)0)), 0);
1952
1953 ProcessFunctionBody(function, createInstancesBody);
1954 ListAdd(ast, createInstancesExternal = MkExternalFunction(function));
1955 }
1956 destroyInstancesBody = MkCompoundStmt((((void *)0)), MkList());
1957 destroyInstancesBody->__anon1.compound.context = __extension__ ({
1958 struct Context * __ecereInstance1 = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Context);
1959
1960 __ecereInstance1->parent = globalContext, __ecereInstance1;
1961 });
1962 specifiers = MkList();
1963 ListAdd(specifiers, MkSpecifier(VOID));
1964 sprintf(registerName, "__ecereDestroyModuleInstances_%s", moduleName);
1965 declarator = MkDeclaratorFunction(MkDeclaratorIdentifier(MkIdentifier(registerName)), (((void *)0)));
1966 {
1967 struct FunctionDefinition * function = _MkFunction(specifiers, declarator, (((void *)0)), 0);
1968
1969 ProcessFunctionBody(function, destroyInstancesBody);
1970 ListAdd(ast, destroyInstancesExternal = MkExternalFunction(function));
1971 }
1972 }
1973 }
1974
1975 void DeclareClass(struct External * neededFor, struct Symbol * classSym, const char * className)
1976 {
1977 if(classSym && classSym->notYetDeclared)
1978 {
1979 if(!classSym->mustRegister)
1980 {
1981 if(!classSym->_import)
1982 {
1983 if(!classSym->module)
1984 classSym->module = mainModule;
1985 if(!classSym->module)
1986 return ;
1987 classSym->_import = __extension__ ({
1988 struct ClassImport * __ecereInstance1 = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_ClassImport);
1989
1990 __ecereInstance1->isRemote = classSym->__anon1.registered ? classSym->__anon1.registered->isRemote : 0, __ecereInstance1->name = __ecereNameSpace__ecere__sys__CopyString(classSym->string), __ecereInstance1;
1991 });
1992 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add(&classSym->module->classes, classSym->_import);
1993 }
1994 classSym->_import->itself = 1;
1995 }
1996 classSym->notYetDeclared = 0;
1997 if(!classSym->__anon2.__anon1.pointerExternal && inCompiler)
1998 {
1999 struct Declaration * decl;
2000 struct __ecereNameSpace__ecere__sys__OldList * specifiers, * declarators;
2001 struct Declarator * d;
2002
2003 specifiers = MkList();
2004 declarators = MkList();
2005 ListAdd(specifiers, MkSpecifier(EXTERN));
2006 ListAdd(specifiers, MkStructOrUnion(3, MkIdentifier("__ecereNameSpace__ecere__com__Class"), (((void *)0))));
2007 d = MkDeclaratorPointer(MkPointer((((void *)0)), (((void *)0))), MkDeclaratorIdentifier(MkIdentifier(className)));
2008 ListAdd(declarators, MkInitDeclarator(d, (((void *)0))));
2009 decl = MkDeclaration(specifiers, declarators);
2010 classSym->__anon2.__anon1.pointerExternal = MkExternalDeclaration(decl);
2011 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add((&*ast), classSym->__anon2.__anon1.pointerExternal);
2012 DeclareStruct(classSym->__anon2.__anon1.pointerExternal, "ecere::com::Class", 0, 1);
2013 }
2014 }
2015 if(inCompiler && classSym && classSym->__anon2.__anon1.pointerExternal && neededFor)
2016 __ecereMethod_External_CreateUniqueEdge(neededFor, classSym->__anon2.__anon1.pointerExternal, 0);
2017 }
2018
2019 void __ecereUnregisterModule_pass16(struct __ecereNameSpace__ecere__com__Instance * module)
2020 {
2021
2022 }
2023
2024 static void ProcessStatement(struct Statement *  stmt);
2025
2026 static void ProcessFunction(struct FunctionDefinition * function)
2027 {
2028 if(function->body)
2029 {
2030 yylloc = function->loc;
2031 ProcessStatement(function->body);
2032 }
2033 }
2034
2035 static void ProcessInstantiation(struct Instantiation * inst)
2036 {
2037 if(inst->members && (*inst->members).first)
2038 {
2039 struct MembersInit * members;
2040
2041 for(members = (*inst->members).first; members; members = members->next)
2042 {
2043 if(members->type == 0)
2044 {
2045 if(members->__anon1.dataMembers)
2046 {
2047 struct MemberInit * member;
2048
2049 for(member = (*members->__anon1.dataMembers).first; member; member = member->next)
2050 ProcessMemberInitData(member);
2051 }
2052 }
2053 else if(members->type == 1)
2054 {
2055 ProcessFunction((struct FunctionDefinition *)members->__anon1.function);
2056 }
2057 }
2058 }
2059 }
2060
2061 static void ProcessDeclaration(struct Declaration *  decl);
2062
2063 static void ProcessStatement(struct Statement * stmt)
2064 {
2065 yylloc = stmt->loc;
2066 switch(stmt->type)
2067 {
2068 case 0:
2069 if(stmt->__anon1.labeled.stmt)
2070 ProcessStatement(stmt->__anon1.labeled.stmt);
2071 break;
2072 case 1:
2073 if(stmt->__anon1.caseStmt.exp)
2074 ProcessExpression(stmt->__anon1.caseStmt.exp);
2075 if(stmt->__anon1.caseStmt.stmt)
2076 ProcessStatement(stmt->__anon1.caseStmt.stmt);
2077 break;
2078 case 2:
2079 {
2080 if(stmt->__anon1.compound.context)
2081 {
2082 struct Declaration * decl;
2083 struct Statement * s;
2084 struct Statement * prevCompound = curCompound;
2085 struct Context * prevContext = curContext;
2086
2087 if(!stmt->__anon1.compound.isSwitch)
2088 {
2089 curCompound = stmt;
2090 curContext = stmt->__anon1.compound.context;
2091 }
2092 if(stmt->__anon1.compound.declarations)
2093 {
2094 for(decl = (*stmt->__anon1.compound.declarations).first; decl; decl = decl->next)
2095 ProcessDeclaration(decl);
2096 }
2097 if(stmt->__anon1.compound.statements)
2098 {
2099 for(s = (*stmt->__anon1.compound.statements).first; s; s = s->next)
2100 {
2101 ProcessStatement(s);
2102 }
2103 }
2104 curCompound = prevCompound;
2105 curContext = prevContext;
2106 }
2107 break;
2108 }
2109 case 3:
2110 {
2111 struct Expression * exp;
2112
2113 if(stmt->__anon1.expressions)
2114 {
2115 for(exp = (*stmt->__anon1.expressions).first; exp; exp = exp->next)
2116 {
2117 ProcessExpression(exp);
2118 }
2119 }
2120 break;
2121 }
2122 case 4:
2123 {
2124 struct Expression * exp;
2125
2126 ((struct Expression *)(*stmt->__anon1.ifStmt.exp).last)->usage = (((struct Expression *)(*stmt->__anon1.ifStmt.exp).last)->usage & ~0x1) | (((unsigned int)(1)) << 0);
2127 for(exp = (*stmt->__anon1.ifStmt.exp).first; exp; exp = exp->next)
2128 {
2129 ProcessExpression(exp);
2130 }
2131 if(stmt->__anon1.ifStmt.stmt)
2132 ProcessStatement(stmt->__anon1.ifStmt.stmt);
2133 if(stmt->__anon1.ifStmt.elseStmt)
2134 ProcessStatement(stmt->__anon1.ifStmt.elseStmt);
2135 break;
2136 }
2137 case 5:
2138 {
2139 struct Expression * exp;
2140
2141 ((struct Expression *)(*stmt->__anon1.switchStmt.exp).last)->usage = (((struct Expression *)(*stmt->__anon1.switchStmt.exp).last)->usage & ~0x1) | (((unsigned int)(1)) << 0);
2142 for(exp = (*stmt->__anon1.switchStmt.exp).first; exp; exp = exp->next)
2143 ProcessExpression(exp);
2144 ProcessStatement(stmt->__anon1.switchStmt.stmt);
2145 break;
2146 }
2147 case 6:
2148 {
2149 if(stmt->__anon1.whileStmt.exp)
2150 {
2151 struct Expression * exp;
2152
2153 ((struct Expression *)(*stmt->__anon1.whileStmt.exp).last)->usage = (((struct Expression *)(*stmt->__anon1.whileStmt.exp).last)->usage & ~0x1) | (((unsigned int)(1)) << 0);
2154 for(exp = (*stmt->__anon1.whileStmt.exp).first; exp; exp = exp->next)
2155 {
2156 ProcessExpression(exp);
2157 }
2158 }
2159 if(stmt->__anon1.whileStmt.stmt)
2160 ProcessStatement(stmt->__anon1.whileStmt.stmt);
2161 break;
2162 }
2163 case 7:
2164 {
2165 if(stmt->__anon1.doWhile.exp)
2166 {
2167 struct Expression * exp;
2168
2169 ((struct Expression *)(*stmt->__anon1.doWhile.exp).last)->usage = (((struct Expression *)(*stmt->__anon1.doWhile.exp).last)->usage & ~0x1) | (((unsigned int)(1)) << 0);
2170 for(exp = (*stmt->__anon1.doWhile.exp).first; exp; exp = exp->next)
2171 {
2172 ProcessExpression(exp);
2173 }
2174 }
2175 if(stmt->__anon1.doWhile.stmt)
2176 ProcessStatement(stmt->__anon1.doWhile.stmt);
2177 break;
2178 }
2179 case 8:
2180 {
2181 struct Expression * exp;
2182
2183 if(stmt->__anon1.forStmt.init)
2184 ProcessStatement(stmt->__anon1.forStmt.init);
2185 if(stmt->__anon1.forStmt.check && stmt->__anon1.forStmt.check->__anon1.expressions)
2186 {
2187 ((struct Expression *)(*stmt->__anon1.forStmt.check->__anon1.expressions).last)->usage = (((struct Expression *)(*stmt->__anon1.forStmt.check->__anon1.expressions).last)->usage & ~0x1) | (((unsigned int)(1)) << 0);
2188 }
2189 if(stmt->__anon1.forStmt.check)
2190 ProcessStatement(stmt->__anon1.forStmt.check);
2191 if(stmt->__anon1.forStmt.increment)
2192 {
2193 for(exp = (*stmt->__anon1.forStmt.increment).first; exp; exp = exp->next)
2194 ProcessExpression(exp);
2195 }
2196 if(stmt->__anon1.forStmt.stmt)
2197 ProcessStatement(stmt->__anon1.forStmt.stmt);
2198 break;
2199 }
2200 case 9:
2201 break;
2202 case 10:
2203 break;
2204 case 11:
2205 break;
2206 case 12:
2207 {
2208 struct Expression * exp;
2209
2210 if(stmt->__anon1.expressions && (*stmt->__anon1.expressions).last)
2211 {
2212 ((struct Expression *)(*stmt->__anon1.expressions).last)->usage = (((struct Expression *)(*stmt->__anon1.expressions).last)->usage & ~0x1) | (((unsigned int)(1)) << 0);
2213 for(exp = (*stmt->__anon1.expressions).first; exp; exp = exp->next)
2214 {
2215 ProcessExpression(exp);
2216 }
2217 }
2218 break;
2219 }
2220 case 14:
2221 {
2222 ProcessDeclaration(stmt->__anon1.decl);
2223 break;
2224 }
2225 case 13:
2226 {
2227 struct AsmField * field;
2228
2229 if(stmt->__anon1.asmStmt.inputFields)
2230 {
2231 for(field = (*stmt->__anon1.asmStmt.inputFields).first; field; field = field->next)
2232 if(field->expression)
2233 ProcessExpression(field->expression);
2234 }
2235 if(stmt->__anon1.asmStmt.outputFields)
2236 {
2237 for(field = (*stmt->__anon1.asmStmt.outputFields).first; field; field = field->next)
2238 if(field->expression)
2239 ProcessExpression(field->expression);
2240 }
2241 if(stmt->__anon1.asmStmt.clobberedFields)
2242 {
2243 for(field = (*stmt->__anon1.asmStmt.clobberedFields).first; field; field = field->next)
2244 if(field->expression)
2245 ProcessExpression(field->expression);
2246 }
2247 break;
2248 }
2249 }
2250 }
2251
2252 struct ClassDef;
2253
2254 typedef union YYSTYPE
2255 {
2256 int specifierType;
2257 int i;
2258 int declMode;
2259 struct Identifier * id;
2260 struct Expression * exp;
2261 struct Specifier * specifier;
2262 struct __ecereNameSpace__ecere__sys__OldList * list;
2263 struct Enumerator * enumerator;
2264 struct Declarator * declarator;
2265 struct Pointer * pointer;
2266 struct Initializer * initializer;
2267 struct InitDeclarator * initDeclarator;
2268 struct TypeName * typeName;
2269 struct Declaration * declaration;
2270 struct Statement * stmt;
2271 struct FunctionDefinition * function;
2272 struct External * external;
2273 struct Context * context;
2274 struct AsmField * asmField;
2275 struct Attrib * attrib;
2276 struct ExtDecl * extDecl;
2277 struct Attribute * attribute;
2278 struct Instantiation * instance;
2279 struct MembersInit * membersInit;
2280 struct MemberInit * memberInit;
2281 struct ClassFunction * classFunction;
2282 struct ClassDefinition * _class;
2283 struct ClassDef * classDef;
2284 struct PropertyDef * prop;
2285 char * string;
2286 struct Symbol * symbol;
2287 struct PropertyWatch * propertyWatch;
2288 struct TemplateParameter * templateParameter;
2289 struct TemplateArgument * templateArgument;
2290 struct TemplateDatatype * templateDatatype;
2291 struct DBTableEntry * dbtableEntry;
2292 struct DBIndexItem * dbindexItem;
2293 struct DBTableDef * dbtableDef;
2294 } __attribute__ ((gcc_struct)) YYSTYPE;
2295
2296 extern YYSTYPE yylval;
2297
2298 struct ClassDef
2299 {
2300 struct ClassDef * prev;
2301 struct ClassDef * next;
2302 struct Location loc;
2303 int type;
2304 union
2305 {
2306 struct Declaration * decl;
2307 struct ClassFunction * function;
2308 struct __ecereNameSpace__ecere__sys__OldList *  defProperties;
2309 struct PropertyDef * propertyDef;
2310 struct PropertyWatch * propertyWatch;
2311 char *  designer;
2312 struct Identifier * defaultProperty;
2313 struct
2314 {
2315 struct Identifier * id;
2316 struct Initializer * initializer;
2317 } __attribute__ ((gcc_struct)) __anon1;
2318 } __attribute__ ((gcc_struct)) __anon1;
2319 int memberAccess;
2320 void *  object;
2321 } __attribute__ ((gcc_struct));
2322
2323 static void ProcessSpecifier(struct Specifier * spec)
2324 {
2325 switch(spec->type)
2326 {
2327 case 0:
2328 break;
2329 case 1:
2330 {
2331 break;
2332 }
2333 case 2:
2334 {
2335 struct Enumerator * e;
2336
2337 if(spec->__anon1.__anon2.list)
2338 {
2339 for(e = (*spec->__anon1.__anon2.list).first; e; e = e->next)
2340 {
2341 if(e->exp)
2342 ProcessExpression(e->exp);
2343 }
2344 }
2345 break;
2346 }
2347 case 3:
2348 case 4:
2349 {
2350 if(spec->__anon1.__anon2.definitions)
2351 {
2352 struct ClassDef * def;
2353
2354 for(def = (*spec->__anon1.__anon2.definitions).first; def; def = def->next)
2355 {
2356 if(def->type == 2 && def->__anon1.decl && def->__anon1.decl->type == 0)
2357 ProcessDeclaration(def->__anon1.decl);
2358 }
2359 }
2360 break;
2361 }
2362 }
2363 }
2364
2365 void ProcessInstantiations()
2366 {
2367 struct External * external;
2368
2369 for(external = (*ast).first; external; external = external->next)
2370 {
2371 curExternal = external;
2372 if(external->type == 1)
2373 {
2374 if(external->__anon1.declaration)
2375 {
2376 unsigned int isInstance = external->__anon1.declaration->type == 2;
2377 struct Symbol * sym = isInstance ? FindClass(external->__anon1.declaration->__anon1.inst->_class->__anon1.__anon1.name) : (((void *)0));
2378
2379 ProcessDeclaration(external->__anon1.declaration);
2380 if(isInstance)
2381 {
2382 struct TopoEdge * e, * next;
2383
2384 for(e = ((struct __ecereNameSpace__ecere__com__LinkList *)(((char *)external->incoming + 0 + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->first; e; e = next)
2385 {
2386 struct External * from = e->from;
2387
2388 next = e->in.next;
2389 if(((struct __ecereNameSpace__ecere__com__LinkList *)(((char *)from->incoming + 0 + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->count)
2390 {
2391 unsigned int reroute = 1;
2392
2393 if(sym && sym->__anon1.registered && sym->__anon1.registered->type == 1)
2394 reroute = 0;
2395 else if(from->type == 1 && from->__anon1.declaration && (!from->__anon1.declaration->__anon1.__anon1.declarators || !(*from->__anon1.declaration->__anon1.__anon1.declarators).count) && from->__anon1.declaration->__anon1.__anon1.specifiers)
2396 {
2397 struct Specifier * spec = (((void *)0));
2398
2399 for(spec = (*from->__anon1.declaration->__anon1.__anon1.specifiers).first; spec; spec = spec->next)
2400 {
2401 if(spec->type == 3 || spec->type == 4)
2402 break;
2403 }
2404 if(sym->__anon1.registered && spec && spec->__anon1.__anon2.id && spec->__anon1.__anon2.id->string)
2405 {
2406 char className[1024];
2407 struct __ecereNameSpace__ecere__com__Class * c = sym->__anon1.registered;
2408
2409 strcpy(className, "__ecereClass_");
2410 if(c->type == 5 && c->templateClass)
2411 FullClassNameCat(className, c->templateClass->name, 1);
2412 else
2413 FullClassNameCat(className, c->name, 1);
2414 if(!strcmp(c->name, spec->__anon1.__anon2.id->string))
2415 reroute = 0;
2416 }
2417 }
2418 if(reroute)
2419 {
2420 unsigned int skip = 0;
2421
2422 e->to = createInstancesExternal;
2423 ((void (*)(struct __ecereNameSpace__ecere__com__Instance *, struct __ecereNameSpace__ecere__com__IteratorPointer * it))__extension__ ({
2424 struct __ecereNameSpace__ecere__com__Instance * __internal_ClassInst = external->incoming;
2425
2426 __internal_ClassInst ? __internal_ClassInst->_vTbl : __ecereClass___ecereNameSpace__ecere__com__LinkList->_vTbl;
2427 })[__ecereVMethodID___ecereNameSpace__ecere__com__Container_Remove])(external->incoming, (struct __ecereNameSpace__ecere__com__IteratorPointer *)e);
2428 {
2429 struct TopoEdge * i;
2430 struct __ecereNameSpace__ecere__com__Instance * __internalLinkList = createInstancesExternal->incoming;
2431
2432 for(i = ((struct __ecereNameSpace__ecere__com__LinkList *)(((char *)__internalLinkList + 0 + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->first; i; i = (struct TopoEdge *)((struct __ecereNameSpace__ecere__com__IteratorPointer * (*)(struct __ecereNameSpace__ecere__com__Instance *, struct __ecereNameSpace__ecere__com__IteratorPointer * pointer))__extension__ ({
2433 struct __ecereNameSpace__ecere__com__Instance * __internal_ClassInst = __internalLinkList;
2434
2435 __internal_ClassInst ? __internal_ClassInst->_vTbl : __ecereClass___ecereNameSpace__ecere__com__LinkList->_vTbl;
2436 })[__ecereVMethodID___ecereNameSpace__ecere__com__Container_GetNext])(__internalLinkList, (struct __ecereNameSpace__ecere__com__IteratorPointer *)i))
2437 {
2438 if(i->from == from)
2439 {
2440 skip = 1;
2441 if(i->breakable && !e->breakable)
2442 {
2443 i->breakable = 1;
2444 createInstancesExternal->nonBreakableIncoming++;
2445 }
2446 break;
2447 }
2448 }
2449 }
2450 if(skip)
2451 {
2452 external->nonBreakableIncoming--;
2453 ((void (*)(struct __ecereNameSpace__ecere__com__Instance *, struct __ecereNameSpace__ecere__com__IteratorPointer * it))__extension__ ({
2454 struct __ecereNameSpace__ecere__com__Instance * __internal_ClassInst = e->from->outgoing;
2455
2456 __internal_ClassInst ? __internal_ClassInst->_vTbl : __ecereClass___ecereNameSpace__ecere__com__LinkList->_vTbl;
2457 })[__ecereVMethodID___ecereNameSpace__ecere__com__Container_Remove])(e->from->outgoing, (struct __ecereNameSpace__ecere__com__IteratorPointer *)e);
2458 ((e ? (__ecereClass_TopoEdge->Destructor ? __ecereClass_TopoEdge->Destructor((void *)e) : 0, __ecereNameSpace__ecere__com__eSystem_Delete(e)) : 0), e = 0);
2459 }
2460 else
2461 {
2462 ((struct __ecereNameSpace__ecere__com__IteratorPointer * (*)(struct __ecereNameSpace__ecere__com__Instance *, uint64 value))__extension__ ({
2463 struct __ecereNameSpace__ecere__com__Instance * __internal_ClassInst = createInstancesExternal->incoming;
2464
2465 __internal_ClassInst ? __internal_ClassInst->_vTbl : __ecereClass___ecereNameSpace__ecere__com__LinkList->_vTbl;
2466 })[__ecereVMethodID___ecereNameSpace__ecere__com__Container_Add])(createInstancesExternal->incoming, (uint64)(uintptr_t)(e));
2467 if(!e->breakable)
2468 {
2469 external->nonBreakableIncoming--;
2470 createInstancesExternal->nonBreakableIncoming++;
2471 }
2472 }
2473 }
2474 }
2475 }
2476 }
2477 }
2478 }
2479 else if(external->type == 0)
2480 {
2481 ProcessFunction(external->__anon1.function);
2482 }
2483 else if(external->type == 2)
2484 {
2485 struct ClassDefinition * _class = external->__anon1._class;
2486
2487 if(_class->definitions)
2488 {
2489 struct ClassDef * def;
2490
2491 for(def = (*_class->definitions).first; def; def = def->next)
2492 {
2493 if(def->type == 0)
2494 {
2495 curExternal = def->__anon1.function->declarator ? def->__anon1.function->declarator->symbol->__anon2.__anon1.pointerExternal : external;
2496 ProcessFunction((struct FunctionDefinition *)def->__anon1.function);
2497 }
2498 else if(def->type == 2 && def->__anon1.decl->type == 2)
2499 {
2500 ProcessInstantiation(def->__anon1.decl->__anon1.inst);
2501 }
2502 else if(def->type == 1 && def->__anon1.defProperties)
2503 {
2504 struct MemberInit * defProperty;
2505 struct Symbol * thisSymbol = (thisSymbol = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Symbol), thisSymbol->string = __ecereNameSpace__ecere__sys__CopyString("this"), thisSymbol->type = MkClassTypeSymbol(_class->symbol), thisSymbol);
2506
2507 __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Add(&globalContext->symbols, (struct __ecereNameSpace__ecere__sys__BTNode *)thisSymbol);
2508 for(defProperty = (*def->__anon1.defProperties).first; defProperty; defProperty = defProperty->next)
2509 {
2510 ProcessMemberInitData(defProperty);
2511 }
2512 __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Remove(&globalContext->symbols, (struct __ecereNameSpace__ecere__sys__BTNode *)thisSymbol);
2513 FreeSymbol(thisSymbol);
2514 }
2515 else if(def->type == 3 && def->__anon1.propertyDef)
2516 {
2517 struct PropertyDef * prop = def->__anon1.propertyDef;
2518 struct Symbol * thisSymbol = (thisSymbol = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Symbol), thisSymbol->string = __ecereNameSpace__ecere__sys__CopyString("this"), thisSymbol->type = MkClassTypeSymbol(_class->symbol), thisSymbol);
2519
2520 __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Add(&globalContext->symbols, (struct __ecereNameSpace__ecere__sys__BTNode *)thisSymbol);
2521 if(prop->setStmt)
2522 {
2523 curExternal = prop->symbol ? prop->symbol->__anon2.__anon2.externalSet : (((void *)0));
2524 ProcessStatement(prop->setStmt);
2525 }
2526 if(prop->getStmt)
2527 {
2528 curExternal = prop->symbol ? prop->symbol->__anon2.__anon2.externalGet : (((void *)0));
2529 ProcessStatement(prop->getStmt);
2530 }
2531 if(prop->issetStmt)
2532 {
2533 curExternal = prop->symbol ? prop->symbol->__anon2.__anon2.externalIsSet : (((void *)0));
2534 ProcessStatement(prop->issetStmt);
2535 }
2536 __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Remove(&globalContext->symbols, (struct __ecereNameSpace__ecere__sys__BTNode *)thisSymbol);
2537 FreeSymbol(thisSymbol);
2538 }
2539 else if(def->type == 4 && def->__anon1.propertyWatch)
2540 {
2541 struct PropertyWatch * propertyWatch = def->__anon1.propertyWatch;
2542 struct Symbol * thisSymbol = (thisSymbol = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Symbol), thisSymbol->string = __ecereNameSpace__ecere__sys__CopyString("this"), thisSymbol->type = MkClassTypeSymbol(_class->symbol), thisSymbol);
2543
2544 __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Add(&globalContext->symbols, (struct __ecereNameSpace__ecere__sys__BTNode *)thisSymbol);
2545 if(propertyWatch->compound)
2546 {
2547 __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Add(&propertyWatch->compound->__anon1.compound.context->symbols, (struct __ecereNameSpace__ecere__sys__BTNode *)thisSymbol);
2548 curExternal = (((void *)0));
2549 ProcessStatement(propertyWatch->compound);
2550 }
2551 __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Remove(&globalContext->symbols, (struct __ecereNameSpace__ecere__sys__BTNode *)thisSymbol);
2552 FreeSymbol(thisSymbol);
2553 }
2554 }
2555 }
2556 }
2557 }
2558 }
2559
2560 void __ecereRegisterModule_pass16(struct __ecereNameSpace__ecere__com__Instance * module)
2561 {
2562 struct __ecereNameSpace__ecere__com__Class __attribute__((unused)) * class;
2563
2564 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("DeclareClass", "void DeclareClass(External neededFor, Symbol classSym, const char * className)", DeclareClass, module, 1);
2565 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ProcessExpressionInstPass", "void ProcessExpressionInstPass(Expression exp)", ProcessExpressionInstPass, module, 2);
2566 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ProcessInstantiations", "void ProcessInstantiations(void)", ProcessInstantiations, module, 1);
2567 }
2568
2569 static unsigned int ProcessBracketInst_DataMember(struct __ecereNameSpace__ecere__com__DataMember *  parentMember, struct Instantiation *  inst, struct __ecereNameSpace__ecere__sys__OldList *  list, struct __ecereNameSpace__ecere__com__DataMember *  namedParentMember, unsigned int parentMemberSet);
2570
2571 static unsigned int ProcessBracketInst(struct Instantiation * inst, struct __ecereNameSpace__ecere__sys__OldList * list)
2572 {
2573 static int recursionCount = 0;
2574 struct Symbol * classSym = inst->_class->__anon1.__anon1.symbol;
2575 struct __ecereNameSpace__ecere__com__Class * _class = (((void *)0));
2576 int anonID = 1;
2577
2578 if(recursionCount > 500)
2579 return 0;
2580 recursionCount++;
2581 while(_class != classSym->__anon1.registered)
2582 {
2583 struct __ecereNameSpace__ecere__com__DataMember * dataMember;
2584 struct __ecereNameSpace__ecere__com__Class * lastClass = _class;
2585
2586 for(_class = classSym->__anon1.registered; _class->base != lastClass && _class->base->type != 1000; _class = _class->base)
2587 ;
2588 for(dataMember = _class->membersAndProperties.first; dataMember; dataMember = dataMember->next)
2589 {
2590 if(!dataMember->isProperty && !dataMember->name && (dataMember->type == 1 || dataMember->type == 2))
2591 {
2592 struct __ecereNameSpace__ecere__sys__OldList * subList = MkList();
2593
2594 if(!ProcessBracketInst_DataMember(dataMember, inst, subList ? subList : list, dataMember, 0))
2595 {
2596 if(subList)
2597 FreeList(subList, (void *)(FreeInitializer));
2598 recursionCount--;
2599 return 0;
2600 }
2601 if(dataMember->type == 2 || (subList && (*subList).count))
2602 {
2603 struct Initializer * init = MkInitializerList(subList);
2604 char id[100];
2605
2606 sprintf(id, "__anon%d", anonID);
2607 init->id = MkIdentifier(id);
2608 ListAdd(list, init);
2609 }
2610 else
2611 (__ecereNameSpace__ecere__com__eSystem_Delete(subList), subList = 0);
2612 anonID++;
2613 }
2614 else
2615 {
2616 struct MembersInit * members;
2617 struct MemberInit * member = (((void *)0));
2618 unsigned int found = 0;
2619
2620 if(inst->members && (*inst->members).first)
2621 {
2622 struct __ecereNameSpace__ecere__com__DataMember * curMember = (((void *)0));
2623 struct __ecereNameSpace__ecere__com__Class * curClass = (((void *)0));
2624 struct __ecereNameSpace__ecere__com__DataMember * subMemberStack[256];
2625 int subMemberStackPos = 0;
2626
2627 for(members = (*inst->members).first; members; members = members->next)
2628 {
2629 if(members->type == 0)
2630 {
2631 for(member = (*members->__anon1.dataMembers).first; member; member = member->next)
2632 {
2633 struct Identifier * firstID = member->identifiers ? (*member->identifiers).first : (((void *)0));
2634
2635 if(firstID)
2636 {
2637 struct __ecereNameSpace__ecere__com__DataMember * _subMemberStack[256];
2638 int _subMemberStackPos = 0;
2639 struct __ecereNameSpace__ecere__com__DataMember * thisMember = (struct __ecereNameSpace__ecere__com__DataMember *)__ecereNameSpace__ecere__com__eClass_FindProperty(classSym->__anon1.registered, firstID->string, privateModule);
2640
2641 if(!thisMember)
2642 thisMember = __ecereNameSpace__ecere__com__eClass_FindDataMember(classSym->__anon1.registered, firstID->string, privateModule, _subMemberStack, &_subMemberStackPos);
2643 if(thisMember)
2644 {
2645 curMember = thisMember;
2646 curClass = curMember->_class;
2647 memcpy(subMemberStack, _subMemberStack, sizeof(struct __ecereNameSpace__ecere__com__DataMember *) * _subMemberStackPos);
2648 subMemberStackPos = _subMemberStackPos;
2649 }
2650 if(curMember == dataMember)
2651 {
2652 if(dataMember->isProperty)
2653 {
2654 if(!((struct __ecereNameSpace__ecere__com__Property *)dataMember)->Set)
2655 {
2656 Compiler_Error(__ecereNameSpace__ecere__GetTranslatedString("ec", "No set defined for property %s\n", (((void *)0))), dataMember->name);
2657 continue;
2658 }
2659 recursionCount--;
2660 return 0;
2661 }
2662 if((*member->identifiers).count > 1 && member->initializer && member->initializer->type == 0)
2663 {
2664 struct __ecereNameSpace__ecere__sys__OldList * partList = MkList();
2665 struct Specifier * spec;
2666 struct MembersInit * nextMembers;
2667 struct MemberInit * next = member->next;
2668 struct Symbol * symbol;
2669
2670 if(!dataMember->dataType)
2671 dataMember->dataType = ProcessTypeString(dataMember->dataTypeString, 0);
2672 symbol = (dataMember->dataType && dataMember->dataType->kind == 8) ? dataMember->dataType->__anon1._class : (((void *)0));
2673 spec = _MkSpecifierName(dataMember->dataTypeString, symbol, (((void *)0)));
2674 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove((&*member->identifiers), firstID);
2675 ListAdd(partList, MkMemberInit(member->identifiers, MkInitializerAssignment(member->initializer->__anon1.exp)));
2676 for(nextMembers = members; nextMembers; nextMembers = nextMembers->next)
2677 {
2678 if(!nextMembers->__anon1.dataMembers)
2679 continue;
2680 if(members != nextMembers)
2681 next = (*nextMembers->__anon1.dataMembers).first;
2682 if(nextMembers->type == 0)
2683 {
2684 struct MemberInit * nextMember;
2685
2686 for(nextMember = next; nextMember; nextMember = next, next = nextMember ? nextMember->next : (((void *)0)))
2687 {
2688 struct Identifier * nextID = (*nextMember->identifiers).first;
2689
2690 if(nextMember->identifiers && (*nextMember->identifiers).count > 1 && !strcmp(firstID->string, nextID->string))
2691 {
2692 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove((&*nextMembers->__anon1.dataMembers), nextMember);
2693 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove((&*nextMember->identifiers), nextID);
2694 ListAdd(partList, nextMember);
2695 }
2696 }
2697 }
2698 }
2699 member->initializer->__anon1.exp = MkExpInstance(MkInstantiation(spec, (((void *)0)), MkListOne(MkMembersInitList(partList))));
2700 member->identifiers = (((void *)0));
2701 }
2702 found = 1;
2703 break;
2704 }
2705 }
2706 else
2707 {
2708 __ecereNameSpace__ecere__com__eClass_FindNextMember(classSym->__anon1.registered, &curClass, &curMember, subMemberStack, &subMemberStackPos);
2709 if(curMember == dataMember)
2710 {
2711 if(dataMember->isProperty)
2712 {
2713 if(!((struct __ecereNameSpace__ecere__com__Property *)dataMember)->Set)
2714 {
2715 Compiler_Error(__ecereNameSpace__ecere__GetTranslatedString("ec", "No set defined for property %s\n", (((void *)0))), dataMember->name);
2716 continue;
2717 }
2718 recursionCount--;
2719 return 0;
2720 }
2721 found = 1;
2722 break;
2723 }
2724 }
2725 }
2726 }
2727 if(found)
2728 break;
2729 }
2730 }
2731 if(dataMember->isProperty)
2732 continue;
2733 if(member && member->initializer && member->initializer->type == 0)
2734 {
2735 if(member->initializer->__anon1.exp->type == 1 && member->initializer->__anon1.exp->expType && member->initializer->__anon1.exp->expType->__anon1._class && member->initializer->__anon1.exp->expType->__anon1._class->__anon1.registered && member->initializer->__anon1.exp->expType->__anon1._class->__anon1.registered->type == 1)
2736 {
2737 struct __ecereNameSpace__ecere__sys__OldList * subList = MkList();
2738
2739 ProcessBracketInst(member->initializer->__anon1.exp->__anon1.instance, subList);
2740 FreeExpression(member->initializer->__anon1.exp);
2741 member->initializer->__anon1.exp = (((void *)0));
2742 ListAdd(list, MkInitializerList(subList));
2743 }
2744 else
2745 {
2746 member->initializer->__anon1.exp->usage = (member->initializer->__anon1.exp->usage & ~0x1) | (((unsigned int)(1)) << 0);
2747 ProcessExpression(member->initializer->__anon1.exp);
2748 ListAdd(list, MkInitializerAssignment(CopyExpression(member->initializer->__anon1.exp)));
2749 }
2750 member->takeOutExp = 1;
2751 }
2752 else if(member && member->initializer && member->initializer->type == 1)
2753 {
2754 ListAdd(list, member->initializer);
2755 member->initializer = (((void *)0));
2756 }
2757 else if(dataMember && dataMember->dataTypeString)
2758 {
2759 struct Symbol * classSym;
2760
2761 if(!dataMember->dataType)
2762 dataMember->dataType = ProcessTypeString(dataMember->dataTypeString, 0);
2763 classSym = (dataMember->dataType && dataMember->dataType->kind == 8) ? dataMember->dataType->__anon1._class : (((void *)0));
2764 if(classSym && classSym->__anon1.registered && classSym->__anon1.registered->type == 1)
2765 {
2766 struct __ecereNameSpace__ecere__sys__OldList * subList = MkList();
2767 struct Specifier * spec = _MkSpecifierName(dataMember->dataTypeString, classSym, (((void *)0)));
2768 struct Instantiation * inst = MkInstantiation(spec, (((void *)0)), (((void *)0)));
2769
2770 ProcessBracketInst(inst, subList);
2771 FreeInstance(inst);
2772 ListAdd(list, MkInitializerList(subList));
2773 }
2774 else if(dataMember->dataType->kind == 12)
2775 {
2776 struct Type * t = dataMember->dataType->__anon1.type;
2777 struct Initializer * inner = MkInitializerAssignment((((void *)0))), * i = inner;
2778
2779 while(t && t->kind == 12)
2780 {
2781 i = MkInitializerList(MkListOne(i));
2782 t = t->__anon1.type;
2783 }
2784 if(t && t->kind == 8 && t->__anon1._class && t->__anon1._class->__anon1.registered && t->__anon1._class->__anon1.registered->type == 1)
2785 {
2786 struct __ecereNameSpace__ecere__sys__OldList * subList = MkList();
2787 struct Specifier * spec = _MkSpecifierName(t->__anon1._class->__anon1.registered->name, classSym, (((void *)0)));
2788 struct Instantiation * inst = MkInstantiation(spec, (((void *)0)), (((void *)0)));
2789
2790 ProcessBracketInst(inst, subList);
2791 FreeInstance(inst);
2792 inner->type = 1;
2793 inner->__anon1.list = subList;
2794 }
2795 else
2796 inner->__anon1.exp = MkExpConstant("0");
2797 ListAdd(list, MkInitializerList(MkListOne(i)));
2798 }
2799 else
2800 ListAdd(list, MkInitializerAssignment(MkExpConstant("0")));
2801 }
2802 }
2803 }
2804 }
2805 if(inst->members && (*inst->members).first)
2806 {
2807 struct MembersInit * members;
2808 struct MemberInit * member = (((void *)0));
2809
2810 for(members = (*inst->members).first; members; members = members->next)
2811 {
2812 if(members->type == 0)
2813 {
2814 for(member = (*members->__anon1.dataMembers).first; member; member = member->next)
2815 {
2816 if(member->takeOutExp)
2817 {
2818 FreeInitializer(member->initializer);
2819 member->initializer = (((void *)0));
2820 }
2821 }
2822 }
2823 }
2824 }
2825 recursionCount--;
2826 return 1;
2827 }
2828
2829 static void ProcessExpression(struct Expression * exp)
2830 {
2831 switch(exp->type)
2832 {
2833 case 0:
2834 break;
2835 case 1:
2836 {
2837 struct Instantiation * inst = exp->__anon1.instance;
2838
2839 if(inCompiler && inst->_class)
2840 {
2841 char className[1024];
2842 struct Symbol * classSym = inst->_class->__anon1.__anon1.symbol;
2843 struct Expression * instExp;
2844
2845 if(classSym && classSym->__anon1.registered && classSym->__anon1.registered->type == 2)
2846 {
2847 if(inst->exp)
2848 {
2849 struct __ecereNameSpace__ecere__sys__OldList list =
2850 {
2851 0
2852 };
2853
2854 ProcessInstMembers(inst, (((void *)0)), &list, 0);
2855 ProcessExpression(inst->exp);
2856 exp->type = 4;
2857 exp->__anon1.op.op = '=';
2858 exp->__anon1.op.exp1 = inst->exp;
2859 exp->__anon1.op.exp2 = list.first;
2860 inst->exp = (((void *)0));
2861 }
2862 else
2863 {
2864 struct Type * expType = exp->expType;
2865 struct Expression * prev = exp->prev, * next = exp->next;
2866 struct __ecereNameSpace__ecere__sys__OldList list =
2867 {
2868 0, 0, 0, 0, 0
2869 };
2870
2871 ProcessInstMembers(inst, (((void *)0)), &list, 0);
2872 FreeType(exp->destType);
2873 *exp = *(struct Expression *)list.first;
2874 {
2875 struct Expression * firstExp = list.first;
2876
2877 ((firstExp ? (__ecereClass_Expression->Destructor ? __ecereClass_Expression->Destructor((void *)firstExp) : 0, __ecereNameSpace__ecere__com__eSystem_Delete(firstExp)) : 0), firstExp = 0);
2878 }
2879 FreeType(exp->destType);
2880 exp->destType = expType;
2881 exp->prev = prev;
2882 exp->next = next;
2883 }
2884 }
2885 else if(classSym && classSym->__anon1.registered && (classSym->__anon1.registered->type == 3 || classSym->__anon1.registered->type == 4))
2886 {
2887 if(inst->exp)
2888 {
2889 struct __ecereNameSpace__ecere__sys__OldList list =
2890 {
2891 0
2892 };
2893 struct Expression * e;
2894
2895 ProcessInstMembers(inst, (((void *)0)), &list, 0);
2896 ProcessExpression(inst->exp);
2897 exp->type = 4;
2898 exp->__anon1.op.op = '=';
2899 exp->__anon1.op.exp1 = inst->exp;
2900 exp->__anon1.op.exp2 = list.first;
2901 inst->exp = (((void *)0));
2902 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove(&list, list.first);
2903 while((e = list.first))
2904 {
2905 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove(&list, e);
2906 FreeExpression(e);
2907 }
2908 }
2909 else
2910 {
2911 struct Expression * prev = exp->prev, * next = exp->next;
2912 struct Type * expType = exp->expType;
2913 struct __ecereNameSpace__ecere__sys__OldList list =
2914 {
2915 0
2916 };
2917
2918 ProcessInstMembers(inst, (((void *)0)), &list, 0);
2919 if(list.first)
2920 {
2921 struct Expression * e = list.first;
2922
2923 FreeType(exp->destType);
2924 *exp = *e;
2925 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove(&list, e);
2926 ((e ? (__ecereClass_Expression->Destructor ? __ecereClass_Expression->Destructor((void *)e) : 0, __ecereNameSpace__ecere__com__eSystem_Delete(e)) : 0), e = 0);
2927 exp->expType = expType;
2928 exp->prev = prev;
2929 exp->next = next;
2930 while((e = list.first))
2931 {
2932 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove(&list, e);
2933 FreeExpression(e);
2934 }
2935 }
2936 else
2937 {
2938 exp->type = 2;
2939 exp->__anon1.__anon1.constant = __ecereNameSpace__ecere__sys__CopyString("0");
2940 }
2941 }
2942 }
2943 else if(classSym && classSym->__anon1.registered && classSym->__anon1.registered->type == 1)
2944 {
2945 if(inst->exp)
2946 {
2947 exp->type = 5;
2948 exp->__anon1.list = MkList();
2949 ProcessInstMembers(inst, inst->exp, exp->__anon1.list, 0);
2950 ProcessExpression(inst->exp);
2951 if(!(*exp->__anon1.list).count)
2952 {
2953 exp->type = 16;
2954 (__ecereNameSpace__ecere__com__eSystem_Delete(exp->__anon1.list), exp->__anon1.list = 0);
2955 }
2956 }
2957 else
2958 {
2959 struct Declaration * decl;
2960 struct Declaration * dummyDecl;
2961
2962 {
2963 dummyDecl = MkDeclaration((((void *)0)), (((void *)0)));
2964 if(!curCompound->__anon1.compound.declarations)
2965 curCompound->__anon1.compound.declarations = MkList();
2966 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert((&*curCompound->__anon1.compound.declarations), (((void *)0)), dummyDecl);
2967 sprintf(className, "__simpleStruct%d", curContext->simpleID++);
2968 {
2969 struct __ecereNameSpace__ecere__sys__OldList * list = MkList();
2970
2971 if(inst->isConstant && ProcessBracketInst(inst, list))
2972 {
2973 decl = MkDeclaration(MkList(), MkList());
2974 ListAdd(decl->__anon1.__anon1.specifiers, MkSpecifierName(inst->_class->__anon1.__anon1.name));
2975 ListAdd(decl->__anon1.__anon1.declarators, MkInitDeclarator(MkDeclaratorIdentifier(MkIdentifier(className)), MkInitializerList(list)));
2976 exp->type = 0;
2977 exp->__anon1.__anon1.identifier = MkIdentifier(className);
2978 }
2979 else
2980 {
2981 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Free((&*list), (((void *)0)));
2982 (__ecereNameSpace__ecere__com__eSystem_Delete(list), list = 0);
2983 decl = MkDeclarationInst(MkInstantiation(CopySpecifier(inst->_class), MkExpIdentifier(MkIdentifier(className)), (((void *)0))));
2984 exp->type = 5;
2985 exp->__anon1.list = MkList();
2986 instExp = QMkExpId(className);
2987 instExp->loc = exp->loc;
2988 instExp->expType = MkClassType(inst->_class->__anon1.__anon1.name);
2989 decl->__anon1.inst->fullSet = ProcessInstMembers(inst, instExp, exp->__anon1.list, 0);
2990 ListAdd(exp->__anon1.list, instExp);
2991 }
2992 }
2993 FreeType(exp->expType);
2994 exp->expType = MkClassType(inst->_class->__anon1.__anon1.name);
2995 {
2996 void * prev = dummyDecl->prev, * next = dummyDecl->next;
2997
2998 *dummyDecl = *decl;
2999 dummyDecl->prev = prev;
3000 dummyDecl->next = next;
3001 ((decl ? (__ecereClass_Declaration->Destructor ? __ecereClass_Declaration->Destructor((void *)decl) : 0, __ecereNameSpace__ecere__com__eSystem_Delete(decl)) : 0), decl = 0);
3002 decl = dummyDecl;
3003 }
3004 ProcessDeclaration(decl);
3005 }
3006 }
3007 }
3008 else
3009 {
3010 struct Expression * newCall;
3011
3012 if(classSym && classSym->__anon1.registered && classSym->__anon1.registered->type == 5 && (classSym->__anon1.registered->templateClass ? classSym->__anon1.registered->templateClass->fixed : classSym->__anon1.registered->fixed))
3013 {
3014 char size[256];
3015 struct __ecereNameSpace__ecere__com__Class * c = classSym->__anon1.registered->templateClass ? classSym->__anon1.registered->templateClass : classSym->__anon1.registered;
3016 struct Expression * e = MkExpClassSize(MkSpecifierName(c->name));
3017
3018 ProcessExpressionType(e);
3019 sprintf(size, "%d", c->structSize);
3020 newCall = MkExpCall(QMkExpId("ecere::com::eSystem_New0"), MkListOne(e));
3021 newCall->byReference = 1;
3022 }
3023 else
3024 {
3025 strcpy(className, "__ecereClass_");
3026 if(classSym && classSym->__anon1.registered && classSym->__anon1.registered->type == 5 && classSym->__anon1.registered->templateClass)
3027 {
3028 classSym = FindClass(classSym->__anon1.registered->templateClass->fullName);
3029 FullClassNameCat(className, classSym->string, 1);
3030 }
3031 else
3032 FullClassNameCat(className, inst->_class->__anon1.__anon1.name, 1);
3033 DeclareClass(curExternal, classSym, className);
3034 newCall = MkExpCall(QMkExpId("ecere::com::eInstance_New"), MkListOne(QMkExpId(className)));
3035 newCall->usage = exp->usage;
3036 ProcessExpressionType(newCall);
3037 if(newCall->expType && exp->expType)
3038 newCall->expType->passAsTemplate = exp->expType->passAsTemplate;
3039 newCall->byReference = 1;
3040 }
3041 if(inst->exp)
3042 {
3043 if(inst->members && (*inst->members).first)
3044 {
3045 exp->type = 5;
3046 exp->__anon1.list = MkList();
3047 if(!inst->built)
3048 {
3049 ListAdd(exp->__anon1.list, MkExpOp(inst->exp, '=', newCall));
3050 }
3051 else
3052 FreeExpression(newCall);
3053 ProcessInstMembers(inst, inst->exp, exp->__anon1.list, 0);
3054 if(inst->built)
3055 FreeExpression(inst->exp);
3056 }
3057 else
3058 {
3059 exp->type = 4;
3060 exp->__anon1.op.op = '=';
3061 exp->__anon1.op.exp1 = inst->exp;
3062 exp->__anon1.op.exp2 = newCall;
3063 ProcessExpression(inst->exp);
3064 }
3065 inst->exp = (((void *)0));
3066 }
3067 else
3068 {
3069 if(inst->members && (*inst->members).first)
3070 {
3071 int __simpleStruct0;
3072 char ecereTemp[100];
3073 struct MembersInit * members;
3074 int tempCount = exp->tempCount;
3075 struct __ecereNameSpace__ecere__sys__OldList * expList;
3076
3077 for(members = (*inst->members).first; members; members = members->next)
3078 {
3079 if(members->type == 0 && members->__anon1.dataMembers)
3080 {
3081 struct MemberInit * member;
3082
3083 for(member = (*members->__anon1.dataMembers).first; member; member = member->next)
3084 {
3085 if(member->initializer && member->initializer->type == 0)
3086 {
3087 int __simpleStruct0;
3088
3089 ProcessMemberInitData(member);
3090 tempCount = (__simpleStruct0 = member->initializer->__anon1.exp->tempCount, (tempCount > __simpleStruct0) ? tempCount : __simpleStruct0);
3091 }
3092 }
3093 }
3094 }
3095 if(curDecl)
3096 tempCount = ((tempCount > declTempCount) ? tempCount : declTempCount);
3097 tempCount++;
3098 curExternal->__anon1.function->tempCount = (__simpleStruct0 = curExternal->__anon1.function->tempCount, (__simpleStruct0 > tempCount) ? __simpleStruct0 : tempCount);
3099 sprintf(ecereTemp, "__ecereInstance%d", tempCount);
3100 exp->type = 23;
3101 exp->__anon1.compound = MkCompoundStmt((((void *)0)), (((void *)0)));
3102 exp->__anon1.compound->__anon1.compound.context = PushContext();
3103 exp->__anon1.compound->__anon1.compound.context->simpleID = exp->__anon1.compound->__anon1.compound.context->parent->simpleID;
3104 exp->__anon1.compound->__anon1.compound.declarations = MkListOne(QMkDeclaration(inst->_class->__anon1.__anon1.name, MkInitDeclarator(MkDeclaratorIdentifier(MkIdentifier(ecereTemp)), MkInitializerAssignment(newCall))));
3105 exp->__anon1.compound->__anon1.compound.statements = MkListOne(MkExpressionStmt((expList = MkList())));
3106 instExp = QMkExpId(ecereTemp);
3107 instExp->tempCount = tempCount;
3108 instExp->expType = MkClassType(inst->_class->__anon1.__anon1.name);
3109 instExp->byReference = 1;
3110 ProcessInstMembers(inst, instExp, expList, 0);
3111 FreeExpression(instExp);
3112 if(exp->usage)
3113 {
3114 struct Expression * tmpExp = QMkExpId(ecereTemp);
3115
3116 tmpExp->byReference = 1;
3117 ListAdd(expList, tmpExp);
3118 }
3119 exp->tempCount = tempCount;
3120 if(curDecl)
3121 declTempCount = ((declTempCount > tempCount) ? declTempCount : tempCount);
3122 PopContext(exp->__anon1.compound->__anon1.compound.context);
3123 }
3124 else
3125 {
3126 struct Expression * prev = exp->prev, * next = exp->next;
3127
3128 FreeType(newCall->destType);
3129 FreeType(newCall->expType);
3130 newCall->destType = exp->destType;
3131 newCall->expType = exp->expType;
3132 *exp = *newCall;
3133 exp->prev = prev;
3134 exp->next = next;
3135 ((newCall ? (__ecereClass_Expression->Destructor ? __ecereClass_Expression->Destructor((void *)newCall) : 0, __ecereNameSpace__ecere__com__eSystem_Delete(newCall)) : 0), newCall = 0);
3136 }
3137 }
3138 }
3139 if(exp->type != 1)
3140 FreeInstance(inst);
3141 }
3142 else
3143 ProcessInstantiation(inst);
3144 break;
3145 }
3146 case 2:
3147 break;
3148 case 3:
3149 break;
3150 case 13:
3151 case 26:
3152 ProcessExpression(exp->__anon1._new.size);
3153 break;
3154 case 14:
3155 case 27:
3156 ProcessExpression(exp->__anon1._renew.size);
3157 ProcessExpression(exp->__anon1._renew.exp);
3158 break;
3159 case 4:
3160 {
3161 switch(exp->__anon1.op.op)
3162 {
3163 case '=':
3164 if(exp->__anon1.op.exp2)
3165 exp->__anon1.op.exp2->usage = (exp->__anon1.op.exp2->usage & ~0x1) | (((unsigned int)(1)) << 0);
3166 if(exp->__anon1.op.exp1)
3167 exp->__anon1.op.exp1->usage = (exp->__anon1.op.exp1->usage & ~0x2) | (((unsigned int)(1)) << 1);
3168 break;
3169 case MUL_ASSIGN:
3170 case DIV_ASSIGN:
3171 case MOD_ASSIGN:
3172 case ADD_ASSIGN:
3173 case SUB_ASSIGN:
3174 case LEFT_ASSIGN:
3175 case RIGHT_ASSIGN:
3176 case AND_ASSIGN:
3177 case XOR_ASSIGN:
3178 case OR_ASSIGN:
3179 if(exp->__anon1.op.exp2)
3180 exp->__anon1.op.exp2->usage = (exp->__anon1.op.exp2->usage & ~0x1) | (((unsigned int)(1)) << 0);
3181 if(exp->__anon1.op.exp1)
3182 exp->__anon1.op.exp1->usage = (exp->__anon1.op.exp1->usage & ~0x2) | (((unsigned int)(1)) << 1);
3183 break;
3184 case INC_OP:
3185 case DEC_OP:
3186 if(exp->__anon1.op.exp1)
3187 exp->__anon1.op.exp1->usage = (exp->__anon1.op.exp1->usage & ~0x2) | (((unsigned int)(1)) << 1);
3188 case '&':
3189 if(exp->__anon1.op.exp1 && exp->__anon1.op.exp2)
3190 {
3191 exp->__anon1.op.exp1->usage = (exp->__anon1.op.exp1->usage & ~0x1) | (((unsigned int)(1)) << 0);
3192 exp->__anon1.op.exp2->usage = (exp->__anon1.op.exp2->usage & ~0x1) | (((unsigned int)(1)) << 0);
3193 }
3194 break;
3195 case '*':
3196 case '+':
3197 case '-':
3198 if(exp->__anon1.op.exp1)
3199 {
3200 exp->__anon1.op.exp1->usage = (exp->__anon1.op.exp1->usage & ~0x1) | (((unsigned int)(1)) << 0);
3201 }
3202 case '~':
3203 case '!':
3204 if(exp->__anon1.op.exp2)
3205 exp->__anon1.op.exp2->usage = (exp->__anon1.op.exp2->usage & ~0x1) | (((unsigned int)(1)) << 0);
3206 break;
3207 case '/':
3208 case '%':
3209 case LEFT_OP:
3210 case RIGHT_OP:
3211 case '<':
3212 case '>':
3213 case LE_OP:
3214 case GE_OP:
3215 case EQ_OP:
3216 case NE_OP:
3217 case '|':
3218 case '^':
3219 case AND_OP:
3220 case OR_OP:
3221 if(exp->__anon1.op.exp1)
3222 exp->__anon1.op.exp1->usage = (exp->__anon1.op.exp1->usage & ~0x1) | (((unsigned int)(1)) << 0);
3223 if(exp->__anon1.op.exp2)
3224 exp->__anon1.op.exp2->usage = (exp->__anon1.op.exp2->usage & ~0x1) | (((unsigned int)(1)) << 0);
3225 break;
3226 }
3227 if(exp->__anon1.op.exp1)
3228 {
3229 if(exp->__anon1.op.exp1 && exp->__anon1.op.exp2 && exp->__anon1.op.exp1->destType && exp->__anon1.op.exp1->destType->passAsTemplate && exp->__anon1.op.exp1->expType && !exp->__anon1.op.exp1->expType->passAsTemplate && !((unsigned int)((exp->__anon1.op.exp1->usage & 0x2) >> 1)))
3230 {
3231 struct Type * type = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Type);
3232
3233 CopyTypeInto(type, exp->__anon1.op.exp1->destType);
3234 type->passAsTemplate = 0;
3235 FreeType(exp->__anon1.op.exp1->destType);
3236 exp->__anon1.op.exp1->destType = type;
3237 }
3238 ProcessExpression(exp->__anon1.op.exp1);
3239 }
3240 if(exp->__anon1.op.exp2)
3241 {
3242 if(exp->__anon1.op.exp1 && exp->__anon1.op.exp2 && exp->__anon1.op.exp2->destType && exp->__anon1.op.exp2->destType->passAsTemplate && exp->__anon1.op.exp2->expType && !exp->__anon1.op.exp2->expType->passAsTemplate && !((unsigned int)((exp->__anon1.op.exp1->usage & 0x2) >> 1)))
3243 {
3244 struct Type * type = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Type);
3245
3246 CopyTypeInto(type, exp->__anon1.op.exp2->destType);
3247 type->passAsTemplate = 0;
3248 FreeType(exp->__anon1.op.exp2->destType);
3249 exp->__anon1.op.exp2->destType = type;
3250 }
3251 if(exp->__anon1.op.exp1)
3252 exp->__anon1.op.exp2->tempCount = exp->__anon1.op.exp1->tempCount;
3253 ProcessExpression(exp->__anon1.op.exp2);
3254 }
3255 break;
3256 }
3257 case 32:
3258 case 5:
3259 {
3260 struct Expression * e;
3261
3262 for(e = (*exp->__anon1.list).first; e; e = e->next)
3263 {
3264 int __simpleStruct2, __simpleStruct3;
3265 int __simpleStruct0, __simpleStruct1;
3266
3267 e->tempCount = (__simpleStruct0 = e->tempCount, __simpleStruct1 = exp->tempCount, (__simpleStruct0 > __simpleStruct1) ? __simpleStruct0 : __simpleStruct1);
3268 if(!e->next)
3269 {
3270 e->usage |= (exp->usage & ((((unsigned int)(1)) | (((unsigned int)(1)) << 2))));
3271 }
3272 ProcessExpression(e);
3273 exp->tempCount = (__simpleStruct2 = exp->tempCount, __simpleStruct3 = e->tempCount, (__simpleStruct2 > __simpleStruct3) ? __simpleStruct2 : __simpleStruct3);
3274 }
3275 break;
3276 }
3277 case 6:
3278 {
3279 struct Expression * e;
3280
3281 exp->__anon1.index.exp->usage = (exp->__anon1.index.exp->usage & ~0x1) | (((unsigned int)(1)) << 0);
3282 ProcessExpression(exp->__anon1.index.exp);
3283 for(e = (*exp->__anon1.index.index).first; e; e = e->next)
3284 {
3285 if(!e->next)
3286 e->usage = (e->usage & ~0x1) | (((unsigned int)(1)) << 0);
3287 ProcessExpression(e);
3288 }
3289 exp->tempCount = exp->__anon1.index.exp->tempCount;
3290 break;
3291 }
3292 case 7:
3293 {
3294 struct Expression * e;
3295
3296 ProcessExpression(exp->__anon1.call.exp);
3297 if(exp->__anon1.call.arguments)
3298 {
3299 for(e = (*exp->__anon1.call.arguments).first; e; e = e->next)
3300 {
3301 e->usage = (e->usage & ~0x1) | (((unsigned int)(1)) << 0);
3302 e->usage = (e->usage & ~0x4) | (((unsigned int)(1)) << 2);
3303 ProcessExpression(e);
3304 }
3305 }
3306 break;
3307 }
3308 case 8:
3309 {
3310 exp->__anon1.member.exp->usage = (exp->__anon1.member.exp->usage & ~0x1) | (((unsigned int)(1)) << 0);
3311 ProcessExpression(exp->__anon1.member.exp);
3312 if(!exp->__anon1.member.memberType)
3313 {
3314 struct Type * type = exp->__anon1.member.exp->expType;
3315
3316 if((type && type->kind == 8 && exp->__anon1.member.member))
3317 {
3318 struct __ecereNameSpace__ecere__com__Class * _class = (exp->__anon1.member.member->_class && exp->__anon1.member.member->classSym) ? exp->__anon1.member.member->classSym->__anon1.registered : (type->__anon1._class ? type->__anon1._class->__anon1.registered : (((void *)0)));
3319 struct __ecereNameSpace__ecere__com__Property * prop = (((void *)0));
3320 struct __ecereNameSpace__ecere__com__Method * method = (((void *)0));
3321 struct __ecereNameSpace__ecere__com__DataMember * member = (((void *)0));
3322 struct __ecereNameSpace__ecere__com__Property * revConvert = (((void *)0));
3323
3324 if(exp->__anon1.member.thisPtr)
3325 {
3326 member = __ecereNameSpace__ecere__com__eClass_FindDataMember(_class, exp->__anon1.member.member->string, privateModule, (((void *)0)), (((void *)0)));
3327 if(!member)
3328 prop = __ecereNameSpace__ecere__com__eClass_FindProperty(_class, exp->__anon1.member.member->string, privateModule);
3329 }
3330 else
3331 {
3332 prop = __ecereNameSpace__ecere__com__eClass_FindProperty(_class, exp->__anon1.member.member->string, (((void *)0)));
3333 if(!prop)
3334 member = __ecereNameSpace__ecere__com__eClass_FindDataMember(_class, exp->__anon1.member.member->string, (((void *)0)), (((void *)0)), (((void *)0)));
3335 if(!prop && !member)
3336 {
3337 method = __ecereNameSpace__ecere__com__eClass_FindMethod(_class, exp->__anon1.member.member->string, (((void *)0)));
3338 if(!method)
3339 {
3340 prop = __ecereNameSpace__ecere__com__eClass_FindProperty(_class, exp->__anon1.member.member->string, privateModule);
3341 if(!prop)
3342 member = __ecereNameSpace__ecere__com__eClass_FindDataMember(_class, exp->__anon1.member.member->string, privateModule, (((void *)0)), (((void *)0)));
3343 }
3344 }
3345 }
3346 if(!prop && !member && !method)
3347 method = __ecereNameSpace__ecere__com__eClass_FindMethod(_class, exp->__anon1.member.member->string, privateModule);
3348 if(!prop && !member && !method)
3349 {
3350 struct Symbol * classSym = FindClass(exp->__anon1.member.member->string);
3351
3352 if(classSym)
3353 {
3354 struct __ecereNameSpace__ecere__com__Class * convertClass = classSym->__anon1.registered;
3355
3356 if(convertClass)
3357 revConvert = __ecereNameSpace__ecere__com__eClass_FindProperty(convertClass, _class->fullName, privateModule);
3358 }
3359 }
3360 if(prop)
3361 {
3362 exp->__anon1.member.memberType = 1;
3363 if(!prop->dataType)
3364 prop->dataType = ProcessTypeString(prop->dataTypeString, 0);
3365 FreeType(exp->expType);
3366 exp->expType = prop->dataType;
3367 if(prop->dataType)
3368 prop->dataType->refCount++;
3369 }
3370 else if(method)
3371 {
3372 exp->__anon1.member.memberType = 2;
3373 if(!method->dataType)
3374 ProcessMethodType(method);
3375 FreeType(exp->expType);
3376 exp->expType = method->dataType;
3377 if(method->dataType)
3378 method->dataType->refCount++;
3379 }
3380 else if(member)
3381 {
3382 exp->__anon1.member.memberType = 3;
3383 DeclareStruct(curExternal, _class->fullName, 0, 1);
3384 if(!member->dataType)
3385 member->dataType = ProcessTypeString(member->dataTypeString, 0);
3386 FreeType(exp->expType);
3387 exp->expType = member->dataType;
3388 if(member->dataType)
3389 member->dataType->refCount++;
3390 }
3391 else if(revConvert)
3392 {
3393 exp->__anon1.member.memberType = 4;
3394 FreeType(exp->expType);
3395 exp->expType = MkClassType(revConvert->_class->fullName);
3396 }
3397 }
3398 }
3399 break;
3400 }
3401 case 10:
3402 break;
3403 case 11:
3404 {
3405 exp->__anon1.cast.exp->usage |= exp->usage;
3406 ProcessExpression(exp->__anon1.cast.exp);
3407 break;
3408 }
3409 case 12:
3410 {
3411 struct Expression * e;
3412
3413 if(((unsigned int)((exp->usage & 0x1) >> 0)))
3414 exp->__anon1.cond.cond->usage = (exp->__anon1.cond.cond->usage & ~0x1) | (((unsigned int)(1)) << 0);
3415 ProcessExpression(exp->__anon1.cond.cond);
3416 for(e = (*exp->__anon1.cond.exp).first; e; e = e->next)
3417 {
3418 if(!e->next && ((unsigned int)((exp->usage & 0x1) >> 0)))
3419 e->usage = (e->usage & ~0x1) | (((unsigned int)(1)) << 0);
3420 ProcessExpression(e);
3421 }
3422 if(exp->__anon1.cond.elseExp)
3423 {
3424 if(((unsigned int)((exp->usage & 0x1) >> 0)))
3425 exp->__anon1.cond.elseExp->usage = (exp->__anon1.cond.elseExp->usage & ~0x1) | (((unsigned int)(1)) << 0);
3426 ProcessExpression(exp->__anon1.cond.elseExp);
3427 }
3428 break;
3429 }
3430 case 23:
3431 {
3432 if(exp->__anon1.compound->__anon1.compound.statements && ((struct Statement *)(*exp->__anon1.compound->__anon1.compound.statements).last)->type == 3 && ((struct Statement *)(*exp->__anon1.compound->__anon1.compound.statements).last)->__anon1.expressions && (*((struct Statement *)(*exp->__anon1.compound->__anon1.compound.statements).last)->__anon1.expressions).last)
3433 {
3434 ((struct Expression *)(*((struct Statement *)(*exp->__anon1.compound->__anon1.compound.statements).last)->__anon1.expressions).last)->usage = exp->usage;
3435 }
3436 ProcessStatement(exp->__anon1.compound);
3437 break;
3438 }
3439 case 34:
3440 {
3441 ProcessExpression(exp->__anon1.vaArg.exp);
3442 break;
3443 }
3444 case 33:
3445 {
3446 ProcessInitializer(exp->__anon1.initializer.initializer);
3447 break;
3448 }
3449 }
3450 CheckTemplateTypes(exp);
3451 }
3452
3453 static unsigned int ProcessBracketInst_DataMember(struct __ecereNameSpace__ecere__com__DataMember * parentMember, struct Instantiation * inst, struct __ecereNameSpace__ecere__sys__OldList * list, struct __ecereNameSpace__ecere__com__DataMember * namedParentMember, unsigned int parentMemberSet)
3454 {
3455 struct Symbol * classSym = inst->_class->__anon1.__anon1.symbol;
3456 struct __ecereNameSpace__ecere__com__DataMember * dataMember = (((void *)0));
3457 unsigned int someMemberSet = 0;
3458 int anonID = 1;
3459
3460 for(dataMember = parentMember->members.first; dataMember; dataMember = dataMember->next)
3461 {
3462 struct MembersInit * members;
3463 struct MemberInit * member = (((void *)0));
3464
3465 if(!dataMember->name && (dataMember->type == 1 || dataMember->type == 2))
3466 {
3467 struct __ecereNameSpace__ecere__sys__OldList * subList = MkList();
3468
3469 if(!ProcessBracketInst_DataMember(dataMember, inst, subList ? subList : list, dataMember->name ? dataMember : namedParentMember, someMemberSet || parentMemberSet || dataMember->prev))
3470 {
3471 if(subList)
3472 FreeList(subList, (void *)(FreeInitializer));
3473 return 0;
3474 }
3475 if(subList && (*subList).count)
3476 {
3477 struct Initializer * init = MkInitializerList(subList);
3478 char id[100];
3479
3480 sprintf(id, "__anon%d", anonID);
3481 init->id = MkIdentifier(id);
3482 ListAdd(list, init);
3483 someMemberSet = 1;
3484 }
3485 else
3486 {
3487 if(list->count)
3488 someMemberSet = 1;
3489 (__ecereNameSpace__ecere__com__eSystem_Delete(subList), subList = 0);
3490 }
3491 anonID++;
3492 }
3493 else
3494 {
3495 struct __ecereNameSpace__ecere__com__Class * curClass = (((void *)0));
3496 struct __ecereNameSpace__ecere__com__DataMember * curMember = (((void *)0));
3497 struct __ecereNameSpace__ecere__com__DataMember * subMemberStack[256];
3498 int subMemberStackPos = 0;
3499 unsigned int found = 0;
3500
3501 if(inst->members && (*inst->members).first)
3502 {
3503 for(members = (*inst->members).first; members; members = members->next)
3504 {
3505 if(members->type == 0)
3506 {
3507 for(member = (*members->__anon1.dataMembers).first; member; member = member->next)
3508 {
3509 if(member->identifiers)
3510 {
3511 struct Identifier * firstID = (*member->identifiers).first;
3512 struct __ecereNameSpace__ecere__com__DataMember * _subMemberStack[256];
3513 int _subMemberStackPos = 0;
3514 struct __ecereNameSpace__ecere__com__DataMember * thisMember;
3515
3516 thisMember = firstID ? (struct __ecereNameSpace__ecere__com__DataMember *)__ecereNameSpace__ecere__com__eClass_FindProperty(classSym->__anon1.registered, firstID->string, privateModule) : (((void *)0));
3517 if(!thisMember && firstID)
3518 thisMember = __ecereNameSpace__ecere__com__eClass_FindDataMember(classSym->__anon1.registered, firstID->string, privateModule, _subMemberStack, &_subMemberStackPos);
3519 if(thisMember && thisMember->memberAccess == 1)
3520 {
3521 curMember = thisMember;
3522 curClass = curMember->_class;
3523 memcpy(subMemberStack, _subMemberStack, sizeof(struct __ecereNameSpace__ecere__com__DataMember *) * _subMemberStackPos);
3524 subMemberStackPos = _subMemberStackPos;
3525 }
3526 if(dataMember == thisMember)
3527 {
3528 if((*member->identifiers).count > 1 && member->initializer && member->initializer->type == 0)
3529 {
3530 struct __ecereNameSpace__ecere__sys__OldList * partList = MkList();
3531 struct Symbol * symbol;
3532 struct Specifier * spec;
3533 struct MembersInit * nextMembers;
3534 struct MemberInit * next = member->next;
3535
3536 if(!dataMember->dataType)
3537 dataMember->dataType = ProcessTypeString(dataMember->dataTypeString, 0);
3538 symbol = (dataMember->dataType && dataMember->dataType->kind == 8) ? dataMember->dataType->__anon1._class : (((void *)0));
3539 spec = _MkSpecifierName(dataMember->dataTypeString, symbol, (((void *)0)));
3540 {
3541 struct __ecereNameSpace__ecere__sys__OldList * identifiers = MkList();
3542 struct Identifier * id;
3543
3544 for(id = ((struct Identifier *)(*member->identifiers).first)->next; id; id = id->next)
3545 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add((&*identifiers), CopyIdentifier(id));
3546 ListAdd(partList, MkMemberInit(identifiers, MkInitializerAssignment(member->initializer->__anon1.exp)));
3547 }
3548 for(nextMembers = members; nextMembers; nextMembers = nextMembers->next)
3549 {
3550 if(!nextMembers->__anon1.dataMembers)
3551 continue;
3552 if(members != nextMembers)
3553 next = (*nextMembers->__anon1.dataMembers).first;
3554 if(nextMembers->type == 0)
3555 {
3556 struct MemberInit * nextMember;
3557
3558 for(nextMember = next; nextMember; nextMember = next, next = nextMember ? nextMember->next : (((void *)0)))
3559 {
3560 struct Identifier * nextID = (*nextMember->identifiers).first;
3561
3562 if(nextMember->identifiers && (*nextMember->identifiers).count > 1 && !strcmp(firstID->string, nextID->string))
3563 {
3564 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove((&*nextMembers->__anon1.dataMembers), nextMember);
3565 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove((&*nextMember->identifiers), nextID);
3566 ListAdd(partList, nextMember);
3567 }
3568 }
3569 }
3570 }
3571 member->initializer->__anon1.exp = MkExpInstance(MkInstantiation(spec, (((void *)0)), MkListOne(MkMembersInitList(partList))));
3572 }
3573 found = 1;
3574 break;
3575 }
3576 }
3577 else
3578 {
3579 __ecereNameSpace__ecere__com__eClass_FindNextMember(classSym->__anon1.registered, &curClass, &curMember, subMemberStack, &subMemberStackPos);
3580 if(curMember == dataMember)
3581 {
3582 found = 1;
3583 break;
3584 }
3585 }
3586 }
3587 }
3588 if(found)
3589 break;
3590 }
3591 }
3592 if(member && member->initializer && member->initializer->type == 0)
3593 {
3594 struct Initializer * init = (init = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Initializer), init->loc = yylloc, init);
3595
3596 if(namedParentMember->type == 1 && dataMember->name)
3597 init->id = MkIdentifier(dataMember->name);
3598 if(member->initializer->__anon1.exp->type == 1 && member->initializer->__anon1.exp->expType && member->initializer->__anon1.exp->expType->__anon1._class->__anon1.registered->type == 1)
3599 {
3600 struct __ecereNameSpace__ecere__sys__OldList * subList = MkList();
3601
3602 ProcessBracketInst(member->initializer->__anon1.exp->__anon1.instance, subList);
3603 FreeExpression(member->initializer->__anon1.exp);
3604 if((*subList).count)
3605 {
3606 init->type = 1;
3607 init->__anon1.list = subList;
3608 }
3609 else
3610 {
3611 FreeInitializer(init);
3612 init = (((void *)0));
3613 }
3614 }
3615 else
3616 {
3617 member->initializer->__anon1.exp->usage = (member->initializer->__anon1.exp->usage & ~0x1) | (((unsigned int)(1)) << 0);
3618 ProcessExpression(member->initializer->__anon1.exp);
3619 init->type = 0;
3620 init->__anon1.exp = member->initializer->__anon1.exp;
3621 }
3622 if(init)
3623 ListAdd(list, init);
3624 member->initializer->__anon1.exp = (((void *)0));
3625 FreeInitializer(member->initializer);
3626 member->initializer = (((void *)0));
3627 someMemberSet = 1;
3628 }
3629 else if(member && member->initializer && member->initializer->type == 1)
3630 {
3631 if(namedParentMember->type == 1 && dataMember->name)
3632 member->initializer->id = MkIdentifier(dataMember->name);
3633 ListAdd(list, member->initializer);
3634 member->initializer = (((void *)0));
3635 someMemberSet = 1;
3636 }
3637 else if(dataMember && dataMember->dataTypeString && parentMember->type != 1 && namedParentMember->type != 1)
3638 {
3639 struct Symbol * classSym;
3640 struct Initializer * init = (init = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Initializer), init->loc = yylloc, init);
3641
3642 if(namedParentMember->type == 1 && dataMember->name)
3643 init->id = MkIdentifier(dataMember->name);
3644 if(!dataMember->dataType)
3645 dataMember->dataType = ProcessTypeString(dataMember->dataTypeString, 0);
3646 classSym = (dataMember->dataType && dataMember->dataType->kind == 8) ? dataMember->dataType->__anon1._class : (((void *)0));
3647 if(classSym && classSym->__anon1.registered && classSym->__anon1.registered->type == 1)
3648 {
3649 struct __ecereNameSpace__ecere__sys__OldList * subList = MkList();
3650 struct Specifier * spec = _MkSpecifierName(dataMember->dataTypeString, classSym, (((void *)0)));
3651 struct Instantiation * inst = MkInstantiation(spec, (((void *)0)), (((void *)0)));
3652
3653 ProcessBracketInst(inst, subList);
3654 FreeInstance(inst);
3655 if((*subList).count)
3656 {
3657 init->type = 1;
3658 init->__anon1.list = subList;
3659 }
3660 else
3661 {
3662 FreeInitializer(init);
3663 init = (((void *)0));
3664 }
3665 }
3666 else
3667 {
3668 init->type = 0;
3669 init->__anon1.exp = MkExpConstant("0");
3670 }
3671 someMemberSet = 1;
3672 if(init)
3673 ListAdd(list, init);
3674 }
3675 }
3676 }
3677 if(!someMemberSet && !parentMemberSet)
3678 {
3679 struct Symbol * classSym;
3680 struct Initializer * init = (init = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Initializer), init->loc = yylloc, init);
3681
3682 dataMember = parentMember->members.first;
3683 if(namedParentMember->type == 1 && dataMember->name)
3684 init->id = MkIdentifier(dataMember->name);
3685 if(!dataMember->dataType && dataMember->dataTypeString)
3686 dataMember->dataType = ProcessTypeString(dataMember->dataTypeString, 0);
3687 classSym = (dataMember->dataType && dataMember->dataType->kind == 8) ? dataMember->dataType->__anon1._class : (((void *)0));
3688 if(classSym && classSym->__anon1.registered && classSym->__anon1.registered->type == 1)
3689 {
3690 struct __ecereNameSpace__ecere__sys__OldList * subList = MkList();
3691 struct Specifier * spec = _MkSpecifierName(dataMember->dataTypeString, classSym, (((void *)0)));
3692 struct Instantiation * inst = MkInstantiation(spec, (((void *)0)), (((void *)0)));
3693
3694 ProcessBracketInst(inst, subList);
3695 FreeInstance(inst);
3696 init->type = 1;
3697 init->__anon1.list = subList;
3698 }
3699 else if(dataMember->dataType && (dataMember->dataType->kind == 12 || dataMember->dataType->kind == 9))
3700 {
3701 struct Type * t = dataMember->dataType->kind == 12 ? dataMember->dataType->__anon1.type : dataMember->dataType->__anon1.__anon1.members.first;
3702 struct Initializer * i = MkInitializerAssignment(MkExpConstant("0"));
3703
3704 while(t && (t->kind == 12 || t->kind == 9))
3705 {
3706 i = MkInitializerList(MkListOne(i));
3707 if(t->kind == 12)
3708 t = t->__anon1.type;
3709 else if(t->kind == 9)
3710 t = t->__anon1.__anon1.members.first;
3711 }
3712 init->type = 1;
3713 init->__anon1.list = MkListOne(i);
3714 }
3715 else
3716 {
3717 init->type = 0;
3718 init->__anon1.exp = MkExpConstant("0");
3719 }
3720 ListAdd(list, init);
3721 }
3722 return 1;
3723 }
3724
3725 static void ProcessDeclaration(struct Declaration * decl)
3726 {
3727 yylloc = decl->loc;
3728 switch(decl->type)
3729 {
3730 case 1:
3731 {
3732 if(!curDecl)
3733 {
3734 curDecl = decl;
3735 declTempCount = 0;
3736 }
3737 if(decl->__anon1.__anon1.specifiers)
3738 {
3739 struct Specifier * s;
3740
3741 for(s = (*decl->__anon1.__anon1.specifiers).first; s; s = s->next)
3742 {
3743 ProcessSpecifier(s);
3744 }
3745 }
3746 if(decl->__anon1.__anon1.declarators)
3747 {
3748 struct InitDeclarator * d;
3749
3750 for(d = (*decl->__anon1.__anon1.declarators).first; d; d = d->next)
3751 {
3752 if(d->initializer)
3753 ProcessInitializer(d->initializer);
3754 }
3755 }
3756 if(curDecl == decl)
3757 {
3758 curDecl = (((void *)0));
3759 declTempCount = 0;
3760 }
3761 break;
3762 }
3763 case 2:
3764 {
3765 struct Instantiation * inst = decl->__anon1.inst;
3766
3767 if(inCompiler)
3768 {
3769 struct Symbol * classSym = inst->_class->__anon1.__anon1.symbol;
3770
3771 if(!curCompound)
3772 {
3773 struct Statement * stmt;
3774
3775 if(!inst->isConstant || (classSym && classSym->__anon1.registered && (classSym->__anon1.registered->type == 0 || classSym->__anon1.registered->type == 5)))
3776 {
3777 decl->type = 1;
3778 decl->__anon1.__anon1.specifiers = MkListOne(MkSpecifierName(inst->_class->__anon1.__anon1.name));
3779 if(decl->declMode == 3)
3780 {
3781 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert((&*decl->__anon1.__anon1.specifiers), (((void *)0)), MkSpecifier(STATIC));
3782 }
3783 decl->__anon1.__anon1.declarators = MkListOne(MkInitDeclarator(MkDeclaratorIdentifier(MkIdentifier(inst->exp->__anon1.__anon1.identifier->string)), (((void *)0))));
3784 ProcessDeclaration(decl);
3785 CreateInstancesBody();
3786 {
3787 struct Expression * exp = MkExpInstance(inst);
3788
3789 stmt = MkExpressionStmt(MkListOne(exp));
3790 ListAdd(createInstancesBody->__anon1.compound.statements, stmt);
3791 ProcessExpressionType(exp);
3792 }
3793 if(classSym && classSym->__anon1.registered && (classSym->__anon1.registered->type == 0))
3794 {
3795 ListAdd(createInstancesBody->__anon1.compound.statements, MkExpressionStmt(MkListOne(MkExpCall(MkExpIdentifier(MkIdentifier("ecere::com::eInstance_IncRef")), MkListOne(CopyExpression(inst->exp))))));
3796 {
3797 struct Expression * exp = MkExpOp((((void *)0)), DELETE, CopyExpression(inst->exp));
3798
3799 ListAddFront(destroyInstancesBody->__anon1.compound.statements, MkExpressionStmt(MkListOne(exp)));
3800 ProcessExpressionType(exp);
3801 }
3802 }
3803 else if(classSym && classSym->__anon1.registered && (classSym->__anon1.registered->type == 5))
3804 {
3805 struct Expression * exp = MkExpOp((((void *)0)), DELETE, CopyExpression(inst->exp));
3806
3807 ListAddFront(destroyInstancesBody->__anon1.compound.statements, MkExpressionStmt(MkListOne(exp)));
3808 ProcessExpressionType(exp);
3809 }
3810 __ecereMethod_External_CreateEdge(createInstancesExternal, curExternal, 0);
3811 __ecereMethod_External_CreateEdge(destroyInstancesExternal, curExternal, 0);
3812 break;
3813 }
3814 else
3815 {
3816 CreateInstancesBody();
3817 }
3818 }
3819 {
3820 char className[1024];
3821
3822 className[0] = (char)0;
3823 decl->type = 1;
3824 decl->__anon1.__anon1.specifiers = MkList();
3825 decl->__anon1.__anon1.declarators = MkList();
3826 if(classSym && classSym->__anon1.registered && classSym->__anon1.registered->type == 2)
3827 {
3828 struct __ecereNameSpace__ecere__sys__OldList list =
3829 {
3830 0
3831 };
3832
3833 ProcessInstMembers(inst, inst->exp, &list, 0);
3834 ProcessExpression(inst->exp);
3835 ListAdd(decl->__anon1.__anon1.specifiers, MkSpecifierName(inst->_class->__anon1.__anon1.name));
3836 ListAdd(decl->__anon1.__anon1.declarators, MkInitDeclarator(MkDeclaratorIdentifier(inst->exp->__anon1.__anon1.identifier), MkInitializerAssignment(list.first)));
3837 inst->exp->__anon1.__anon1.identifier = (((void *)0));
3838 }
3839 else if(classSym && classSym->__anon1.registered && classSym->__anon1.registered->type == 3)
3840 {
3841 struct __ecereNameSpace__ecere__sys__OldList list =
3842 {
3843 0
3844 };
3845
3846 ProcessInstMembers(inst, inst->exp, &list, 0);
3847 ProcessExpression(inst->exp);
3848 ListAdd(decl->__anon1.__anon1.specifiers, MkSpecifierName(inst->_class->__anon1.__anon1.name));
3849 ListAdd(decl->__anon1.__anon1.declarators, MkInitDeclarator(MkDeclaratorIdentifier(inst->exp->__anon1.__anon1.identifier), MkInitializerAssignment(list.first)));
3850 inst->exp->__anon1.__anon1.identifier = (((void *)0));
3851 }
3852 else if(classSym && classSym->__anon1.registered && classSym->__anon1.registered->type == 1)
3853 {
3854 struct Expression * exp;
3855
3856 DeclareStruct(curExternal, inst->_class->__anon1.__anon1.name, 0, 1);
3857 ProcessExpression(inst->exp);
3858 {
3859 if(inst->fullSet)
3860 {
3861 ListAdd(decl->__anon1.__anon1.specifiers, MkSpecifierName(inst->_class->__anon1.__anon1.name));
3862 ListAdd(decl->__anon1.__anon1.declarators, MkInitDeclarator(MkDeclaratorIdentifier(inst->exp->__anon1.__anon1.identifier), (((void *)0))));
3863 inst->exp->__anon1.__anon1.identifier = (((void *)0));
3864 }
3865 else
3866 {
3867 struct __ecereNameSpace__ecere__sys__OldList * list = MkList();
3868
3869 if(ProcessBracketInst(inst, list))
3870 {
3871 ListAdd(decl->__anon1.__anon1.specifiers, MkSpecifierName(inst->_class->__anon1.__anon1.name));
3872 ListAdd(decl->__anon1.__anon1.declarators, MkInitDeclarator(MkDeclaratorIdentifier(inst->exp->__anon1.__anon1.identifier), MkInitializerList(list)));
3873 inst->exp->__anon1.__anon1.identifier = (((void *)0));
3874 }
3875 else
3876 {
3877 FreeList(list, (void *)(FreeInitializer));
3878 exp = MkExpBrackets(MkList());
3879 ProcessInstMembers(inst, inst->exp, exp->__anon1.list, 1);
3880 ListAdd(exp->__anon1.list, CopyExpression(inst->exp));
3881 ListAdd(decl->__anon1.__anon1.specifiers, MkSpecifierName(inst->_class->__anon1.__anon1.name));
3882 ListAdd(decl->__anon1.__anon1.declarators, MkInitDeclarator(MkDeclaratorIdentifier(inst->exp->__anon1.__anon1.identifier), MkInitializerAssignment(exp)));
3883 inst->exp->__anon1.__anon1.identifier = (((void *)0));
3884 }
3885 }
3886 }
3887 }
3888 else
3889 {
3890 struct Expression * newCall;
3891
3892 strcpy(className, "__ecereClass_");
3893 if(classSym && classSym->__anon1.registered && classSym->__anon1.registered->type == 5 && classSym->__anon1.registered->templateClass)
3894 {
3895 classSym = FindClass(classSym->__anon1.registered->templateClass->fullName);
3896 FullClassNameCat(className, classSym->string, 1);
3897 }
3898 else
3899 FullClassNameCat(className, inst->_class->__anon1.__anon1.name, 1);
3900 if(classSym)
3901 DeclareClass(curExternal, classSym, className);
3902 if(classSym && classSym->__anon1.registered && classSym->__anon1.registered->type == 5 && (classSym->__anon1.registered->templateClass ? classSym->__anon1.registered->templateClass->fixed : classSym->__anon1.registered->fixed))
3903 {
3904 char size[256];
3905 struct __ecereNameSpace__ecere__com__Class * c = classSym->__anon1.registered->templateClass ? classSym->__anon1.registered->templateClass : classSym->__anon1.registered;
3906 struct Expression * e = MkExpClassSize(MkSpecifierName(c->name));
3907
3908 ProcessExpressionType(e);
3909 sprintf(size, "%d", c->structSize);
3910 newCall = MkExpCall(QMkExpId("ecere::com::eSystem_New0"), MkListOne(e));
3911 }
3912 else
3913 {
3914 newCall = MkExpCall(QMkExpId("ecere::com::eInstance_New"), MkListOne(QMkExpId(className)));
3915 ProcessExpressionType(newCall);
3916 newCall->byReference = 1;
3917 }
3918 if(inst->exp)
3919 {
3920 struct Expression * exp, * newExp;
3921 struct Identifier * id = CopyIdentifier(inst->exp->__anon1.__anon1.identifier);
3922
3923 if(inst->members && (*inst->members).first)
3924 {
3925 newExp = MkExpOp(CopyExpression(inst->exp), '=', newCall);
3926 exp = MkExpBrackets(MkList());
3927 ListAdd(exp->__anon1.list, newExp);
3928 ProcessInstMembers(inst, inst->exp, exp->__anon1.list, 0);
3929 ListAdd(exp->__anon1.list, inst->exp);
3930 ProcessExpression(inst->exp);
3931 inst->exp = (((void *)0));
3932 }
3933 else
3934 exp = newCall;
3935 ListAdd(decl->__anon1.__anon1.specifiers, MkSpecifierName(inst->_class->__anon1.__anon1.name));
3936 ListAdd(decl->__anon1.__anon1.declarators, MkInitDeclarator(MkDeclaratorIdentifier(id), MkInitializerAssignment(exp)));
3937 }
3938 else
3939 FreeExpression(newCall);
3940 }
3941 }
3942 FreeInstance(inst);
3943 }
3944 else
3945 ProcessInstantiation(inst);
3946 break;
3947 }
3948 case 0:
3949 {
3950 if(decl->__anon1.__anon1.specifiers)
3951 {
3952 struct Specifier * spec;
3953
3954 for(spec = (*decl->__anon1.__anon1.specifiers).first; spec; spec = spec->next)
3955 ProcessSpecifier(spec);
3956 }
3957 break;
3958 }
3959 }
3960 }
3961