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