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