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