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