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