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