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