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