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