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