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