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