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