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