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