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