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