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