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