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