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