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