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