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