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