compiler/libec: (#205) Fixed integer promotions to follow the C standard (6.3.1.1)
[sdk] / compiler / bootstrap / libec / bootstrap / pass3.c
1 /* Code generated from eC source file: pass3.ec */
2 #if defined(_WIN32)
3 #define __runtimePlatform 1
4 #elif defined(__APPLE__)
5 #define __runtimePlatform 3
6 #else
7 #define __runtimePlatform 2
8 #endif
9 #if defined(__GNUC__)
10 typedef long long int64;
11 typedef unsigned long long uint64;
12 #ifndef _WIN32
13 #define __declspec(x)
14 #endif
15 #elif defined(__TINYC__)
16 #include <stdarg.h>
17 #define __builtin_va_list va_list
18 #define __builtin_va_start va_start
19 #define __builtin_va_end va_end
20 #ifdef _WIN32
21 #define strcasecmp stricmp
22 #define strncasecmp strnicmp
23 #define __declspec(x) __attribute__((x))
24 #else
25 #define __declspec(x)
26 #endif
27 typedef long long int64;
28 typedef unsigned long long uint64;
29 #else
30 typedef __int64 int64;
31 typedef unsigned __int64 uint64;
32 #endif
33 #ifdef __BIG_ENDIAN__
34 #define __ENDIAN_PAD(x) (8 - (x))
35 #else
36 #define __ENDIAN_PAD(x) 0
37 #endif
38 #if defined(_WIN32)
39 #   if defined(__GNUC__) || defined(__TINYC__)
40 #      define ecere_stdcall __attribute__((__stdcall__))
41 #      define ecere_gcc_struct __attribute__((gcc_struct))
42 #   else
43 #      define ecere_stdcall __stdcall
44 #      define ecere_gcc_struct
45 #   endif
46 #else
47 #   define ecere_stdcall
48 #   define ecere_gcc_struct
49 #endif
50 #include <stdint.h>
51 #include <sys/types.h>
52 enum yytokentype
53 {
54 IDENTIFIER = 258, CONSTANT = 259, STRING_LITERAL = 260, SIZEOF = 261, PTR_OP = 262, INC_OP = 263, DEC_OP = 264, LEFT_OP = 265, RIGHT_OP = 266, LE_OP = 267, GE_OP = 268, EQ_OP = 269, NE_OP = 270, AND_OP = 271, OR_OP = 272, MUL_ASSIGN = 273, DIV_ASSIGN = 274, MOD_ASSIGN = 275, ADD_ASSIGN = 276, SUB_ASSIGN = 277, LEFT_ASSIGN = 278, RIGHT_ASSIGN = 279, AND_ASSIGN = 280, XOR_ASSIGN = 281, OR_ASSIGN = 282, TYPE_NAME = 283, TYPEDEF = 284, EXTERN = 285, STATIC = 286, AUTO = 287, REGISTER = 288, CHAR = 289, SHORT = 290, INT = 291, UINT = 292, INT64 = 293, LONG = 294, SIGNED = 295, UNSIGNED = 296, FLOAT = 297, DOUBLE = 298, CONST = 299, VOLATILE = 300, VOID = 301, VALIST = 302, STRUCT = 303, UNION = 304, ENUM = 305, ELLIPSIS = 306, CASE = 307, DEFAULT = 308, IF = 309, SWITCH = 310, WHILE = 311, DO = 312, FOR = 313, GOTO = 314, CONTINUE = 315, BREAK = 316, RETURN = 317, IFX = 318, ELSE = 319, CLASS = 320, THISCLASS = 321, CLASS_NAME = 322, PROPERTY = 323, SETPROP = 324, GETPROP = 325, NEWOP = 326, RENEW = 327, DELETE = 328, EXT_DECL = 329, EXT_STORAGE = 330, IMPORT = 331, DEFINE = 332, VIRTUAL = 333, ATTRIB = 334, PUBLIC = 335, PRIVATE = 336, TYPED_OBJECT = 337, ANY_OBJECT = 338, _INCREF = 339, EXTENSION = 340, ASM = 341, TYPEOF = 342, WATCH = 343, STOPWATCHING = 344, FIREWATCHERS = 345, WATCHABLE = 346, CLASS_DESIGNER = 347, CLASS_NO_EXPANSION = 348, CLASS_FIXED = 349, ISPROPSET = 350, CLASS_DEFAULT_PROPERTY = 351, PROPERTY_CATEGORY = 352, CLASS_DATA = 353, CLASS_PROPERTY = 354, SUBCLASS = 355, NAMESPACE = 356, NEW0OP = 357, RENEW0 = 358, VAARG = 359, DBTABLE = 360, DBFIELD = 361, DBINDEX = 362, DATABASE_OPEN = 363, ALIGNOF = 364, ATTRIB_DEP = 365, __ATTRIB = 366, BOOL = 367, _BOOL = 368, _COMPLEX = 369, _IMAGINARY = 370, RESTRICT = 371, THREAD = 372, WIDE_STRING_LITERAL = 373
55 };
56
57 extern int targetPlatform;
58
59 extern struct __ecereNameSpace__ecere__com__Property * __ecereProp_Type_isPointerType;
60
61 struct __ecereNameSpace__ecere__sys__OldList
62 {
63 void *  first;
64 void *  last;
65 int count;
66 unsigned int offset;
67 unsigned int circ;
68 } ecere_gcc_struct;
69
70 struct __ecereNameSpace__ecere__sys__BTNode;
71
72 struct __ecereNameSpace__ecere__com__DataValue
73 {
74 union
75 {
76 char c;
77 unsigned char uc;
78 short s;
79 unsigned short us;
80 int i;
81 unsigned int ui;
82 void *  p;
83 float f;
84 double d;
85 long long i64;
86 uint64 ui64;
87 } ecere_gcc_struct __anon1;
88 } ecere_gcc_struct;
89
90 struct __ecereNameSpace__ecere__com__SerialBuffer
91 {
92 unsigned char *  _buffer;
93 unsigned int count;
94 unsigned int _size;
95 unsigned int pos;
96 } ecere_gcc_struct;
97
98 extern void *  __ecereNameSpace__ecere__com__eSystem_New(unsigned int size);
99
100 extern void *  __ecereNameSpace__ecere__com__eSystem_New0(unsigned int size);
101
102 extern void *  __ecereNameSpace__ecere__com__eSystem_Renew(void *  memory, unsigned int size);
103
104 extern void *  __ecereNameSpace__ecere__com__eSystem_Renew0(void *  memory, unsigned int size);
105
106 extern void __ecereNameSpace__ecere__com__eSystem_Delete(void *  memory);
107
108 struct Context;
109
110 struct Attrib;
111
112 struct Attribute;
113
114 struct Instantiation;
115
116 struct MembersInit;
117
118 struct MemberInit;
119
120 struct ClassFunction;
121
122 struct ClassDefinition;
123
124 struct PropertyDef;
125
126 struct PropertyWatch;
127
128 struct TemplateArgument;
129
130 struct DBTableEntry;
131
132 struct DBIndexItem;
133
134 struct DBTableDef;
135
136 struct CodePosition
137 {
138 int line;
139 int charPos;
140 int pos;
141 int included;
142 } ecere_gcc_struct;
143
144 extern char *  __ecereNameSpace__ecere__sys__CopyString(const char *  string);
145
146 struct ModuleImport;
147
148 struct ClassImport;
149
150 extern void FullClassNameCat(char *  output, const char *  className, unsigned int includeTemplateParams);
151
152 extern int strcmp(const char * , const char * );
153
154 extern char *  strchr(const char * , int);
155
156 extern char *  strcpy(char * , const char * );
157
158 extern size_t strlen(const char * );
159
160 struct __ecereNameSpace__ecere__com__LinkList
161 {
162 void * first;
163 void * last;
164 int count;
165 } ecere_gcc_struct;
166
167 struct __ecereNameSpace__ecere__com__LinkElement
168 {
169 void * prev;
170 void * next;
171 } ecere_gcc_struct;
172
173 extern void Compiler_Error(const char *  format, ...);
174
175 struct __ecereNameSpace__ecere__com__GlobalFunction;
176
177 struct __ecereNameSpace__ecere__com__IteratorPointer;
178
179 extern struct __ecereNameSpace__ecere__sys__OldList *  MkList(void);
180
181 extern void FreeList(struct __ecereNameSpace__ecere__sys__OldList * list, void (*  FreeFunction)(void * ));
182
183 extern struct __ecereNameSpace__ecere__sys__OldList *  MkListOne(void *  item);
184
185 extern struct __ecereNameSpace__ecere__sys__OldList *  ast;
186
187 void __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add(struct __ecereNameSpace__ecere__sys__OldList * this, void *  item);
188
189 unsigned int __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert(struct __ecereNameSpace__ecere__sys__OldList * this, void *  prevItem, void *  item);
190
191 void __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove(struct __ecereNameSpace__ecere__sys__OldList * this, void *  item);
192
193 extern struct Context * curContext;
194
195 extern struct Context * globalContext;
196
197 struct Location
198 {
199 struct CodePosition start;
200 struct CodePosition end;
201 } ecere_gcc_struct;
202
203 extern struct Location yylloc;
204
205 struct ExtDecl
206 {
207 struct Location loc;
208 int type;
209 union
210 {
211 char * s;
212 struct Attrib * attr;
213 } ecere_gcc_struct __anon1;
214 } ecere_gcc_struct;
215
216 extern struct ExtDecl * MkExtDeclString(char * s);
217
218 struct External;
219
220 extern struct External * curExternal;
221
222 extern struct External * DeclareStruct(struct External * neededBy, const char *  name, unsigned int skipNoHead, unsigned int needDereference);
223
224 extern void FreeExternal(struct External * external);
225
226 struct TopoEdge
227 {
228 struct __ecereNameSpace__ecere__com__LinkElement in;
229 struct __ecereNameSpace__ecere__com__LinkElement out;
230 struct External * from;
231 struct External * to;
232 unsigned int breakable;
233 } ecere_gcc_struct;
234
235 struct __ecereNameSpace__ecere__com__Class;
236
237 struct __ecereNameSpace__ecere__com__Instance
238 {
239 void * *  _vTbl;
240 struct __ecereNameSpace__ecere__com__Class * _class;
241 int _refCount;
242 } ecere_gcc_struct;
243
244 extern long long __ecereNameSpace__ecere__com__eClass_GetProperty(struct __ecereNameSpace__ecere__com__Class * _class, const char *  name);
245
246 extern void __ecereNameSpace__ecere__com__eClass_SetProperty(struct __ecereNameSpace__ecere__com__Class * _class, const char *  name, long long value);
247
248 extern void *  __ecereNameSpace__ecere__com__eInstance_New(struct __ecereNameSpace__ecere__com__Class * _class);
249
250 extern void __ecereNameSpace__ecere__com__eInstance_SetMethod(struct __ecereNameSpace__ecere__com__Instance * instance, const char *  name, void *  function);
251
252 extern void __ecereNameSpace__ecere__com__eInstance_IncRef(struct __ecereNameSpace__ecere__com__Instance * instance);
253
254 int __ecereVMethodID___ecereNameSpace__ecere__com__Container_Remove;
255
256 int __ecereVMethodID___ecereNameSpace__ecere__com__Container_Add;
257
258 struct __ecereNameSpace__ecere__com__Property;
259
260 extern void __ecereNameSpace__ecere__com__eInstance_FireSelfWatchers(struct __ecereNameSpace__ecere__com__Instance * instance, struct __ecereNameSpace__ecere__com__Property * _property);
261
262 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);
263
264 extern void __ecereNameSpace__ecere__com__eInstance_Watch(void *  instance, struct __ecereNameSpace__ecere__com__Property * _property, void *  object, void (*  callback)(void * , void * ));
265
266 extern void __ecereNameSpace__ecere__com__eInstance_FireWatchers(struct __ecereNameSpace__ecere__com__Instance * instance, struct __ecereNameSpace__ecere__com__Property * _property);
267
268 struct Specifier;
269
270 extern struct Specifier * CopySpecifier(struct Specifier * spec);
271
272 extern void FreeSpecifier(struct Specifier * spec);
273
274 extern void FreeSpecifierContents(struct Specifier * spec);
275
276 extern struct Specifier * MkSpecifier(int specifier);
277
278 extern struct Specifier * MkSpecifierName(const char *  name);
279
280 struct Declarator;
281
282 extern struct Declarator * SpecDeclFromString(const char *  string, struct __ecereNameSpace__ecere__sys__OldList *  specs, struct Declarator * baseDecl);
283
284 extern void FreeDeclarator(struct Declarator * decl);
285
286 struct TemplateDatatype
287 {
288 struct __ecereNameSpace__ecere__sys__OldList *  specifiers;
289 struct Declarator * decl;
290 } ecere_gcc_struct;
291
292 extern struct Declarator * QMkPtrDecl(const char *  id);
293
294 struct Symbol;
295
296 extern struct Symbol * FindClass(const char *  name);
297
298 struct Identifier;
299
300 extern struct Identifier * MkIdentifier(const char *  string);
301
302 extern struct Specifier * MkStructOrUnion(int type, struct Identifier * id, struct __ecereNameSpace__ecere__sys__OldList * definitions);
303
304 extern struct Declarator * MkDeclaratorIdentifier(struct Identifier * id);
305
306 struct Identifier
307 {
308 struct Identifier * prev;
309 struct Identifier * next;
310 struct Location loc;
311 struct Symbol * classSym;
312 struct Specifier * _class;
313 char *  string;
314 struct Identifier * badID;
315 } ecere_gcc_struct;
316
317 static void InstDeclPassIdentifier(struct Identifier * id)
318 {
319 if(strchr(id->string, ':'))
320 {
321 char newID[1024];
322 int c;
323 char ch;
324 int len;
325
326 strcpy(newID, "__ecereNameSpace__");
327 len = strlen(newID);
328 for(c = 0; (ch = id->string[c]); c++)
329 {
330 if(ch == ':')
331 ch = '_';
332 newID[len++] = ch;
333 }
334 newID[len] = 0;
335 (__ecereNameSpace__ecere__com__eSystem_Delete(id->string), id->string = 0);
336 id->string = __ecereNameSpace__ecere__sys__CopyString(newID);
337 }
338 }
339
340 struct Type;
341
342 struct __ecereNameSpace__ecere__com__Property
343 {
344 struct __ecereNameSpace__ecere__com__Property * prev;
345 struct __ecereNameSpace__ecere__com__Property * next;
346 const char *  name;
347 unsigned int isProperty;
348 int memberAccess;
349 int id;
350 struct __ecereNameSpace__ecere__com__Class * _class;
351 const char *  dataTypeString;
352 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
353 struct Type * dataType;
354 void (*  Set)(void * , int);
355 int (*  Get)(void * );
356 unsigned int (*  IsSet)(void * );
357 void *  data;
358 void *  symbol;
359 int vid;
360 unsigned int conversion;
361 unsigned int watcherOffset;
362 const char *  category;
363 unsigned int compiled;
364 unsigned int selfWatchable;
365 unsigned int isWatchable;
366 } ecere_gcc_struct;
367
368 extern struct Type * ProcessTypeString(const char *  string, unsigned int staticMethod);
369
370 extern struct Type * ProcessType(struct __ecereNameSpace__ecere__sys__OldList * specs, struct Declarator * decl);
371
372 extern void FreeType(struct Type * type);
373
374 struct Expression;
375
376 extern struct Expression * MkExpBrackets(struct __ecereNameSpace__ecere__sys__OldList * expressions);
377
378 extern struct Expression * MoveExpContents(struct Expression * exp);
379
380 extern struct Expression * GetNonBracketsExp(struct Expression * exp);
381
382 extern void FreeExpContents(struct Expression * exp);
383
384 struct TypeName;
385
386 struct TypeName
387 {
388 struct TypeName * prev;
389 struct TypeName * next;
390 struct Location loc;
391 struct __ecereNameSpace__ecere__sys__OldList *  qualifiers;
392 struct Declarator * declarator;
393 int classObjectType;
394 struct Expression * bitCount;
395 } ecere_gcc_struct;
396
397 extern struct TypeName * MkTypeName(struct __ecereNameSpace__ecere__sys__OldList * qualifiers, struct Declarator * declarator);
398
399 extern void FreeTypeName(struct TypeName * typeName);
400
401 extern struct Expression * MkExpCast(struct TypeName * typeName, struct Expression * expression);
402
403 struct Pointer;
404
405 struct Declarator
406 {
407 struct Declarator * prev;
408 struct Declarator * next;
409 struct Location loc;
410 int type;
411 struct Symbol * symbol;
412 struct Declarator * declarator;
413 union
414 {
415 struct Identifier * identifier;
416 struct
417 {
418 struct Expression * exp;
419 struct Expression * posExp;
420 struct Attrib * attrib;
421 } ecere_gcc_struct structDecl;
422 struct
423 {
424 struct Expression * exp;
425 struct Specifier * enumClass;
426 } ecere_gcc_struct array;
427 struct
428 {
429 struct __ecereNameSpace__ecere__sys__OldList * parameters;
430 } ecere_gcc_struct function;
431 struct
432 {
433 struct Pointer * pointer;
434 } ecere_gcc_struct pointer;
435 struct
436 {
437 struct ExtDecl * extended;
438 } ecere_gcc_struct extended;
439 } ecere_gcc_struct __anon1;
440 } ecere_gcc_struct;
441
442 extern struct Pointer * MkPointer(struct __ecereNameSpace__ecere__sys__OldList * qualifiers, struct Pointer * pointer);
443
444 extern struct Declarator * MkDeclaratorPointer(struct Pointer * pointer, struct Declarator * declarator);
445
446 struct Pointer
447 {
448 struct Pointer * prev;
449 struct Pointer * next;
450 struct Location loc;
451 struct __ecereNameSpace__ecere__sys__OldList *  qualifiers;
452 struct Pointer * pointer;
453 } ecere_gcc_struct;
454
455 struct __ecereNameSpace__ecere__sys__BinaryTree;
456
457 struct __ecereNameSpace__ecere__sys__BinaryTree
458 {
459 struct __ecereNameSpace__ecere__sys__BTNode * root;
460 int count;
461 int (*  CompareKey)(struct __ecereNameSpace__ecere__sys__BinaryTree * tree, uintptr_t a, uintptr_t b);
462 void (*  FreeKey)(void *  key);
463 } ecere_gcc_struct;
464
465 struct __ecereNameSpace__ecere__com__Module;
466
467 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);
468
469 struct __ecereNameSpace__ecere__com__DataMember;
470
471 struct __ecereNameSpace__ecere__com__DataMember
472 {
473 struct __ecereNameSpace__ecere__com__DataMember * prev;
474 struct __ecereNameSpace__ecere__com__DataMember * next;
475 const char *  name;
476 unsigned int isProperty;
477 int memberAccess;
478 int id;
479 struct __ecereNameSpace__ecere__com__Class * _class;
480 const char *  dataTypeString;
481 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
482 struct Type * dataType;
483 int type;
484 int offset;
485 int memberID;
486 struct __ecereNameSpace__ecere__sys__OldList members;
487 struct __ecereNameSpace__ecere__sys__BinaryTree membersAlpha;
488 int memberOffset;
489 short structAlignment;
490 short pointerAlignment;
491 } ecere_gcc_struct;
492
493 struct InitDeclarator;
494
495 struct ClassDef;
496
497 struct FunctionDefinition;
498
499 struct __ecereNameSpace__ecere__com__Method;
500
501 struct __ecereNameSpace__ecere__com__ClassTemplateArgument
502 {
503 union
504 {
505 struct
506 {
507 const char *  dataTypeString;
508 struct __ecereNameSpace__ecere__com__Class * dataTypeClass;
509 } ecere_gcc_struct __anon1;
510 struct __ecereNameSpace__ecere__com__DataValue expression;
511 struct
512 {
513 const char *  memberString;
514 union
515 {
516 struct __ecereNameSpace__ecere__com__DataMember * member;
517 struct __ecereNameSpace__ecere__com__Property * prop;
518 struct __ecereNameSpace__ecere__com__Method * method;
519 } ecere_gcc_struct __anon1;
520 } ecere_gcc_struct __anon2;
521 } ecere_gcc_struct __anon1;
522 } ecere_gcc_struct;
523
524 struct __ecereNameSpace__ecere__com__Method
525 {
526 const char *  name;
527 struct __ecereNameSpace__ecere__com__Method * parent;
528 struct __ecereNameSpace__ecere__com__Method * left;
529 struct __ecereNameSpace__ecere__com__Method * right;
530 int depth;
531 int (*  function)();
532 int vid;
533 int type;
534 struct __ecereNameSpace__ecere__com__Class * _class;
535 void *  symbol;
536 const char *  dataTypeString;
537 struct Type * dataType;
538 int memberAccess;
539 } ecere_gcc_struct;
540
541 struct Symbol
542 {
543 char *  string;
544 struct Symbol * parent;
545 struct Symbol * left;
546 struct Symbol * right;
547 int depth;
548 struct Type * type;
549 union
550 {
551 struct __ecereNameSpace__ecere__com__Method * method;
552 struct __ecereNameSpace__ecere__com__Property * _property;
553 struct __ecereNameSpace__ecere__com__Class * registered;
554 } ecere_gcc_struct __anon1;
555 unsigned int notYetDeclared;
556 union
557 {
558 struct
559 {
560 struct External * pointerExternal;
561 struct External * structExternal;
562 } ecere_gcc_struct __anon1;
563 struct
564 {
565 struct External * externalGet;
566 struct External * externalSet;
567 struct External * externalPtr;
568 struct External * externalIsSet;
569 } ecere_gcc_struct __anon2;
570 struct
571 {
572 struct External * methodExternal;
573 struct External * methodCodeExternal;
574 } ecere_gcc_struct __anon3;
575 } ecere_gcc_struct __anon2;
576 unsigned int imported;
577 unsigned int declaredStructSym;
578 struct __ecereNameSpace__ecere__com__Class * _class;
579 unsigned int declaredStruct;
580 unsigned int needConstructor;
581 unsigned int needDestructor;
582 char *  constructorName;
583 char *  structName;
584 char *  className;
585 char *  destructorName;
586 struct ModuleImport * module;
587 struct ClassImport * _import;
588 struct Location nameLoc;
589 unsigned int isParam;
590 unsigned int isRemote;
591 unsigned int isStruct;
592 unsigned int fireWatchersDone;
593 int declaring;
594 unsigned int classData;
595 unsigned int isStatic;
596 char *  shortName;
597 struct __ecereNameSpace__ecere__sys__OldList *  templateParams;
598 struct __ecereNameSpace__ecere__sys__OldList templatedClasses;
599 struct Context * ctx;
600 int isIterator;
601 struct Expression * propCategory;
602 unsigned int mustRegister;
603 } ecere_gcc_struct;
604
605 struct TemplateParameter;
606
607 struct Specifier
608 {
609 struct Specifier * prev;
610 struct Specifier * next;
611 struct Location loc;
612 int type;
613 union
614 {
615 int specifier;
616 struct
617 {
618 struct ExtDecl * extDecl;
619 char *  name;
620 struct Symbol * symbol;
621 struct __ecereNameSpace__ecere__sys__OldList *  templateArgs;
622 struct Specifier * nsSpec;
623 } ecere_gcc_struct __anon1;
624 struct
625 {
626 struct Identifier * id;
627 struct __ecereNameSpace__ecere__sys__OldList *  list;
628 struct __ecereNameSpace__ecere__sys__OldList *  baseSpecs;
629 struct __ecereNameSpace__ecere__sys__OldList *  definitions;
630 unsigned int addNameSpace;
631 struct Context * ctx;
632 struct ExtDecl * extDeclStruct;
633 } ecere_gcc_struct __anon2;
634 struct Expression * expression;
635 struct Specifier * _class;
636 struct TemplateParameter * templateParameter;
637 } ecere_gcc_struct __anon1;
638 } ecere_gcc_struct;
639
640 struct TemplateParameter
641 {
642 struct TemplateParameter * prev;
643 struct TemplateParameter * next;
644 struct Location loc;
645 int type;
646 struct Identifier * identifier;
647 union
648 {
649 struct TemplateDatatype * dataType;
650 int memberType;
651 } ecere_gcc_struct __anon1;
652 struct TemplateArgument * defaultArgument;
653 const char *  dataTypeString;
654 struct Type * baseType;
655 } ecere_gcc_struct;
656
657 struct Type
658 {
659 struct Type * prev;
660 struct Type * next;
661 int refCount;
662 union
663 {
664 struct Symbol * _class;
665 struct
666 {
667 struct __ecereNameSpace__ecere__sys__OldList members;
668 char *  enumName;
669 } ecere_gcc_struct __anon1;
670 struct
671 {
672 struct Type * returnType;
673 struct __ecereNameSpace__ecere__sys__OldList params;
674 struct Symbol * thisClass;
675 unsigned int staticMethod;
676 struct TemplateParameter * thisClassTemplate;
677 } ecere_gcc_struct __anon2;
678 struct
679 {
680 struct __ecereNameSpace__ecere__com__Method * method;
681 struct __ecereNameSpace__ecere__com__Class * methodClass;
682 struct __ecereNameSpace__ecere__com__Class * usedClass;
683 } ecere_gcc_struct __anon3;
684 struct
685 {
686 struct Type * arrayType;
687 int arraySize;
688 struct Expression * arraySizeExp;
689 unsigned int freeExp;
690 struct Symbol * enumClass;
691 } ecere_gcc_struct __anon4;
692 struct Type * type;
693 struct TemplateParameter * templateParameter;
694 } ecere_gcc_struct __anon1;
695 int kind;
696 unsigned int size;
697 char *  name;
698 char *  typeName;
699 struct __ecereNameSpace__ecere__com__Class * thisClassFrom;
700 int promotedFrom;
701 int classObjectType;
702 int alignment;
703 unsigned int offset;
704 int bitFieldCount;
705 int count;
706 int bitMemberSize;
707 unsigned int isSigned : 1;
708 unsigned int constant : 1;
709 unsigned int truth : 1;
710 unsigned int byReference : 1;
711 unsigned int extraParam : 1;
712 unsigned int directClassAccess : 1;
713 unsigned int computing : 1;
714 unsigned int keepCast : 1;
715 unsigned int passAsTemplate : 1;
716 unsigned int dllExport : 1;
717 unsigned int attrStdcall : 1;
718 unsigned int declaredWithStruct : 1;
719 unsigned int typedByReference : 1;
720 unsigned int casted : 1;
721 unsigned int pointerAlignment : 1;
722 unsigned int isLong : 1;
723 unsigned int signedBeforePromotion : 1;
724 } ecere_gcc_struct;
725
726 unsigned int IsVoidPtrCast(struct TypeName * typeName)
727 {
728 unsigned int result = 0;
729 struct Declarator * d = typeName->declarator;
730
731 if(d && d->type == 5 && d->__anon1.pointer.pointer && !d->__anon1.pointer.pointer->pointer)
732 {
733 if(typeName->qualifiers)
734 {
735 struct Specifier * s;
736
737 for(s = (*typeName->qualifiers).first; s; s = s->next)
738 {
739 if(s->type == 0 && s->__anon1.specifier == VOID)
740 result = 1;
741 }
742 }
743 }
744 return result;
745 }
746
747 unsigned int __ecereProp_Type_Get_isPointerType(struct Type * this);
748
749 struct Enumerator;
750
751 struct Enumerator
752 {
753 struct Enumerator * prev;
754 struct Enumerator * next;
755 struct Location loc;
756 struct Identifier * id;
757 struct Expression * exp;
758 } ecere_gcc_struct;
759
760 struct Initializer;
761
762 struct Initializer
763 {
764 struct Initializer * prev;
765 struct Initializer * next;
766 struct Location loc;
767 int type;
768 union
769 {
770 struct Expression * exp;
771 struct __ecereNameSpace__ecere__sys__OldList *  list;
772 } ecere_gcc_struct __anon1;
773 unsigned int isConstant;
774 struct Identifier * id;
775 } ecere_gcc_struct;
776
777 struct InitDeclarator
778 {
779 struct InitDeclarator * prev;
780 struct InitDeclarator * next;
781 struct Location loc;
782 struct Declarator * declarator;
783 struct Initializer * initializer;
784 } ecere_gcc_struct;
785
786 struct Declaration;
787
788 struct ClassDef
789 {
790 struct ClassDef * prev;
791 struct ClassDef * next;
792 struct Location loc;
793 int type;
794 union
795 {
796 struct Declaration * decl;
797 struct ClassFunction * function;
798 struct __ecereNameSpace__ecere__sys__OldList *  defProperties;
799 struct PropertyDef * propertyDef;
800 struct PropertyWatch * propertyWatch;
801 char *  designer;
802 struct Identifier * defaultProperty;
803 struct
804 {
805 struct Identifier * id;
806 struct Initializer * initializer;
807 } ecere_gcc_struct __anon1;
808 } ecere_gcc_struct __anon1;
809 int memberAccess;
810 void *  object;
811 } ecere_gcc_struct;
812
813 struct Declaration
814 {
815 struct Declaration * prev;
816 struct Declaration * next;
817 struct Location loc;
818 int type;
819 union
820 {
821 struct
822 {
823 struct __ecereNameSpace__ecere__sys__OldList *  specifiers;
824 struct __ecereNameSpace__ecere__sys__OldList *  declarators;
825 } ecere_gcc_struct __anon1;
826 struct Instantiation * inst;
827 struct
828 {
829 struct Identifier * id;
830 struct Expression * exp;
831 } ecere_gcc_struct __anon2;
832 } ecere_gcc_struct __anon1;
833 struct Specifier * extStorage;
834 struct Symbol * symbol;
835 int declMode;
836 } ecere_gcc_struct;
837
838 struct External
839 {
840 struct External * prev;
841 struct External * next;
842 struct Location loc;
843 int type;
844 struct Symbol * symbol;
845 union
846 {
847 struct FunctionDefinition * function;
848 struct ClassDefinition * _class;
849 struct Declaration * declaration;
850 char *  importString;
851 struct Identifier * id;
852 struct DBTableDef * table;
853 } ecere_gcc_struct __anon1;
854 int importType;
855 struct External * fwdDecl;
856 struct __ecereNameSpace__ecere__com__Instance * outgoing;
857 struct __ecereNameSpace__ecere__com__Instance * incoming;
858 int nonBreakableIncoming;
859 } ecere_gcc_struct;
860
861 struct External * __ecereMethod_External_ForwardDeclare();
862
863 struct AsmField;
864
865 struct AsmField
866 {
867 struct AsmField * prev;
868 struct AsmField * next;
869 struct Location loc;
870 char *  command;
871 struct Expression * expression;
872 struct Identifier * symbolic;
873 } ecere_gcc_struct;
874
875 struct __ecereNameSpace__ecere__com__NameSpace;
876
877 struct __ecereNameSpace__ecere__com__NameSpace
878 {
879 const char *  name;
880 struct __ecereNameSpace__ecere__com__NameSpace *  btParent;
881 struct __ecereNameSpace__ecere__com__NameSpace *  left;
882 struct __ecereNameSpace__ecere__com__NameSpace *  right;
883 int depth;
884 struct __ecereNameSpace__ecere__com__NameSpace *  parent;
885 struct __ecereNameSpace__ecere__sys__BinaryTree nameSpaces;
886 struct __ecereNameSpace__ecere__sys__BinaryTree classes;
887 struct __ecereNameSpace__ecere__sys__BinaryTree defines;
888 struct __ecereNameSpace__ecere__sys__BinaryTree functions;
889 } ecere_gcc_struct;
890
891 struct __ecereNameSpace__ecere__com__Class
892 {
893 struct __ecereNameSpace__ecere__com__Class * prev;
894 struct __ecereNameSpace__ecere__com__Class * next;
895 const char *  name;
896 int offset;
897 int structSize;
898 void * *  _vTbl;
899 int vTblSize;
900 unsigned int (*  Constructor)(void * );
901 void (*  Destructor)(void * );
902 int offsetClass;
903 int sizeClass;
904 struct __ecereNameSpace__ecere__com__Class * base;
905 struct __ecereNameSpace__ecere__sys__BinaryTree methods;
906 struct __ecereNameSpace__ecere__sys__BinaryTree members;
907 struct __ecereNameSpace__ecere__sys__BinaryTree prop;
908 struct __ecereNameSpace__ecere__sys__OldList membersAndProperties;
909 struct __ecereNameSpace__ecere__sys__BinaryTree classProperties;
910 struct __ecereNameSpace__ecere__sys__OldList derivatives;
911 int memberID;
912 int startMemberID;
913 int type;
914 struct __ecereNameSpace__ecere__com__Instance * module;
915 struct __ecereNameSpace__ecere__com__NameSpace *  nameSpace;
916 const char *  dataTypeString;
917 struct Type * dataType;
918 int typeSize;
919 int defaultAlignment;
920 void (*  Initialize)();
921 int memberOffset;
922 struct __ecereNameSpace__ecere__sys__OldList selfWatchers;
923 const char *  designerClass;
924 unsigned int noExpansion;
925 const char *  defaultProperty;
926 unsigned int comRedefinition;
927 int count;
928 int isRemote;
929 unsigned int internalDecl;
930 void *  data;
931 unsigned int computeSize;
932 short structAlignment;
933 short pointerAlignment;
934 int destructionWatchOffset;
935 unsigned int fixed;
936 struct __ecereNameSpace__ecere__sys__OldList delayedCPValues;
937 int inheritanceAccess;
938 const char *  fullName;
939 void *  symbol;
940 struct __ecereNameSpace__ecere__sys__OldList conversions;
941 struct __ecereNameSpace__ecere__sys__OldList templateParams;
942 struct __ecereNameSpace__ecere__com__ClassTemplateArgument *  templateArgs;
943 struct __ecereNameSpace__ecere__com__Class * templateClass;
944 struct __ecereNameSpace__ecere__sys__OldList templatized;
945 int numParams;
946 unsigned int isInstanceClass;
947 unsigned int byValueSystemClass;
948 } ecere_gcc_struct;
949
950 struct __ecereNameSpace__ecere__com__Application
951 {
952 int argc;
953 const char * *  argv;
954 int exitCode;
955 unsigned int isGUIApp;
956 struct __ecereNameSpace__ecere__sys__OldList allModules;
957 char *  parsedCommand;
958 struct __ecereNameSpace__ecere__com__NameSpace systemNameSpace;
959 } ecere_gcc_struct;
960
961 extern void __ecereNameSpace__ecere__com__PrintLn(struct __ecereNameSpace__ecere__com__Class * class, const void * object, ...);
962
963 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_Declarator;
964
965 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_TypeName;
966
967 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_Specifier;
968
969 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_Expression;
970
971 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__LinkList;
972
973 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_char__PTR_;
974
975 extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_TopoEdge;
976
977 struct __ecereNameSpace__ecere__com__Module
978 {
979 struct __ecereNameSpace__ecere__com__Instance * application;
980 struct __ecereNameSpace__ecere__sys__OldList classes;
981 struct __ecereNameSpace__ecere__sys__OldList defines;
982 struct __ecereNameSpace__ecere__sys__OldList functions;
983 struct __ecereNameSpace__ecere__sys__OldList modules;
984 struct __ecereNameSpace__ecere__com__Instance * prev;
985 struct __ecereNameSpace__ecere__com__Instance * next;
986 const char *  name;
987 void *  library;
988 void *  Unload;
989 int importType;
990 int origImportType;
991 struct __ecereNameSpace__ecere__com__NameSpace privateNameSpace;
992 struct __ecereNameSpace__ecere__com__NameSpace publicNameSpace;
993 } ecere_gcc_struct;
994
995 static void ReplaceByInstancePtr(struct Specifier * spec, struct Declarator ** declPtr, int type)
996 {
997 struct Declarator * decl = *declPtr;
998
999 if(decl && decl->type == 5)
1000 {
1001 if(type == 2)
1002 ;
1003 else
1004 decl->__anon1.pointer.pointer = MkPointer((((void *)0)), decl->__anon1.pointer.pointer);
1005 }
1006 else
1007 {
1008 struct Declarator * newDecl = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Declarator);
1009
1010 if(decl)
1011 {
1012 *newDecl = *decl;
1013 decl->declarator = newDecl;
1014 }
1015 else
1016 decl = newDecl;
1017 decl->type = 5;
1018 decl->__anon1.pointer.pointer = MkPointer((((void *)0)), (((void *)0)));
1019 *declPtr = decl;
1020 }
1021 }
1022
1023 static int ReplaceClassSpec(struct __ecereNameSpace__ecere__sys__OldList * specs, struct Specifier * spec, unsigned int param)
1024 {
1025 if(spec->type == 8)
1026 {
1027 struct TemplateParameter * parameter = spec->__anon1.templateParameter;
1028
1029 if(!param && parameter->dataTypeString)
1030 {
1031 struct __ecereNameSpace__ecere__sys__OldList * newSpecs = MkList();
1032 struct Declarator * decl = SpecDeclFromString(parameter->dataTypeString, newSpecs, (((void *)0)));
1033
1034 if((*newSpecs).first)
1035 {
1036 struct Specifier * newSpec = CopySpecifier((*newSpecs).first);
1037
1038 *spec = *newSpec;
1039 ((newSpec ? (__ecereClass_Specifier->Destructor ? __ecereClass_Specifier->Destructor((void *)newSpec) : 0, __ecereNameSpace__ecere__com__eSystem_Delete(newSpec)) : 0), newSpec = 0);
1040 }
1041 FreeList(newSpecs, (void *)(FreeSpecifier));
1042 if(decl)
1043 {
1044 unsigned int isPointer = decl->type == 5;
1045
1046 if(decl)
1047 FreeDeclarator(decl);
1048 if(isPointer)
1049 return 1;
1050 }
1051 }
1052 else if(!param && parameter->__anon1.dataType)
1053 {
1054 struct __ecereNameSpace__ecere__sys__OldList * newSpecs = parameter->__anon1.dataType->specifiers;
1055 struct Declarator * decl = parameter->__anon1.dataType->decl;
1056
1057 if((*newSpecs).first)
1058 {
1059 struct Specifier * newSpec = CopySpecifier((*newSpecs).first);
1060
1061 *spec = *newSpec;
1062 ((newSpec ? (__ecereClass_Specifier->Destructor ? __ecereClass_Specifier->Destructor((void *)newSpec) : 0, __ecereNameSpace__ecere__com__eSystem_Delete(newSpec)) : 0), newSpec = 0);
1063 }
1064 if(decl)
1065 {
1066 unsigned int isPointer = decl->type == 5;
1067
1068 if(isPointer)
1069 return 1;
1070 }
1071 }
1072 else
1073 {
1074 spec->type = 1;
1075 spec->__anon1.__anon1.name = __ecereNameSpace__ecere__sys__CopyString("uint64");
1076 spec->__anon1.__anon1.symbol = FindClass("uint64");
1077 }
1078 }
1079 if(spec->type == 1 || spec->type == 7)
1080 {
1081 struct Symbol * classSym = spec->__anon1.__anon1.symbol;
1082
1083 if(spec->type == 7)
1084 {
1085 classSym = FindClass("ecere::com::Class");
1086 }
1087 if(classSym)
1088 {
1089 struct __ecereNameSpace__ecere__com__Class * _class = classSym->__anon1.registered;
1090
1091 FreeSpecifierContents(spec);
1092 spec->type = 1;
1093 if(_class && _class->type == 1)
1094 {
1095 char name[1024];
1096
1097 name[0] = 0;
1098 FullClassNameCat(name, _class->fullName, 0);
1099 FreeSpecifierContents(spec);
1100 spec->type = 3;
1101 spec->__anon1.__anon2.baseSpecs = (((void *)0));
1102 spec->__anon1.__anon2.id = MkIdentifier(name);
1103 spec->__anon1.__anon2.list = (((void *)0));
1104 spec->__anon1.__anon2.definitions = (((void *)0));
1105 spec->__anon1.__anon2.ctx = (((void *)0));
1106 spec->__anon1.__anon2.addNameSpace = 0;
1107 }
1108 else if(_class && _class->type == 5)
1109 {
1110 char name[1024] = "";
1111
1112 FullClassNameCat(name, _class->fullName, 0);
1113 spec->type = 3;
1114 spec->__anon1.__anon2.baseSpecs = (((void *)0));
1115 spec->__anon1.__anon2.id = MkIdentifier(name);
1116 spec->__anon1.__anon2.list = (((void *)0));
1117 spec->__anon1.__anon2.definitions = (((void *)0));
1118 spec->__anon1.__anon2.ctx = (((void *)0));
1119 spec->__anon1.__anon2.addNameSpace = 0;
1120 }
1121 else if(_class)
1122 {
1123 if((_class->type != 1000 || !strcmp(_class->fullName, "enum") || (_class->dataTypeString && !strcmp(_class->dataTypeString, "char *")) || !strcmp(_class->fullName, "uint64") || !strcmp(_class->fullName, "uint32") || !strcmp(_class->fullName, "uint16") || !strcmp(_class->fullName, "uintptr") || !strcmp(_class->fullName, "intptr") || !strcmp(_class->fullName, "uintsize") || !strcmp(_class->fullName, "intsize") || !strcmp(_class->fullName, "uint") || !strcmp(_class->fullName, "byte")))
1124 {
1125 if(_class->dataTypeString)
1126 {
1127 if(!strcmp(_class->dataTypeString, "uint64") || !strcmp(_class->dataTypeString, "uint32") || !strcmp(_class->dataTypeString, "uint16") || !strcmp(_class->dataTypeString, "uintptr") || !strcmp(_class->dataTypeString, "intptr") || !strcmp(_class->dataTypeString, "uintsize") || !strcmp(_class->dataTypeString, "intsize") || !strcmp(_class->dataTypeString, "uint") || !strcmp(_class->dataTypeString, "byte"))
1128 {
1129 if(!_class->dataType)
1130 _class->dataType = ProcessTypeString(_class->dataTypeString, 0);
1131 if(_class->dataType && _class->dataType->kind == 8)
1132 classSym = _class->dataType->__anon1._class;
1133 else
1134 classSym = FindClass(_class->dataTypeString);
1135 _class = classSym ? classSym->__anon1.registered : (((void *)0));
1136 }
1137 spec->__anon1.__anon1.name = __ecereNameSpace__ecere__sys__CopyString(!strcmp(_class->dataTypeString, "char *") ? "char" : _class->dataTypeString);
1138 spec->__anon1.__anon1.symbol = (((void *)0));
1139 }
1140 else
1141 {
1142 spec->__anon1.__anon1.name = __ecereNameSpace__ecere__sys__CopyString((((void *)0)));
1143 spec->__anon1.__anon1.symbol = (((void *)0));
1144 }
1145 }
1146 else if(!_class->base)
1147 {
1148 spec->type = 0;
1149 spec->__anon1.specifier = VOID;
1150 return 1;
1151 }
1152 }
1153 else
1154 {
1155 spec->type = 3;
1156 spec->__anon1.__anon2.id = MkIdentifier("__ecereNameSpace__ecere__com__Instance");
1157 spec->__anon1.__anon2.list = (((void *)0));
1158 spec->__anon1.__anon2.baseSpecs = (((void *)0));
1159 spec->__anon1.__anon2.definitions = (((void *)0));
1160 spec->__anon1.__anon2.ctx = (((void *)0));
1161 spec->__anon1.__anon2.addNameSpace = 0;
1162 }
1163 if(_class && _class->dataTypeString && !strcmp(_class->dataTypeString, "char *"))
1164 return 1;
1165 if(!_class || _class->type == 0 || _class->type == 5)
1166 return 1;
1167 else if(param && _class->type == 1)
1168 return 2;
1169 }
1170 }
1171 else if(spec->type == 0)
1172 {
1173 if(spec->__anon1.specifier == ANY_OBJECT || spec->__anon1.specifier == CLASS)
1174 {
1175 spec->__anon1.specifier = CONST;
1176 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add(specs, MkSpecifier(VOID));
1177 return 1;
1178 }
1179 }
1180 return 0;
1181 }
1182
1183 void TopoSort(struct __ecereNameSpace__ecere__sys__OldList * input)
1184 {
1185 struct __ecereNameSpace__ecere__sys__OldList L =
1186 {
1187 0, 0, 0, 0, 0
1188 };
1189 struct __ecereNameSpace__ecere__sys__OldList S =
1190 {
1191 0, 0, 0, 0, 0
1192 };
1193 struct __ecereNameSpace__ecere__sys__OldList B =
1194 {
1195 0, 0, 0, 0, 0
1196 };
1197 struct External * n, * next;
1198
1199 for(n = (*input).first; n; n = next)
1200 {
1201 next = n->next;
1202 if(n->type == 1 && !n->__anon1.declaration)
1203 {
1204 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove((&*input), n);
1205 if(n->symbol && n->symbol->__anon2.__anon1.structExternal == n)
1206 n->symbol->__anon2.__anon1.structExternal = (((void *)0));
1207 FreeExternal(n);
1208 }
1209 else if(!((struct __ecereNameSpace__ecere__com__LinkList *)(((char *)n->incoming + 0 + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->count)
1210 {
1211 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove((&*input), n);
1212 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add(&S, n);
1213 }
1214 else if(!n->nonBreakableIncoming)
1215 {
1216 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove((&*input), n);
1217 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add(&B, n);
1218 }
1219 }
1220 while(1)
1221 {
1222 struct TopoEdge * e, * ne;
1223
1224 if((n = S.first))
1225 {
1226 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove(&S, (struct __ecereNameSpace__ecere__com__IteratorPointer *)n);
1227 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add(&L, n);
1228 for(e = ((struct __ecereNameSpace__ecere__com__LinkList *)(((char *)n->outgoing + 0 + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->first; e; e = ne)
1229 {
1230 struct External * m = e->to;
1231 struct __ecereNameSpace__ecere__sys__OldList * list;
1232
1233 if(m->nonBreakableIncoming)
1234 {
1235 list = input;
1236 }
1237 else
1238 {
1239 list = &B;
1240 }
1241 if(!(*list).count)
1242 __ecereNameSpace__ecere__com__PrintLn(__ecereClass_char__PTR_, "!!! Something's wrong !!!", (void *)0);
1243 ne = e->out.next;
1244 if(!e->breakable)
1245 {
1246 m->nonBreakableIncoming--;
1247 }
1248 ((void (*)(struct __ecereNameSpace__ecere__com__Instance *, struct __ecereNameSpace__ecere__com__IteratorPointer * it))__extension__ ({
1249 struct __ecereNameSpace__ecere__com__Instance * __internal_ClassInst = n->outgoing;
1250
1251 __internal_ClassInst ? __internal_ClassInst->_vTbl : __ecereClass___ecereNameSpace__ecere__com__LinkList->_vTbl;
1252 })[__ecereVMethodID___ecereNameSpace__ecere__com__Container_Remove])(n->outgoing, (struct __ecereNameSpace__ecere__com__IteratorPointer *)e);
1253 ((void (*)(struct __ecereNameSpace__ecere__com__Instance *, struct __ecereNameSpace__ecere__com__IteratorPointer * it))__extension__ ({
1254 struct __ecereNameSpace__ecere__com__Instance * __internal_ClassInst = m->incoming;
1255
1256 __internal_ClassInst ? __internal_ClassInst->_vTbl : __ecereClass___ecereNameSpace__ecere__com__LinkList->_vTbl;
1257 })[__ecereVMethodID___ecereNameSpace__ecere__com__Container_Remove])(m->incoming, (struct __ecereNameSpace__ecere__com__IteratorPointer *)e);
1258 ((e ? (__ecereClass_TopoEdge->Destructor ? __ecereClass_TopoEdge->Destructor((void *)e) : 0, __ecereNameSpace__ecere__com__eSystem_Delete(e)) : 0), e = 0);
1259 if(!((struct __ecereNameSpace__ecere__com__LinkList *)(((char *)m->incoming + 0 + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->count)
1260 {
1261 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove((&*list), m);
1262 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add(&S, m);
1263 }
1264 else if(!m->nonBreakableIncoming)
1265 {
1266 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove((&*list), m);
1267 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add(&B, m);
1268 }
1269 }
1270 }
1271 else if((n = B.first))
1272 {
1273 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove(&B, (struct __ecereNameSpace__ecere__com__IteratorPointer *)n);
1274 for(e = ((struct __ecereNameSpace__ecere__com__LinkList *)(((char *)n->incoming + 0 + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->first; e; e = ne)
1275 {
1276 struct TopoEdge * e2, * n2;
1277 struct External * m = e->from;
1278 struct External * f;
1279
1280 f = __ecereMethod_External_ForwardDeclare(m);
1281 ne = e->in.next;
1282 {
1283 struct External * c, * next;
1284
1285 for(c = (*input).first; c; c = next)
1286 {
1287 next = c->next;
1288 if(!((struct __ecereNameSpace__ecere__com__LinkList *)(((char *)c->incoming + 0 + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->count)
1289 {
1290 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove((&*input), c);
1291 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add(&S, c);
1292 }
1293 else if(!c->nonBreakableIncoming)
1294 {
1295 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove((&*input), c);
1296 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add(&B, c);
1297 }
1298 }
1299 }
1300 for(e2 = ((struct __ecereNameSpace__ecere__com__LinkList *)(((char *)m->outgoing + 0 + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->first; e2; e2 = n2)
1301 {
1302 n2 = e2->out.next;
1303 if(e2->breakable)
1304 {
1305 struct External * to = e2->to;
1306
1307 if(e2 == e)
1308 ;
1309 else
1310 ;
1311 e2->breakable = 0;
1312 e2->from = f;
1313 ((void (*)(struct __ecereNameSpace__ecere__com__Instance *, struct __ecereNameSpace__ecere__com__IteratorPointer * it))__extension__ ({
1314 struct __ecereNameSpace__ecere__com__Instance * __internal_ClassInst = m->outgoing;
1315
1316 __internal_ClassInst ? __internal_ClassInst->_vTbl : __ecereClass___ecereNameSpace__ecere__com__LinkList->_vTbl;
1317 })[__ecereVMethodID___ecereNameSpace__ecere__com__Container_Remove])(m->outgoing, (struct __ecereNameSpace__ecere__com__IteratorPointer *)e2);
1318 ((struct __ecereNameSpace__ecere__com__IteratorPointer * (*)(struct __ecereNameSpace__ecere__com__Instance *, uint64 value))__extension__ ({
1319 struct __ecereNameSpace__ecere__com__Instance * __internal_ClassInst = f->outgoing;
1320
1321 __internal_ClassInst ? __internal_ClassInst->_vTbl : __ecereClass___ecereNameSpace__ecere__com__LinkList->_vTbl;
1322 })[__ecereVMethodID___ecereNameSpace__ecere__com__Container_Add])(f->outgoing, (uint64)(uintptr_t)(e2));
1323 to->nonBreakableIncoming++;
1324 if(e2 != e && to->nonBreakableIncoming == 1)
1325 {
1326 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove(&B, to);
1327 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add((&*input), to);
1328 }
1329 }
1330 }
1331 if(!((struct __ecereNameSpace__ecere__com__LinkList *)(((char *)f->incoming + 0 + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->count)
1332 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add(&S, f);
1333 else if(!f->nonBreakableIncoming)
1334 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add(&B, f);
1335 else
1336 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add((&*input), f);
1337 if(S.first)
1338 break;
1339 }
1340 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add((&*input), n);
1341 }
1342 else
1343 {
1344 if((*input).count)
1345 {
1346 Compiler_Error("declarations cycles found\n");
1347 }
1348 else
1349 *input = L;
1350 break;
1351 }
1352 }
1353 for(n = (*input).first; n; n = next)
1354 {
1355 next = n->next;
1356 if(n->type == 1 && (!n->__anon1.declaration || ((!n->__anon1.declaration->__anon1.__anon1.specifiers || !(*n->__anon1.declaration->__anon1.__anon1.specifiers).count) && (!n->__anon1.declaration->__anon1.__anon1.declarators || !(*n->__anon1.declaration->__anon1.__anon1.declarators).count))))
1357 {
1358 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove((&*input), n);
1359 if(n->symbol && n->symbol->__anon2.__anon1.structExternal == n)
1360 n->symbol->__anon2.__anon1.structExternal = (((void *)0));
1361 FreeExternal(n);
1362 }
1363 }
1364 }
1365
1366 void __ecereUnregisterModule_pass3(struct __ecereNameSpace__ecere__com__Instance * module)
1367 {
1368
1369 }
1370
1371 struct Statement;
1372
1373 typedef union YYSTYPE
1374 {
1375 int specifierType;
1376 int i;
1377 int declMode;
1378 struct Identifier * id;
1379 struct Expression * exp;
1380 struct Specifier * specifier;
1381 struct __ecereNameSpace__ecere__sys__OldList * list;
1382 struct Enumerator * enumerator;
1383 struct Declarator * declarator;
1384 struct Pointer * pointer;
1385 struct Initializer * initializer;
1386 struct InitDeclarator * initDeclarator;
1387 struct TypeName * typeName;
1388 struct Declaration * declaration;
1389 struct Statement * stmt;
1390 struct FunctionDefinition * function;
1391 struct External * external;
1392 struct Context * context;
1393 struct AsmField * asmField;
1394 struct Attrib * attrib;
1395 struct ExtDecl * extDecl;
1396 struct Attribute * attribute;
1397 struct Instantiation * instance;
1398 struct MembersInit * membersInit;
1399 struct MemberInit * memberInit;
1400 struct ClassFunction * classFunction;
1401 struct ClassDefinition * _class;
1402 struct ClassDef * classDef;
1403 struct PropertyDef * prop;
1404 char * string;
1405 struct Symbol * symbol;
1406 struct PropertyWatch * propertyWatch;
1407 struct TemplateParameter * templateParameter;
1408 struct TemplateArgument * templateArgument;
1409 struct TemplateDatatype * templateDatatype;
1410 struct DBTableEntry * dbtableEntry;
1411 struct DBIndexItem * dbindexItem;
1412 struct DBTableDef * dbtableDef;
1413 } ecere_gcc_struct YYSTYPE;
1414
1415 extern YYSTYPE yylval;
1416
1417 struct Expression
1418 {
1419 struct Expression * prev;
1420 struct Expression * next;
1421 struct Location loc;
1422 int type;
1423 union
1424 {
1425 struct
1426 {
1427 char *  constant;
1428 struct Identifier * identifier;
1429 } ecere_gcc_struct __anon1;
1430 struct Statement * compound;
1431 struct Instantiation * instance;
1432 struct
1433 {
1434 char *  string;
1435 unsigned int intlString;
1436 unsigned int wideString;
1437 } ecere_gcc_struct __anon2;
1438 struct __ecereNameSpace__ecere__sys__OldList *  list;
1439 struct
1440 {
1441 struct __ecereNameSpace__ecere__sys__OldList * specifiers;
1442 struct Declarator * decl;
1443 } ecere_gcc_struct _classExp;
1444 struct
1445 {
1446 struct Identifier * id;
1447 } ecere_gcc_struct classData;
1448 struct
1449 {
1450 struct Expression * exp;
1451 struct __ecereNameSpace__ecere__sys__OldList * arguments;
1452 struct Location argLoc;
1453 } ecere_gcc_struct call;
1454 struct
1455 {
1456 struct Expression * exp;
1457 struct __ecereNameSpace__ecere__sys__OldList * index;
1458 } ecere_gcc_struct index;
1459 struct
1460 {
1461 struct Expression * exp;
1462 struct Identifier * member;
1463 int memberType;
1464 unsigned int thisPtr;
1465 } ecere_gcc_struct member;
1466 struct
1467 {
1468 int op;
1469 struct Expression * exp1;
1470 struct Expression * exp2;
1471 } ecere_gcc_struct op;
1472 struct TypeName * typeName;
1473 struct Specifier * _class;
1474 struct
1475 {
1476 struct TypeName * typeName;
1477 struct Expression * exp;
1478 } ecere_gcc_struct cast;
1479 struct
1480 {
1481 struct Expression * cond;
1482 struct __ecereNameSpace__ecere__sys__OldList * exp;
1483 struct Expression * elseExp;
1484 } ecere_gcc_struct cond;
1485 struct
1486 {
1487 struct TypeName * typeName;
1488 struct Expression * size;
1489 } ecere_gcc_struct _new;
1490 struct
1491 {
1492 struct TypeName * typeName;
1493 struct Expression * size;
1494 struct Expression * exp;
1495 } ecere_gcc_struct _renew;
1496 struct
1497 {
1498 char * table;
1499 struct Identifier * id;
1500 } ecere_gcc_struct db;
1501 struct
1502 {
1503 struct Expression * ds;
1504 struct Expression * name;
1505 } ecere_gcc_struct dbopen;
1506 struct
1507 {
1508 struct TypeName * typeName;
1509 struct Initializer * initializer;
1510 } ecere_gcc_struct initializer;
1511 struct
1512 {
1513 struct Expression * exp;
1514 struct TypeName * typeName;
1515 } ecere_gcc_struct vaArg;
1516 } ecere_gcc_struct __anon1;
1517 unsigned int debugValue;
1518 struct __ecereNameSpace__ecere__com__DataValue val;
1519 uint64 address;
1520 unsigned int hasAddress;
1521 struct Type * expType;
1522 struct Type * destType;
1523 unsigned int usage;
1524 int tempCount;
1525 unsigned int byReference;
1526 unsigned int isConstant;
1527 unsigned int addedThis;
1528 unsigned int needCast;
1529 unsigned int thisPtr;
1530 unsigned int opDestType;
1531 unsigned int needTemplateCast;
1532 } ecere_gcc_struct;
1533
1534 struct Statement
1535 {
1536 struct Statement * prev;
1537 struct Statement * next;
1538 struct Location loc;
1539 int type;
1540 union
1541 {
1542 struct __ecereNameSpace__ecere__sys__OldList *  expressions;
1543 struct
1544 {
1545 struct Identifier * id;
1546 struct Statement * stmt;
1547 } ecere_gcc_struct labeled;
1548 struct
1549 {
1550 struct Expression * exp;
1551 struct Statement * stmt;
1552 } ecere_gcc_struct caseStmt;
1553 struct
1554 {
1555 struct __ecereNameSpace__ecere__sys__OldList * declarations;
1556 struct __ecereNameSpace__ecere__sys__OldList * statements;
1557 struct Context * context;
1558 unsigned int isSwitch;
1559 } ecere_gcc_struct compound;
1560 struct
1561 {
1562 struct __ecereNameSpace__ecere__sys__OldList * exp;
1563 struct Statement * stmt;
1564 struct Statement * elseStmt;
1565 } ecere_gcc_struct ifStmt;
1566 struct
1567 {
1568 struct __ecereNameSpace__ecere__sys__OldList * exp;
1569 struct Statement * stmt;
1570 } ecere_gcc_struct switchStmt;
1571 struct
1572 {
1573 struct __ecereNameSpace__ecere__sys__OldList * exp;
1574 struct Statement * stmt;
1575 } ecere_gcc_struct whileStmt;
1576 struct
1577 {
1578 struct __ecereNameSpace__ecere__sys__OldList * exp;
1579 struct Statement * stmt;
1580 } ecere_gcc_struct doWhile;
1581 struct
1582 {
1583 struct Statement * init;
1584 struct Statement * check;
1585 struct __ecereNameSpace__ecere__sys__OldList * increment;
1586 struct Statement * stmt;
1587 } ecere_gcc_struct forStmt;
1588 struct
1589 {
1590 struct Identifier * id;
1591 } ecere_gcc_struct gotoStmt;
1592 struct
1593 {
1594 struct Specifier * spec;
1595 char * statements;
1596 struct __ecereNameSpace__ecere__sys__OldList * inputFields;
1597 struct __ecereNameSpace__ecere__sys__OldList * outputFields;
1598 struct __ecereNameSpace__ecere__sys__OldList * clobberedFields;
1599 } ecere_gcc_struct asmStmt;
1600 struct
1601 {
1602 struct Expression * watcher;
1603 struct Expression * object;
1604 struct __ecereNameSpace__ecere__sys__OldList * watches;
1605 } ecere_gcc_struct _watch;
1606 struct
1607 {
1608 struct Identifier * id;
1609 struct __ecereNameSpace__ecere__sys__OldList * exp;
1610 struct __ecereNameSpace__ecere__sys__OldList * filter;
1611 struct Statement * stmt;
1612 } ecere_gcc_struct forEachStmt;
1613 struct Declaration * decl;
1614 } ecere_gcc_struct __anon1;
1615 } ecere_gcc_struct;
1616
1617 struct FunctionDefinition
1618 {
1619 struct FunctionDefinition * prev;
1620 struct FunctionDefinition * next;
1621 struct Location loc;
1622 struct __ecereNameSpace__ecere__sys__OldList *  specifiers;
1623 struct Declarator * declarator;
1624 struct __ecereNameSpace__ecere__sys__OldList *  declarations;
1625 struct Statement * body;
1626 struct __ecereNameSpace__ecere__com__Class * _class;
1627 struct __ecereNameSpace__ecere__sys__OldList attached;
1628 int declMode;
1629 struct Type * type;
1630 struct Symbol * propSet;
1631 int tempCount;
1632 unsigned int propertyNoThis;
1633 } ecere_gcc_struct;
1634
1635 static void AddPointerCast(struct Expression * e)
1636 {
1637 struct Type * src = e->expType;
1638
1639 if(src && (src->kind == 20 || src->kind == 8))
1640 {
1641 if(e->type != 11 || !IsVoidPtrCast(e->__anon1.cast.typeName))
1642 {
1643 if(src)
1644 src->refCount++;
1645 if(src->kind == 20 && src->__anon1.templateParameter && src->__anon1.templateParameter->type == 0)
1646 {
1647 struct Type * newType = (((void *)0));
1648
1649 if(src->__anon1.templateParameter->dataTypeString)
1650 newType = ProcessTypeString(src->__anon1.templateParameter->dataTypeString, 0);
1651 else if(src->__anon1.templateParameter->__anon1.dataType)
1652 newType = ProcessType(src->__anon1.templateParameter->__anon1.dataType->specifiers, src->__anon1.templateParameter->__anon1.dataType->decl);
1653 if(newType)
1654 {
1655 FreeType(src);
1656 src = newType;
1657 }
1658 }
1659 if(src && src->kind == 8 && src->__anon1._class)
1660 {
1661 struct __ecereNameSpace__ecere__com__Class * sc = src->__anon1._class->__anon1.registered;
1662
1663 if(src->thisClassFrom && src->thisClassFrom->base)
1664 sc = src->thisClassFrom;
1665 if(sc && (sc->type == 1 || sc->type == 5))
1666 {
1667 struct Type * dest = e->destType;
1668
1669 if(dest && (dest->kind == 20 || dest->kind == 8))
1670 {
1671 if(dest)
1672 dest->refCount++;
1673 if(dest->kind == 20 && dest->__anon1.templateParameter && dest->__anon1.templateParameter->type == 0)
1674 {
1675 struct Type * newType = (((void *)0));
1676
1677 if(dest->__anon1.templateParameter->dataTypeString)
1678 newType = ProcessTypeString(dest->__anon1.templateParameter->dataTypeString, 0);
1679 else if(dest->__anon1.templateParameter->__anon1.dataType)
1680 newType = ProcessType(dest->__anon1.templateParameter->__anon1.dataType->specifiers, dest->__anon1.templateParameter->__anon1.dataType->decl);
1681 if(newType)
1682 {
1683 FreeType(dest);
1684 dest = newType;
1685 }
1686 }
1687 if(!dest->passAsTemplate && dest->kind == 8 && dest->__anon1._class && dest->__anon1._class->__anon1.registered)
1688 {
1689 struct __ecereNameSpace__ecere__com__Class * dc = dest->__anon1._class->__anon1.registered;
1690
1691 if(sc->templateClass)
1692 sc = sc->templateClass;
1693 if(dc->templateClass)
1694 dc = dc->templateClass;
1695 if(dc->base && sc != dc)
1696 {
1697 e->__anon1.cast.exp = MkExpBrackets(MkListOne(MoveExpContents(e)));
1698 e->type = 11;
1699 e->__anon1.typeName = MkTypeName(MkListOne(MkSpecifier(VOID)), QMkPtrDecl((((void *)0))));
1700 }
1701 }
1702 FreeType(dest);
1703 }
1704 }
1705 }
1706 FreeType(src);
1707 }
1708 }
1709 else if(src && src->kind == 22 && e->destType && e->destType->classObjectType)
1710 {
1711 struct Expression * nbExp = GetNonBracketsExp(e);
1712
1713 if(nbExp->type != 11 || !IsVoidPtrCast(nbExp->__anon1.cast.typeName))
1714 {
1715 e->__anon1.cast.exp = MkExpBrackets(MkListOne(MoveExpContents(e)));
1716 e->type = 11;
1717 e->__anon1.typeName = MkTypeName(MkListOne(MkSpecifier(VOID)), QMkPtrDecl((((void *)0))));
1718 }
1719 }
1720 }
1721
1722 static void InstDeclPassDeclaration(struct Declaration *  decl);
1723
1724 static void InstDeclPassSpecifier(struct Specifier * spec, unsigned int byRefTypedObject)
1725 {
1726 switch(spec->type)
1727 {
1728 case 0:
1729 if(spec->__anon1.specifier == TYPED_OBJECT)
1730 {
1731 spec->type = 5;
1732 spec->__anon1.__anon1.extDecl = MkExtDeclString(__ecereNameSpace__ecere__sys__CopyString(byRefTypedObject ? "struct __ecereNameSpace__ecere__com__Class * class, void *" : "struct __ecereNameSpace__ecere__com__Class * class, const void *"));
1733 DeclareStruct(curExternal, "ecere::com::Class", 0, 1);
1734 }
1735 break;
1736 case 1:
1737 break;
1738 case 2:
1739 {
1740 struct Enumerator * e;
1741
1742 if(spec->__anon1.__anon2.list)
1743 {
1744 for(e = (*spec->__anon1.__anon2.list).first; e; e = e->next)
1745 {
1746 }
1747 }
1748 break;
1749 }
1750 case 3:
1751 case 4:
1752 {
1753 if(spec->__anon1.__anon2.definitions)
1754 {
1755 struct ClassDef * def;
1756
1757 for(def = (*spec->__anon1.__anon2.definitions).first; def; def = def->next)
1758 if(def->__anon1.decl)
1759 InstDeclPassDeclaration(def->__anon1.decl);
1760 }
1761 if(spec->__anon1.__anon2.id)
1762 InstDeclPassIdentifier(spec->__anon1.__anon2.id);
1763 break;
1764 }
1765 case 5:
1766 if(spec->__anon1.__anon1.extDecl && spec->__anon1.__anon1.extDecl->type == 0 && spec->__anon1.__anon1.extDecl->__anon1.s)
1767 {
1768 if(!strcmp(spec->__anon1.__anon1.extDecl->__anon1.s, "dllexport"))
1769 {
1770 struct Specifier * prevSpec;
1771
1772 (__ecereNameSpace__ecere__com__eSystem_Delete(spec->__anon1.__anon1.extDecl->__anon1.s), spec->__anon1.__anon1.extDecl->__anon1.s = 0);
1773 for(prevSpec = spec->prev; prevSpec; prevSpec = prevSpec->prev)
1774 if(prevSpec->type == 0 && prevSpec->__anon1.specifier == EXTERN)
1775 break;
1776 if(prevSpec)
1777 {
1778 if(targetPlatform == 1)
1779 spec->__anon1.__anon1.extDecl->__anon1.s = __ecereNameSpace__ecere__sys__CopyString("__declspec(dllexport)");
1780 else
1781 spec->__anon1.__anon1.extDecl->__anon1.s = __ecereNameSpace__ecere__sys__CopyString("__attribute__ ((visibility(\"default\")))");
1782 }
1783 else
1784 {
1785 if(targetPlatform == 1)
1786 spec->__anon1.__anon1.extDecl->__anon1.s = __ecereNameSpace__ecere__sys__CopyString("extern __declspec(dllexport)");
1787 else
1788 spec->__anon1.__anon1.extDecl->__anon1.s = __ecereNameSpace__ecere__sys__CopyString("extern __attribute__ ((visibility(\"default\")))");
1789 }
1790 }
1791 else if(!strcmp(spec->__anon1.__anon1.extDecl->__anon1.s, "stdcall") || !strcmp(spec->__anon1.__anon1.extDecl->__anon1.s, "_stdcall") || !strcmp(spec->__anon1.__anon1.extDecl->__anon1.s, "__stdcall") || !strcmp(spec->__anon1.__anon1.extDecl->__anon1.s, "__stdcall__"))
1792 {
1793 (__ecereNameSpace__ecere__com__eSystem_Delete(spec->__anon1.__anon1.extDecl->__anon1.s), spec->__anon1.__anon1.extDecl->__anon1.s = 0);
1794 spec->__anon1.__anon1.extDecl->__anon1.s = __ecereNameSpace__ecere__sys__CopyString("ecere_stdcall");
1795 }
1796 }
1797 break;
1798 }
1799 }
1800
1801 void InstDeclPassTypeName(struct TypeName *  type, unsigned int param);
1802
1803 static void InstDeclPassDeclarator(struct Declarator * decl)
1804 {
1805 switch(decl->type)
1806 {
1807 case 0:
1808 if(decl->declarator)
1809 InstDeclPassDeclarator(decl->declarator);
1810 break;
1811 case 1:
1812 {
1813 if(decl->__anon1.identifier)
1814 InstDeclPassIdentifier(decl->__anon1.identifier);
1815 break;
1816 }
1817 case 2:
1818 if(decl->declarator)
1819 InstDeclPassDeclarator(decl->declarator);
1820 break;
1821 case 3:
1822 if(decl->declarator)
1823 InstDeclPassDeclarator(decl->declarator);
1824 break;
1825 case 4:
1826 {
1827 if(decl->declarator)
1828 InstDeclPassDeclarator(decl->declarator);
1829 if(decl->__anon1.function.parameters)
1830 {
1831 struct TypeName * type;
1832
1833 if(decl->declarator)
1834 InstDeclPassDeclarator(decl->declarator);
1835 for(type = (*decl->__anon1.function.parameters).first; type; type = type->next)
1836 {
1837 unsigned int typedObject = 0;
1838 struct Specifier * spec = (((void *)0));
1839
1840 if(type->qualifiers)
1841 {
1842 spec = (struct Specifier *)(*type->qualifiers).first;
1843 if(spec && spec->type == 1 && !strcmp(spec->__anon1.__anon1.name, "class"))
1844 typedObject = 1;
1845 }
1846 InstDeclPassTypeName(type, 1);
1847 if(typedObject)
1848 {
1849 struct TypeName * _class = (_class = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_TypeName), _class->qualifiers = MkListOne(MkStructOrUnion(3, MkIdentifier("__ecereNameSpace__ecere__com__Class"), (((void *)0)))), _class->declarator = MkDeclaratorPointer(MkPointer((((void *)0)), (((void *)0))), MkDeclaratorIdentifier(MkIdentifier("class"))), _class);
1850
1851 DeclareStruct(curExternal, "ecere::com::Class", 0, 1);
1852 __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert((&*decl->__anon1.function.parameters), spec->prev, _class);
1853 }
1854 }
1855 }
1856 break;
1857 }
1858 case 5:
1859 case 6:
1860 case 7:
1861 if((decl->type == 6 || decl->type == 7) && decl->__anon1.extended.extended)
1862 {
1863 if(decl->__anon1.extended.extended->type == 0 && decl->__anon1.extended.extended->__anon1.s && !strcmp(decl->__anon1.extended.extended->__anon1.s, "dllexport"))
1864 {
1865 (__ecereNameSpace__ecere__com__eSystem_Delete(decl->__anon1.extended.extended->__anon1.s), decl->__anon1.extended.extended->__anon1.s = 0);
1866 if(targetPlatform == 1)
1867 decl->__anon1.extended.extended->__anon1.s = __ecereNameSpace__ecere__sys__CopyString("extern __declspec(dllexport)");
1868 else
1869 decl->__anon1.extended.extended->__anon1.s = __ecereNameSpace__ecere__sys__CopyString("extern __attribute__ ((visibility(\"default\")))");
1870 }
1871 else if(decl->__anon1.extended.extended->type == 0 && decl->__anon1.extended.extended->__anon1.s && (!strcmp(decl->__anon1.extended.extended->__anon1.s, "stdcall") || !strcmp(decl->__anon1.extended.extended->__anon1.s, "_stdcall") || !strcmp(decl->__anon1.extended.extended->__anon1.s, "__stdcall") || !strcmp(decl->__anon1.extended.extended->__anon1.s, "__stdcall__")))
1872 {
1873 (__ecereNameSpace__ecere__com__eSystem_Delete(decl->__anon1.extended.extended->__anon1.s), decl->__anon1.extended.extended->__anon1.s = 0);
1874 decl->__anon1.extended.extended->__anon1.s = __ecereNameSpace__ecere__sys__CopyString("ecere_stdcall");
1875 }
1876 }
1877 if(decl->declarator)
1878 InstDeclPassDeclarator(decl->declarator);
1879 break;
1880 }
1881 }
1882
1883 void InstDeclPassTypeName(struct TypeName * type, unsigned int param)
1884 {
1885 if(type->qualifiers)
1886 {
1887 struct Specifier * spec;
1888
1889 for(spec = (*type->qualifiers).first; spec; spec = spec->next)
1890 {
1891 int result;
1892
1893 if((result = ReplaceClassSpec(type->qualifiers, spec, param)))
1894 ReplaceByInstancePtr(spec, &type->declarator, result);
1895 else
1896 {
1897 struct Symbol * classSym = (spec->type == 1) ? spec->__anon1.__anon1.symbol : (((void *)0));
1898
1899 if(type->classObjectType && (!classSym || (classSym && classSym->__anon1.registered && (classSym->__anon1.registered->type == 4 || classSym->__anon1.registered->type == 2 || classSym->__anon1.registered->type == 3))))
1900 ReplaceByInstancePtr(spec, &type->declarator, 2);
1901 }
1902 InstDeclPassSpecifier(spec, type->declarator && type->declarator->type == 5);
1903 }
1904 }
1905 if(type->declarator)
1906 InstDeclPassDeclarator(type->declarator);
1907 }
1908
1909 static void InstDeclPassExpression(struct Expression *  exp);
1910
1911 static void InstDeclPassInitializer(struct Initializer * init)
1912 {
1913 switch(init->type)
1914 {
1915 case 0:
1916 if(init->__anon1.exp)
1917 {
1918 InstDeclPassExpression(init->__anon1.exp);
1919 AddPointerCast(init->__anon1.exp);
1920 }
1921 break;
1922 case 1:
1923 {
1924 struct Initializer * i;
1925
1926 for(i = (*init->__anon1.list).first; i; i = i->next)
1927 InstDeclPassInitializer(i);
1928 break;
1929 }
1930 }
1931 }
1932
1933 static void InstDeclPassStatement(struct Statement * stmt)
1934 {
1935 switch(stmt->type)
1936 {
1937 case 14:
1938 if(stmt->__anon1.decl)
1939 InstDeclPassDeclaration(stmt->__anon1.decl);
1940 break;
1941 case 0:
1942 InstDeclPassStatement(stmt->__anon1.labeled.stmt);
1943 break;
1944 case 1:
1945 if(stmt->__anon1.caseStmt.exp)
1946 InstDeclPassExpression(stmt->__anon1.caseStmt.exp);
1947 if(stmt->__anon1.caseStmt.stmt)
1948 InstDeclPassStatement(stmt->__anon1.caseStmt.stmt);
1949 break;
1950 case 2:
1951 {
1952 struct Declaration * decl;
1953 struct Statement * s;
1954 struct Context * prevContext = curContext;
1955
1956 if(!stmt->__anon1.compound.isSwitch)
1957 curContext = stmt->__anon1.compound.context;
1958 if(stmt->__anon1.compound.declarations)
1959 {
1960 for(decl = (*stmt->__anon1.compound.declarations).first; decl; decl = decl->next)
1961 InstDeclPassDeclaration(decl);
1962 }
1963 if(stmt->__anon1.compound.statements)
1964 {
1965 for(s = (*stmt->__anon1.compound.statements).first; s; s = s->next)
1966 InstDeclPassStatement(s);
1967 }
1968 curContext = prevContext;
1969 break;
1970 }
1971 case 3:
1972 {
1973 if(stmt->__anon1.expressions)
1974 {
1975 struct Expression * exp;
1976
1977 for(exp = (*stmt->__anon1.expressions).first; exp; exp = exp->next)
1978 InstDeclPassExpression(exp);
1979 }
1980 break;
1981 }
1982 case 4:
1983 {
1984 if(stmt->__anon1.ifStmt.exp)
1985 {
1986 struct Expression * exp;
1987
1988 for(exp = (*stmt->__anon1.ifStmt.exp).first; exp; exp = exp->next)
1989 InstDeclPassExpression(exp);
1990 }
1991 if(stmt->__anon1.ifStmt.stmt)
1992 InstDeclPassStatement(stmt->__anon1.ifStmt.stmt);
1993 if(stmt->__anon1.ifStmt.elseStmt)
1994 InstDeclPassStatement(stmt->__anon1.ifStmt.elseStmt);
1995 break;
1996 }
1997 case 5:
1998 {
1999 struct Expression * exp;
2000
2001 if(stmt->__anon1.switchStmt.exp)
2002 {
2003 for(exp = (*stmt->__anon1.switchStmt.exp).first; exp; exp = exp->next)
2004 InstDeclPassExpression(exp);
2005 }
2006 InstDeclPassStatement(stmt->__anon1.switchStmt.stmt);
2007 break;
2008 }
2009 case 6:
2010 {
2011 struct Expression * exp;
2012
2013 if(stmt->__anon1.whileStmt.exp)
2014 {
2015 for(exp = (*stmt->__anon1.whileStmt.exp).first; exp; exp = exp->next)
2016 InstDeclPassExpression(exp);
2017 }
2018 InstDeclPassStatement(stmt->__anon1.whileStmt.stmt);
2019 break;
2020 }
2021 case 7:
2022 {
2023 if(stmt->__anon1.doWhile.exp)
2024 {
2025 struct Expression * exp;
2026
2027 for(exp = (*stmt->__anon1.doWhile.exp).first; exp; exp = exp->next)
2028 InstDeclPassExpression(exp);
2029 }
2030 if(stmt->__anon1.doWhile.stmt)
2031 InstDeclPassStatement(stmt->__anon1.doWhile.stmt);
2032 break;
2033 }
2034 case 8:
2035 {
2036 struct Expression * exp;
2037
2038 if(stmt->__anon1.forStmt.init)
2039 InstDeclPassStatement(stmt->__anon1.forStmt.init);
2040 if(stmt->__anon1.forStmt.check)
2041 InstDeclPassStatement(stmt->__anon1.forStmt.check);
2042 if(stmt->__anon1.forStmt.increment)
2043 {
2044 for(exp = (*stmt->__anon1.forStmt.increment).first; exp; exp = exp->next)
2045 InstDeclPassExpression(exp);
2046 }
2047 if(stmt->__anon1.forStmt.stmt)
2048 InstDeclPassStatement(stmt->__anon1.forStmt.stmt);
2049 break;
2050 }
2051 case 9:
2052 break;
2053 case 10:
2054 break;
2055 case 11:
2056 break;
2057 case 12:
2058 {
2059 struct Expression * exp;
2060
2061 if(stmt->__anon1.expressions)
2062 {
2063 for(exp = (*stmt->__anon1.expressions).first; exp; exp = exp->next)
2064 InstDeclPassExpression(exp);
2065 AddPointerCast((*stmt->__anon1.expressions).last);
2066 }
2067 break;
2068 }
2069 case 13:
2070 {
2071 struct AsmField * field;
2072
2073 if(stmt->__anon1.asmStmt.inputFields)
2074 {
2075 for(field = (*stmt->__anon1.asmStmt.inputFields).first; field; field = field->next)
2076 if(field->expression)
2077 InstDeclPassExpression(field->expression);
2078 }
2079 if(stmt->__anon1.asmStmt.outputFields)
2080 {
2081 for(field = (*stmt->__anon1.asmStmt.outputFields).first; field; field = field->next)
2082 if(field->expression)
2083 InstDeclPassExpression(field->expression);
2084 }
2085 if(stmt->__anon1.asmStmt.clobberedFields)
2086 {
2087 for(field = (*stmt->__anon1.asmStmt.clobberedFields).first; field; field = field->next)
2088 if(field->expression)
2089 InstDeclPassExpression(field->expression);
2090 }
2091 break;
2092 }
2093 }
2094 }
2095
2096 static void InstDeclPassDeclaration(struct Declaration * decl)
2097 {
2098 switch(decl->type)
2099 {
2100 case 1:
2101 {
2102 if(decl->__anon1.__anon1.specifiers)
2103 {
2104 struct Specifier * spec;
2105
2106 for(spec = (*decl->__anon1.__anon1.specifiers).first; spec; spec = spec->next)
2107 {
2108 int type;
2109
2110 if((type = ReplaceClassSpec(decl->__anon1.__anon1.specifiers, spec, 0)))
2111 {
2112 struct InitDeclarator * d;
2113
2114 if(decl->__anon1.__anon1.declarators)
2115 {
2116 for(d = (*decl->__anon1.__anon1.declarators).first; d; d = d->next)
2117 ReplaceByInstancePtr(spec, &d->declarator, type);
2118 }
2119 }
2120 InstDeclPassSpecifier(spec, 0);
2121 }
2122 }
2123 if(decl->__anon1.__anon1.declarators)
2124 {
2125 struct InitDeclarator * d;
2126
2127 for(d = (*decl->__anon1.__anon1.declarators).first; d; d = d->next)
2128 {
2129 InstDeclPassDeclarator(d->declarator);
2130 if(d->initializer)
2131 InstDeclPassInitializer(d->initializer);
2132 }
2133 }
2134 break;
2135 }
2136 case 0:
2137 {
2138 if(decl->__anon1.__anon1.specifiers)
2139 {
2140 struct Specifier * spec;
2141
2142 for(spec = (*decl->__anon1.__anon1.specifiers).first; spec; spec = spec->next)
2143 {
2144 int type;
2145
2146 if((type = ReplaceClassSpec(decl->__anon1.__anon1.specifiers, spec, 0)))
2147 {
2148 if(decl->__anon1.__anon1.declarators)
2149 {
2150 struct Declarator * d;
2151
2152 for(d = (*decl->__anon1.__anon1.declarators).first; d; d = d->next)
2153 ReplaceByInstancePtr(spec, &d, type);
2154 }
2155 }
2156 InstDeclPassSpecifier(spec, 0);
2157 }
2158 }
2159 if(decl->__anon1.__anon1.declarators)
2160 {
2161 struct Declarator * d;
2162
2163 for(d = (*decl->__anon1.__anon1.declarators).first; d; d = d->next)
2164 InstDeclPassDeclarator(d);
2165 }
2166 break;
2167 }
2168 case 2:
2169 break;
2170 }
2171 }
2172
2173 static void InstDeclPassExpression(struct Expression * exp)
2174 {
2175 switch(exp->type)
2176 {
2177 case 0:
2178 {
2179 if(exp->__anon1.__anon1.identifier)
2180 InstDeclPassIdentifier(exp->__anon1.__anon1.identifier);
2181 break;
2182 }
2183 case 2:
2184 break;
2185 case 3:
2186 break;
2187 case 4:
2188 if(exp->__anon1.op.exp1)
2189 InstDeclPassExpression(exp->__anon1.op.exp1);
2190 if(exp->__anon1.op.exp2)
2191 {
2192 InstDeclPassExpression(exp->__anon1.op.exp2);
2193 if(exp->__anon1.op.op != '=' && exp->__anon1.op.exp1 && exp->__anon1.op.exp1->expType && exp->__anon1.op.exp1->expType->kind == 13 && exp->__anon1.op.exp1->expType->__anon1.type && exp->__anon1.op.exp1->expType->__anon1.type->kind == 20 && 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)
2194 {
2195 struct Expression * e = exp->__anon1.op.exp2;
2196
2197 e->__anon1.cast.exp = MkExpBrackets(MkListOne(MoveExpContents(e)));
2198 e->type = 11;
2199 e->__anon1.typeName = MkTypeName(MkListOne(MkSpecifier(VOID)), QMkPtrDecl((((void *)0))));
2200 e = exp->__anon1.op.exp1;
2201 e->__anon1.cast.exp = MkExpBrackets(MkListOne(MoveExpContents(e)));
2202 e->type = 11;
2203 e->__anon1.typeName = MkTypeName(MkListOne(MkSpecifier(VOID)), QMkPtrDecl((((void *)0))));
2204 }
2205 else if(exp->__anon1.op.exp1 && (exp->__anon1.op.op == '=' || exp->__anon1.op.op == EQ_OP || exp->__anon1.op.op == NE_OP))
2206 AddPointerCast(exp->__anon1.op.exp2);
2207 }
2208 break;
2209 case 32:
2210 case 5:
2211 {
2212 struct Expression * e;
2213
2214 for(e = (*exp->__anon1.list).first; e; e = e->next)
2215 InstDeclPassExpression(e);
2216 break;
2217 }
2218 case 6:
2219 {
2220 struct Expression * e;
2221
2222 InstDeclPassExpression(exp->__anon1.index.exp);
2223 for(e = (*exp->__anon1.index.index).first; e; e = e->next)
2224 InstDeclPassExpression(e);
2225 break;
2226 }
2227 case 7:
2228 {
2229 struct Expression * e;
2230
2231 InstDeclPassExpression(exp->__anon1.call.exp);
2232 if(exp->__anon1.call.arguments)
2233 {
2234 for(e = (*exp->__anon1.call.arguments).first; e; e = e->next)
2235 {
2236 unsigned int addCast = 0;
2237
2238 InstDeclPassExpression(e);
2239 AddPointerCast(e);
2240 if(e->expType && e->expType->kind == 13 && e->expType->__anon1.type && (e->expType->__anon1.type->kind == 8 || (e->expType->__anon1.type->kind == 13 && e->expType->__anon1.type->__anon1.type && e->expType->__anon1.type->__anon1.type->kind != 0)) && e->destType && e->destType->kind == 13 && e->destType->__anon1.type && e->destType->__anon1.type->kind == 13 && e->destType->__anon1.type->__anon1.type && e->destType->__anon1.type->__anon1.type->kind == 0)
2241 addCast = 1;
2242 else if(e->expType && e->expType->kind == 8 && e->expType->__anon1._class && e->expType->__anon1._class->__anon1.registered && e->expType->__anon1._class->__anon1.registered->type == 1 && e->byReference && e->destType && e->destType->kind == 8 && e->destType->classObjectType && e->destType->byReference)
2243 addCast = 1;
2244 if(addCast && (e->type != 11 || !IsVoidPtrCast(e->__anon1.cast.typeName)))
2245 {
2246 e->__anon1.cast.exp = MkExpBrackets(MkListOne(MoveExpContents(e)));
2247 e->type = 11;
2248 e->__anon1.typeName = MkTypeName(MkListOne(MkSpecifier(VOID)), QMkPtrDecl((((void *)0))));
2249 }
2250 }
2251 }
2252 break;
2253 }
2254 case 8:
2255 {
2256 if(exp->__anon1.member.exp)
2257 InstDeclPassExpression(exp->__anon1.member.exp);
2258 break;
2259 }
2260 case 9:
2261 {
2262 if(exp->__anon1.member.exp)
2263 InstDeclPassExpression(exp->__anon1.member.exp);
2264 break;
2265 }
2266 case 10:
2267 InstDeclPassTypeName(exp->__anon1.typeName, 0);
2268 break;
2269 case 11:
2270 {
2271 struct Type * type = exp->expType;
2272
2273 if(type && type->kind == 8 && type->__anon1._class->__anon1.registered && type->__anon1._class->__anon1.registered->type == 1 && !exp->needCast)
2274 {
2275 if(exp->destType && exp->destType->classObjectType == 2 && exp->destType->byReference)
2276 {
2277 FreeTypeName(exp->__anon1.cast.typeName);
2278 exp->__anon1.cast.typeName = MkTypeName(MkListOne(MkSpecifier(VOID)), MkDeclaratorPointer(MkPointer((((void *)0)), MkPointer((((void *)0)), (((void *)0)))), (((void *)0))));
2279 }
2280 else
2281 {
2282 struct Expression * castExp = exp->__anon1.cast.exp;
2283 struct Expression * prev = exp->prev, * next = exp->next;
2284
2285 exp->__anon1.cast.exp = (((void *)0));
2286 FreeExpContents(exp);
2287 FreeType(exp->expType);
2288 FreeType(exp->destType);
2289 *exp = *castExp;
2290 ((castExp ? (__ecereClass_Expression->Destructor ? __ecereClass_Expression->Destructor((void *)castExp) : 0, __ecereNameSpace__ecere__com__eSystem_Delete(castExp)) : 0), castExp = 0);
2291 exp->prev = prev;
2292 exp->next = next;
2293 InstDeclPassExpression(exp);
2294 }
2295 }
2296 else
2297 {
2298 if(exp->expType && exp->expType->kind == 13)
2299 {
2300 if(exp->__anon1.cast.exp && exp->__anon1.cast.exp->expType && exp->__anon1.cast.exp->expType->kind == 20 && !__ecereProp_Type_Get_isPointerType(exp->__anon1.cast.exp->expType))
2301 exp->__anon1.cast.exp = MkExpCast(MkTypeName(MkListOne(MkSpecifierName("uintptr")), (((void *)0))), exp->__anon1.cast.exp);
2302 }
2303 InstDeclPassTypeName(exp->__anon1.cast.typeName, ((unsigned int)((exp->usage & 0x4) >> 2)));
2304 if(exp->__anon1.cast.exp)
2305 {
2306 if(exp->expType && exp->expType->kind == 20 && exp->destType && (exp->destType->passAsTemplate || (!exp->destType->__anon1.templateParameter || (!exp->destType->__anon1.templateParameter->__anon1.dataType && !exp->destType->__anon1.templateParameter->dataTypeString))) && exp->__anon1.cast.exp->expType && !exp->__anon1.cast.exp->expType->passAsTemplate && __ecereProp_Type_Get_isPointerType(exp->__anon1.cast.exp->expType))
2307 exp->__anon1.cast.exp = MkExpCast(MkTypeName(MkListOne(MkSpecifierName("uintptr")), (((void *)0))), exp->__anon1.cast.exp);
2308 InstDeclPassExpression(exp->__anon1.cast.exp);
2309 }
2310 }
2311 break;
2312 }
2313 case 12:
2314 {
2315 struct Expression * e;
2316
2317 InstDeclPassExpression(exp->__anon1.cond.cond);
2318 for(e = (*exp->__anon1.cond.exp).first; e; e = e->next)
2319 InstDeclPassExpression(e);
2320 InstDeclPassExpression(exp->__anon1.cond.elseExp);
2321 break;
2322 }
2323 case 23:
2324 {
2325 InstDeclPassStatement(exp->__anon1.compound);
2326 break;
2327 }
2328 case 34:
2329 {
2330 InstDeclPassExpression(exp->__anon1.vaArg.exp);
2331 break;
2332 }
2333 case 33:
2334 {
2335 InstDeclPassTypeName(exp->__anon1.initializer.typeName, 0);
2336 InstDeclPassInitializer(exp->__anon1.initializer.initializer);
2337 break;
2338 }
2339 }
2340 }
2341
2342 void ProcessInstanceDeclarations()
2343 {
2344 struct External * external;
2345
2346 curContext = globalContext;
2347 for(external = (*ast).first; external; external = external->next)
2348 {
2349 curExternal = external;
2350 if(external->type == 0)
2351 {
2352 struct FunctionDefinition * func = external->__anon1.function;
2353
2354 if(func->specifiers)
2355 {
2356 struct Specifier * spec;
2357
2358 for(spec = (*func->specifiers).first; spec; spec = spec->next)
2359 {
2360 int type;
2361
2362 if((type = ReplaceClassSpec(func->specifiers, spec, 0)))
2363 ReplaceByInstancePtr(spec, &func->declarator, type);
2364 InstDeclPassSpecifier(spec, 0);
2365 }
2366 }
2367 InstDeclPassDeclarator(func->declarator);
2368 if(func->body)
2369 InstDeclPassStatement(func->body);
2370 }
2371 else if(external->type == 1)
2372 {
2373 if(external->__anon1.declaration)
2374 InstDeclPassDeclaration(external->__anon1.declaration);
2375 }
2376 }
2377 TopoSort(ast);
2378 }
2379
2380 void __ecereRegisterModule_pass3(struct __ecereNameSpace__ecere__com__Instance * module)
2381 {
2382 struct __ecereNameSpace__ecere__com__Class __attribute__((unused)) * class;
2383
2384 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("InstDeclPassTypeName", "void InstDeclPassTypeName(TypeName type, bool param)", InstDeclPassTypeName, module, 2);
2385 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("IsVoidPtrCast", "bool IsVoidPtrCast(TypeName typeName)", IsVoidPtrCast, module, 2);
2386 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("TopoSort", "void TopoSort(ecere::sys::OldList * input)", TopoSort, module, 2);
2387 __ecereNameSpace__ecere__com__eSystem_RegisterFunction("ProcessInstanceDeclarations", "void ProcessInstanceDeclarations(void)", ProcessInstanceDeclarations, module, 1);
2388 }
2389