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