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