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