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