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