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