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