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