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