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