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