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