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