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