/* Code generated from eC source file: pass0.ec */ #if defined(_WIN32) #define __runtimePlatform 1 #elif defined(__APPLE__) #define __runtimePlatform 3 #else #define __runtimePlatform 2 #endif #if defined(__GNUC__) typedef long long int64; typedef unsigned long long uint64; #ifndef _WIN32 #define __declspec(x) #endif #elif defined(__TINYC__) #include #define __builtin_va_list va_list #define __builtin_va_start va_start #define __builtin_va_end va_end #ifdef _WIN32 #define strcasecmp stricmp #define strncasecmp strnicmp #define __declspec(x) __attribute__((x)) #else #define __declspec(x) #endif typedef long long int64; typedef unsigned long long uint64; #else typedef __int64 int64; typedef unsigned __int64 uint64; #endif #ifdef __BIG_ENDIAN__ #define __ENDIAN_PAD(x) (8 - (x)) #else #define __ENDIAN_PAD(x) 0 #endif #if defined(_WIN32) # if defined(__GNUC__) || defined(__TINYC__) # define ecere_stdcall __attribute__((__stdcall__)) # define ecere_gcc_struct __attribute__((gcc_struct)) # else # define ecere_stdcall __stdcall # define ecere_gcc_struct # endif #else # define ecere_stdcall # define ecere_gcc_struct #endif #include #include enum yytokentype { IDENTIFIER = 258, CONSTANT = 259, STRING_LITERAL = 260, SIZEOF = 261, PTR_OP = 262, INC_OP = 263, DEC_OP = 264, LEFT_OP = 265, RIGHT_OP = 266, LE_OP = 267, GE_OP = 268, EQ_OP = 269, NE_OP = 270, AND_OP = 271, OR_OP = 272, MUL_ASSIGN = 273, DIV_ASSIGN = 274, MOD_ASSIGN = 275, ADD_ASSIGN = 276, SUB_ASSIGN = 277, LEFT_ASSIGN = 278, RIGHT_ASSIGN = 279, AND_ASSIGN = 280, XOR_ASSIGN = 281, OR_ASSIGN = 282, TYPE_NAME = 283, TYPEDEF = 284, EXTERN = 285, STATIC = 286, AUTO = 287, REGISTER = 288, CHAR = 289, SHORT = 290, INT = 291, UINT = 292, INT64 = 293, LONG = 294, SIGNED = 295, UNSIGNED = 296, FLOAT = 297, DOUBLE = 298, CONST = 299, VOLATILE = 300, VOID = 301, VALIST = 302, STRUCT = 303, UNION = 304, ENUM = 305, ELLIPSIS = 306, CASE = 307, DEFAULT = 308, IF = 309, SWITCH = 310, WHILE = 311, DO = 312, FOR = 313, GOTO = 314, CONTINUE = 315, BREAK = 316, RETURN = 317, IFX = 318, ELSE = 319, CLASS = 320, THISCLASS = 321, CLASS_NAME = 322, PROPERTY = 323, SETPROP = 324, GETPROP = 325, NEWOP = 326, RENEW = 327, DELETE = 328, EXT_DECL = 329, EXT_STORAGE = 330, IMPORT = 331, DEFINE = 332, VIRTUAL = 333, ATTRIB = 334, PUBLIC = 335, PRIVATE = 336, TYPED_OBJECT = 337, ANY_OBJECT = 338, _INCREF = 339, EXTENSION = 340, ASM = 341, TYPEOF = 342, WATCH = 343, STOPWATCHING = 344, FIREWATCHERS = 345, WATCHABLE = 346, CLASS_DESIGNER = 347, CLASS_NO_EXPANSION = 348, CLASS_FIXED = 349, ISPROPSET = 350, CLASS_DEFAULT_PROPERTY = 351, PROPERTY_CATEGORY = 352, CLASS_DATA = 353, CLASS_PROPERTY = 354, SUBCLASS = 355, NAMESPACE = 356, NEW0OP = 357, RENEW0 = 358, VAARG = 359, DBTABLE = 360, DBFIELD = 361, DBINDEX = 362, DATABASE_OPEN = 363, ALIGNOF = 364, ATTRIB_DEP = 365, __ATTRIB = 366, BOOL = 367, _BOOL = 368, _COMPLEX = 369, _IMAGINARY = 370, RESTRICT = 371, THREAD = 372, WIDE_STRING_LITERAL = 373, BUILTIN_OFFSETOF = 374 }; extern unsigned int inCompiler; extern int declMode; extern int structDeclMode; extern const char * sourceFile; extern struct __ecereNameSpace__ecere__com__Property * __ecereProp_Type_isPointerType; struct __ecereNameSpace__ecere__sys__OldList { void * first; void * last; int count; unsigned int offset; unsigned int circ; } ecere_gcc_struct; struct __ecereNameSpace__ecere__sys__BTNode; struct __ecereNameSpace__ecere__com__DataValue { union { char c; unsigned char uc; short s; unsigned short us; int i; unsigned int ui; void * p; float f; double d; long long i64; uint64 ui64; } ecere_gcc_struct __anon1; } ecere_gcc_struct; struct __ecereNameSpace__ecere__com__SerialBuffer { unsigned char * _buffer; unsigned int count; unsigned int _size; unsigned int pos; } ecere_gcc_struct; extern void * __ecereNameSpace__ecere__com__eSystem_New(unsigned int size); extern void * __ecereNameSpace__ecere__com__eSystem_New0(unsigned int size); extern void * __ecereNameSpace__ecere__com__eSystem_Renew(void * memory, unsigned int size); extern void * __ecereNameSpace__ecere__com__eSystem_Renew0(void * memory, unsigned int size); extern void __ecereNameSpace__ecere__com__eSystem_Delete(void * memory); struct Enumerator; struct Pointer; struct InitDeclarator; struct AsmField; struct Attrib; struct ExtDecl; struct Attribute; struct PropertyWatch; struct TemplateParameter; struct TemplateArgument; struct TemplateDatatype; struct DBTableEntry; struct DBIndexItem; struct DBTableDef; struct CodePosition { int line; int charPos; int pos; int included; } ecere_gcc_struct; extern char * strcat(char * , const char * ); extern size_t strlen(const char * ); extern int strncmp(const char * , const char * , size_t n); struct ModuleImport; struct ClassImport; extern void Compiler_Error(const char * format, ...); extern const char * __ecereNameSpace__ecere__GetTranslatedString(const char * name, const char * string, const char * stringAndContext); struct __ecereNameSpace__ecere__com__LinkList { void * first; void * last; int count; } ecere_gcc_struct; extern char * __ecereNameSpace__ecere__sys__CopyString(const char * string); extern char * strcpy(char * , const char * ); struct __ecereNameSpace__ecere__com__LinkElement { void * prev; void * next; } ecere_gcc_struct; extern char * strstr(const char * , const char * ); extern void Compiler_Warning(const char * format, ...); extern int sprintf(char * , const char * , ...); struct __ecereNameSpace__ecere__com__GlobalFunction; struct __ecereNameSpace__ecere__com__IteratorPointer; extern struct __ecereNameSpace__ecere__sys__OldList * MkList(void); extern void ListAdd(struct __ecereNameSpace__ecere__sys__OldList * list, void * item); extern void FreeList(struct __ecereNameSpace__ecere__sys__OldList * list, void (* FreeFunction)(void * )); extern struct __ecereNameSpace__ecere__sys__OldList * MkListOne(void * item); extern struct __ecereNameSpace__ecere__sys__OldList * ast; extern struct __ecereNameSpace__ecere__sys__OldList * excludedSymbols; extern struct __ecereNameSpace__ecere__sys__OldList * CopyList(struct __ecereNameSpace__ecere__sys__OldList * source, void * (* CopyFunction)(void * )); unsigned int __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert(struct __ecereNameSpace__ecere__sys__OldList * this, void * prevItem, void * item); void __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove(struct __ecereNameSpace__ecere__sys__OldList * this, void * item); void __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add(struct __ecereNameSpace__ecere__sys__OldList * this, void * item); void __ecereMethod___ecereNameSpace__ecere__sys__OldList_Clear(struct __ecereNameSpace__ecere__sys__OldList * this); extern struct Pointer * MkPointer(struct __ecereNameSpace__ecere__sys__OldList * qualifiers, struct Pointer * pointer); extern void FreeInitDeclarator(struct InitDeclarator * decl); extern struct Attrib * MkAttrib(int type, struct __ecereNameSpace__ecere__sys__OldList * attribs); extern struct ExtDecl * MkExtDeclAttrib(struct Attrib * attr); struct Location { struct CodePosition start; struct CodePosition end; } ecere_gcc_struct; void FullClassNameCat(char * output, const char * className, unsigned int includeTemplateParams) { int c; char ch; int len; for(c = 0; (ch = className[c]) && ch != '<'; c++) { if(ch == ':') { strcat(output, "__ecereNameSpace__"); break; } } len = strlen(output); c = 0; if(!strncmp(className, "const ", 6)) c += 6; for(; (ch = className[c]); c++) { if(ch == ':') output[len++] = '_'; else if(ch == ' ') output[len++] = '_'; else if(ch == '*') { output[len++] = '_'; output[len++] = 'P'; output[len++] = 'T'; output[len++] = 'R'; output[len++] = '_'; } else if(ch == '=') { output[len++] = '_'; output[len++] = 'E'; output[len++] = 'Q'; output[len++] = 'U'; output[len++] = '_'; } else if(ch == '<') { if(!includeTemplateParams) break; if(!strncmp(className + c + 1, "const ", 6)) c += 6; output[len++] = '_'; output[len++] = 'T'; output[len++] = 'P'; output[len++] = 'L'; output[len++] = '_'; } else if(ch == '>') { output[len++] = '_'; } else if(ch == ',') { if(!strncmp(className + c + 1, "const ", 6)) c += 6; output[len++] = '_'; } else output[len++] = ch; } output[len++] = 0; } extern struct Location yylloc; struct External; extern struct External * curExternal; struct TopoEdge { struct __ecereNameSpace__ecere__com__LinkElement in; struct __ecereNameSpace__ecere__com__LinkElement out; struct External * from; struct External * to; unsigned int breakable; } ecere_gcc_struct; extern void FreeExternal(struct External * external); extern struct External * DeclareStruct(struct External * neededBy, const char * name, unsigned int skipNoHead, unsigned int needDereference); struct Context; extern struct Context * PushContext(void); extern void PopContext(struct Context * ctx); extern struct Context * curContext; struct __ecereNameSpace__ecere__com__Class; struct __ecereNameSpace__ecere__com__Instance { void * * _vTbl; struct __ecereNameSpace__ecere__com__Class * _class; int _refCount; } ecere_gcc_struct; extern long long __ecereNameSpace__ecere__com__eClass_GetProperty(struct __ecereNameSpace__ecere__com__Class * _class, const char * name); extern void __ecereNameSpace__ecere__com__eClass_SetProperty(struct __ecereNameSpace__ecere__com__Class * _class, const char * name, long long value); extern int AddMembers(struct External * neededBy, struct __ecereNameSpace__ecere__sys__OldList * declarations, struct __ecereNameSpace__ecere__com__Class * _class, unsigned int isMember, unsigned int * retSize, struct __ecereNameSpace__ecere__com__Class * topClass, unsigned int * addedPadding); extern void * __ecereNameSpace__ecere__com__eInstance_New(struct __ecereNameSpace__ecere__com__Class * _class); extern void __ecereNameSpace__ecere__com__eInstance_SetMethod(struct __ecereNameSpace__ecere__com__Instance * instance, const char * name, void * function); extern void __ecereNameSpace__ecere__com__eInstance_IncRef(struct __ecereNameSpace__ecere__com__Instance * instance); int __ecereVMethodID___ecereNameSpace__ecere__com__Container_GetNext; struct __ecereNameSpace__ecere__com__Property; extern void __ecereNameSpace__ecere__com__eInstance_FireSelfWatchers(struct __ecereNameSpace__ecere__com__Instance * instance, struct __ecereNameSpace__ecere__com__Property * _property); 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); extern void __ecereNameSpace__ecere__com__eInstance_Watch(void * instance, struct __ecereNameSpace__ecere__com__Property * _property, void * object, void (* callback)(void * , void * )); extern void __ecereNameSpace__ecere__com__eInstance_FireWatchers(struct __ecereNameSpace__ecere__com__Instance * instance, struct __ecereNameSpace__ecere__com__Property * _property); extern struct __ecereNameSpace__ecere__com__Property * __ecereNameSpace__ecere__com__eClass_AddProperty(struct __ecereNameSpace__ecere__com__Class * _class, const char * name, const char * dataType, void * setStmt, void * getStmt, int declMode); struct Declarator; extern void FreeDeclarator(struct Declarator * decl); extern struct Declarator * MkDeclaratorPointer(struct Pointer * pointer, struct Declarator * declarator); extern struct Declarator * MkDeclaratorFunction(struct Declarator * declarator, struct __ecereNameSpace__ecere__sys__OldList * parameters); extern struct Declarator * PlugDeclarator(struct Declarator * decl, struct Declarator * baseDecl); extern struct Declarator * CopyDeclarator(struct Declarator * declarator); extern struct Declarator * GetFuncDecl(struct Declarator * decl); struct __ecereNameSpace__ecere__com__BTNamedLink; struct __ecereNameSpace__ecere__com__BTNamedLink { const char * name; struct __ecereNameSpace__ecere__com__BTNamedLink * parent; struct __ecereNameSpace__ecere__com__BTNamedLink * left; struct __ecereNameSpace__ecere__com__BTNamedLink * right; int depth; void * data; } ecere_gcc_struct; struct Symbol; extern struct Symbol * FindClass(const char * name); struct Declaration; extern struct External * MkExternalDeclaration(struct Declaration * declaration); extern struct Declaration * MkDeclaration(struct __ecereNameSpace__ecere__sys__OldList * specifiers, struct __ecereNameSpace__ecere__sys__OldList * initDeclarators); struct Specifier; extern struct Specifier * MkSpecifierName(const char * name); extern struct Declaration * MkStructDeclaration(struct __ecereNameSpace__ecere__sys__OldList * specifiers, struct __ecereNameSpace__ecere__sys__OldList * declarators, struct Specifier * extStorage); extern void FreeSpecifier(struct Specifier * spec); extern struct Specifier * MkSpecifier(int specifier); extern struct Specifier * CopySpecifier(struct Specifier * spec); extern struct Specifier * MkSpecifierExtended(struct ExtDecl * extDecl); struct Identifier; extern struct Identifier * GetDeclId(struct Declarator * decl); struct Identifier { struct Identifier * prev; struct Identifier * next; struct Location loc; struct Symbol * classSym; struct Specifier * _class; char * string; struct Identifier * badID; } ecere_gcc_struct; extern struct Declarator * MkDeclaratorIdentifier(struct Identifier * id); extern struct Identifier * MkIdentifier(const char * string); extern struct Specifier * MkStructOrUnion(int type, struct Identifier * id, struct __ecereNameSpace__ecere__sys__OldList * definitions); struct Expression; struct Specifier { struct Specifier * prev; struct Specifier * next; struct Location loc; int type; union { int specifier; struct { struct ExtDecl * extDecl; char * name; struct Symbol * symbol; struct __ecereNameSpace__ecere__sys__OldList * templateArgs; struct Specifier * nsSpec; } ecere_gcc_struct __anon1; struct { struct Identifier * id; struct __ecereNameSpace__ecere__sys__OldList * list; struct __ecereNameSpace__ecere__sys__OldList * baseSpecs; struct __ecereNameSpace__ecere__sys__OldList * definitions; unsigned int addNameSpace; struct Context * ctx; struct ExtDecl * extDeclStruct; } ecere_gcc_struct __anon2; struct Expression * expression; struct Specifier * _class; struct TemplateParameter * templateParameter; } ecere_gcc_struct __anon1; } ecere_gcc_struct; struct Declarator { struct Declarator * prev; struct Declarator * next; struct Location loc; int type; struct Symbol * symbol; struct Declarator * declarator; union { struct Identifier * identifier; struct { struct Expression * exp; struct Expression * posExp; struct Attrib * attrib; } ecere_gcc_struct structDecl; struct { struct Expression * exp; struct Specifier * enumClass; } ecere_gcc_struct array; struct { struct __ecereNameSpace__ecere__sys__OldList * parameters; } ecere_gcc_struct function; struct { struct Pointer * pointer; } ecere_gcc_struct pointer; struct { struct ExtDecl * extended; } ecere_gcc_struct extended; } ecere_gcc_struct __anon1; } ecere_gcc_struct; extern struct Expression * QMkExpId(const char * id); extern struct Expression * MkExpOp(struct Expression * exp1, int op, struct Expression * exp2); extern struct Expression * CopyExpression(struct Expression * exp); extern struct Expression * MkExpCall(struct Expression * expression, struct __ecereNameSpace__ecere__sys__OldList * arguments); extern struct Expression * MkExpIdentifier(struct Identifier * id); extern struct Expression * MkExpMember(struct Expression * expression, struct Identifier * member); extern struct Attribute * MkAttribute(char * attr, struct Expression * exp); struct Type; struct __ecereNameSpace__ecere__com__Property { struct __ecereNameSpace__ecere__com__Property * prev; struct __ecereNameSpace__ecere__com__Property * next; const char * name; unsigned int isProperty; int memberAccess; int id; struct __ecereNameSpace__ecere__com__Class * _class; const char * dataTypeString; struct __ecereNameSpace__ecere__com__Class * dataTypeClass; struct Type * dataType; void (* Set)(void * , int); int (* Get)(void * ); unsigned int (* IsSet)(void * ); void * data; void * symbol; int vid; unsigned int conversion; unsigned int watcherOffset; const char * category; unsigned int compiled; unsigned int selfWatchable; unsigned int isWatchable; } ecere_gcc_struct; extern struct Type * MkClassType(const char * name); extern struct Type * ProcessType(struct __ecereNameSpace__ecere__sys__OldList * specs, struct Declarator * decl); extern void FreeType(struct Type * type); struct ClassFunction; extern struct ClassFunction * MkClassFunction(struct __ecereNameSpace__ecere__sys__OldList * specifiers, struct Specifier * _class, struct Declarator * decl, struct __ecereNameSpace__ecere__sys__OldList * declList); struct Initializer; struct Initializer { struct Initializer * prev; struct Initializer * next; struct Location loc; int type; union { struct Expression * exp; struct __ecereNameSpace__ecere__sys__OldList * list; } ecere_gcc_struct __anon1; unsigned int isConstant; struct Identifier * id; } ecere_gcc_struct; extern struct InitDeclarator * MkInitDeclarator(struct Declarator * declarator, struct Initializer * initializer); extern void FreeInitializer(struct Initializer * initializer); extern struct Initializer * MkInitializerAssignment(struct Expression * exp); struct __ecereNameSpace__ecere__com__Method; struct __ecereNameSpace__ecere__com__Method { const char * name; struct __ecereNameSpace__ecere__com__Method * parent; struct __ecereNameSpace__ecere__com__Method * left; struct __ecereNameSpace__ecere__com__Method * right; int depth; int (* function)(); int vid; int type; struct __ecereNameSpace__ecere__com__Class * _class; void * symbol; const char * dataTypeString; struct Type * dataType; int memberAccess; } ecere_gcc_struct; struct Symbol { char * string; struct Symbol * parent; struct Symbol * left; struct Symbol * right; int depth; struct Type * type; union { struct __ecereNameSpace__ecere__com__Method * method; struct __ecereNameSpace__ecere__com__Property * _property; struct __ecereNameSpace__ecere__com__Class * registered; } ecere_gcc_struct __anon1; unsigned int notYetDeclared; union { struct { struct External * pointerExternal; struct External * structExternal; } ecere_gcc_struct __anon1; struct { struct External * externalGet; struct External * externalSet; struct External * externalPtr; struct External * externalIsSet; } ecere_gcc_struct __anon2; struct { struct External * methodExternal; struct External * methodCodeExternal; } ecere_gcc_struct __anon3; } ecere_gcc_struct __anon2; unsigned int imported; unsigned int declaredStructSym; struct __ecereNameSpace__ecere__com__Class * _class; unsigned int declaredStruct; unsigned int needConstructor; unsigned int needDestructor; char * constructorName; char * structName; char * className; char * destructorName; struct ModuleImport * module; struct ClassImport * _import; struct Location nameLoc; unsigned int isParam; unsigned int isRemote; unsigned int isStruct; unsigned int fireWatchersDone; int declaring; unsigned int classData; unsigned int isStatic; char * shortName; struct __ecereNameSpace__ecere__sys__OldList * templateParams; struct __ecereNameSpace__ecere__sys__OldList templatedClasses; struct Context * ctx; int isIterator; struct Expression * propCategory; unsigned int mustRegister; } ecere_gcc_struct; struct Type { struct Type * prev; struct Type * next; int refCount; union { struct Symbol * _class; struct { struct __ecereNameSpace__ecere__sys__OldList members; char * enumName; } ecere_gcc_struct __anon1; struct { struct Type * returnType; struct __ecereNameSpace__ecere__sys__OldList params; struct Symbol * thisClass; unsigned int staticMethod; struct TemplateParameter * thisClassTemplate; } ecere_gcc_struct __anon2; struct { struct __ecereNameSpace__ecere__com__Method * method; struct __ecereNameSpace__ecere__com__Class * methodClass; struct __ecereNameSpace__ecere__com__Class * usedClass; } ecere_gcc_struct __anon3; struct { struct Type * arrayType; int arraySize; struct Expression * arraySizeExp; unsigned int freeExp; struct Symbol * enumClass; } ecere_gcc_struct __anon4; struct Type * type; struct TemplateParameter * templateParameter; } ecere_gcc_struct __anon1; int kind; unsigned int size; char * name; char * typeName; struct __ecereNameSpace__ecere__com__Class * thisClassFrom; int promotedFrom; int classObjectType; int alignment; unsigned int offset; int bitFieldCount; int count; int bitMemberSize; unsigned int isSigned : 1; unsigned int constant : 1; unsigned int truth : 1; unsigned int byReference : 1; unsigned int extraParam : 1; unsigned int directClassAccess : 1; unsigned int computing : 1; unsigned int keepCast : 1; unsigned int passAsTemplate : 1; unsigned int dllExport : 1; unsigned int attrStdcall : 1; unsigned int declaredWithStruct : 1; unsigned int typedByReference : 1; unsigned int casted : 1; unsigned int pointerAlignment : 1; unsigned int isLong : 1; unsigned int signedBeforePromotion : 1; } ecere_gcc_struct; extern struct __ecereNameSpace__ecere__com__Method * __ecereNameSpace__ecere__com__eClass_AddMethod(struct __ecereNameSpace__ecere__com__Class * _class, const char * name, const char * type, void * function, int declMode); extern void ProcessMethodType(struct __ecereNameSpace__ecere__com__Method * method); unsigned int __ecereProp_Type_Get_isPointerType(struct Type * this); struct Statement; struct ClassFunction { struct ClassFunction * prev; struct ClassFunction * next; struct Location loc; struct __ecereNameSpace__ecere__sys__OldList * specifiers; struct Declarator * declarator; struct __ecereNameSpace__ecere__sys__OldList * declarations; struct Statement * body; struct __ecereNameSpace__ecere__com__Class * _class; struct __ecereNameSpace__ecere__sys__OldList attached; int declMode; struct Type * type; struct Symbol * propSet; unsigned int isVirtual; unsigned int isConstructor; unsigned int isDestructor; unsigned int dontMangle; int id; int idCode; } ecere_gcc_struct; struct Statement { struct Statement * prev; struct Statement * next; struct Location loc; int type; union { struct __ecereNameSpace__ecere__sys__OldList * expressions; struct { struct Identifier * id; struct Statement * stmt; } ecere_gcc_struct labeled; struct { struct Expression * exp; struct Statement * stmt; } ecere_gcc_struct caseStmt; struct { struct __ecereNameSpace__ecere__sys__OldList * declarations; struct __ecereNameSpace__ecere__sys__OldList * statements; struct Context * context; unsigned int isSwitch; } ecere_gcc_struct compound; struct { struct __ecereNameSpace__ecere__sys__OldList * exp; struct Statement * stmt; struct Statement * elseStmt; } ecere_gcc_struct ifStmt; struct { struct __ecereNameSpace__ecere__sys__OldList * exp; struct Statement * stmt; } ecere_gcc_struct switchStmt; struct { struct __ecereNameSpace__ecere__sys__OldList * exp; struct Statement * stmt; } ecere_gcc_struct whileStmt; struct { struct __ecereNameSpace__ecere__sys__OldList * exp; struct Statement * stmt; } ecere_gcc_struct doWhile; struct { struct Statement * init; struct Statement * check; struct __ecereNameSpace__ecere__sys__OldList * increment; struct Statement * stmt; } ecere_gcc_struct forStmt; struct { struct Identifier * id; } ecere_gcc_struct gotoStmt; struct { struct Specifier * spec; char * statements; struct __ecereNameSpace__ecere__sys__OldList * inputFields; struct __ecereNameSpace__ecere__sys__OldList * outputFields; struct __ecereNameSpace__ecere__sys__OldList * clobberedFields; } ecere_gcc_struct asmStmt; struct { struct Expression * watcher; struct Expression * object; struct __ecereNameSpace__ecere__sys__OldList * watches; } ecere_gcc_struct _watch; struct { struct Identifier * id; struct __ecereNameSpace__ecere__sys__OldList * exp; struct __ecereNameSpace__ecere__sys__OldList * filter; struct Statement * stmt; } ecere_gcc_struct forEachStmt; struct Declaration * decl; } ecere_gcc_struct __anon1; } ecere_gcc_struct; extern struct Statement * MkExpressionStmt(struct __ecereNameSpace__ecere__sys__OldList * expressions); extern struct Statement * MkCompoundStmt(struct __ecereNameSpace__ecere__sys__OldList * declarations, struct __ecereNameSpace__ecere__sys__OldList * statements); extern void ProcessClassFunctionBody(struct ClassFunction * func, struct Statement * body); extern struct Statement * MkReturnStmt(struct __ecereNameSpace__ecere__sys__OldList * exp); struct __ecereNameSpace__ecere__sys__BinaryTree; struct __ecereNameSpace__ecere__sys__BinaryTree { struct __ecereNameSpace__ecere__sys__BTNode * root; int count; int (* CompareKey)(struct __ecereNameSpace__ecere__sys__BinaryTree * tree, uintptr_t a, uintptr_t b); void (* FreeKey)(void * key); } ecere_gcc_struct; struct __ecereNameSpace__ecere__sys__BTNode * __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FindString(struct __ecereNameSpace__ecere__sys__BinaryTree * this, const char * key); unsigned int __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Add(struct __ecereNameSpace__ecere__sys__BinaryTree * this, struct __ecereNameSpace__ecere__sys__BTNode * node); struct __ecereNameSpace__ecere__com__DataMember; struct __ecereNameSpace__ecere__com__ClassTemplateArgument { union { struct { const char * dataTypeString; struct __ecereNameSpace__ecere__com__Class * dataTypeClass; } ecere_gcc_struct __anon1; struct __ecereNameSpace__ecere__com__DataValue expression; struct { const char * memberString; union { struct __ecereNameSpace__ecere__com__DataMember * member; struct __ecereNameSpace__ecere__com__Property * prop; struct __ecereNameSpace__ecere__com__Method * method; } ecere_gcc_struct __anon1; } ecere_gcc_struct __anon2; } ecere_gcc_struct __anon1; } ecere_gcc_struct; struct __ecereNameSpace__ecere__com__DataMember { struct __ecereNameSpace__ecere__com__DataMember * prev; struct __ecereNameSpace__ecere__com__DataMember * next; const char * name; unsigned int isProperty; int memberAccess; int id; struct __ecereNameSpace__ecere__com__Class * _class; const char * dataTypeString; struct __ecereNameSpace__ecere__com__Class * dataTypeClass; struct Type * dataType; int type; int offset; int memberID; struct __ecereNameSpace__ecere__sys__OldList members; struct __ecereNameSpace__ecere__sys__BinaryTree membersAlpha; int memberOffset; short structAlignment; short pointerAlignment; } ecere_gcc_struct; extern struct __ecereNameSpace__ecere__com__DataMember * __ecereNameSpace__ecere__com__eClass_AddDataMember(struct __ecereNameSpace__ecere__com__Class * _class, const char * name, const char * type, unsigned int size, unsigned int alignment, int declMode); struct __ecereNameSpace__ecere__com__Module; extern unsigned int ModuleAccess(struct __ecereNameSpace__ecere__com__Instance * searchIn, struct __ecereNameSpace__ecere__com__Instance * searchFor); extern struct __ecereNameSpace__ecere__com__Instance * privateModule; 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); extern struct __ecereNameSpace__ecere__com__Class * __ecereNameSpace__ecere__com__eSystem_FindClass(struct __ecereNameSpace__ecere__com__Instance * module, const char * name); 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); 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); 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); struct TypeName; struct TypeName { struct TypeName * prev; struct TypeName * next; struct Location loc; struct __ecereNameSpace__ecere__sys__OldList * qualifiers; struct Declarator * declarator; int classObjectType; struct Expression * bitCount; } ecere_gcc_struct; extern struct TypeName * MkTypeName(struct __ecereNameSpace__ecere__sys__OldList * qualifiers, struct Declarator * declarator); extern struct Expression * MkExpCast(struct TypeName * typeName, struct Expression * expression); struct ClassDef; extern struct ClassDef * MkClassDefDeclaration(struct Declaration * decl); extern struct ClassDef * MkClassDefFunction(struct ClassFunction * function); struct ClassDefinition; struct Context { struct Context * parent; struct __ecereNameSpace__ecere__sys__BinaryTree types; struct __ecereNameSpace__ecere__sys__BinaryTree classes; struct __ecereNameSpace__ecere__sys__BinaryTree symbols; struct __ecereNameSpace__ecere__sys__BinaryTree structSymbols; int nextID; int simpleID; struct __ecereNameSpace__ecere__sys__BinaryTree templateTypes; struct ClassDefinition * classDef; unsigned int templateTypesOnly; unsigned int hasNameSpace; } ecere_gcc_struct; struct ClassDefinition { struct ClassDefinition * prev; struct ClassDefinition * next; struct Location loc; struct Specifier * _class; struct __ecereNameSpace__ecere__sys__OldList * baseSpecs; struct __ecereNameSpace__ecere__sys__OldList * definitions; struct Symbol * symbol; struct Location blockStart; struct Location nameLoc; int declMode; unsigned int deleteWatchable; } ecere_gcc_struct; struct Instantiation; struct Expression { struct Expression * prev; struct Expression * next; struct Location loc; int type; union { struct { char * constant; struct Identifier * identifier; } ecere_gcc_struct __anon1; struct Statement * compound; struct Instantiation * instance; struct { char * string; unsigned int intlString; unsigned int wideString; } ecere_gcc_struct __anon2; struct __ecereNameSpace__ecere__sys__OldList * list; struct { struct __ecereNameSpace__ecere__sys__OldList * specifiers; struct Declarator * decl; } ecere_gcc_struct _classExp; struct { struct Identifier * id; } ecere_gcc_struct classData; struct { struct Expression * exp; struct __ecereNameSpace__ecere__sys__OldList * arguments; struct Location argLoc; } ecere_gcc_struct call; struct { struct Expression * exp; struct __ecereNameSpace__ecere__sys__OldList * index; } ecere_gcc_struct index; struct { struct Expression * exp; struct Identifier * member; int memberType; unsigned int thisPtr; } ecere_gcc_struct member; struct { int op; struct Expression * exp1; struct Expression * exp2; } ecere_gcc_struct op; struct TypeName * typeName; struct Specifier * _class; struct { struct TypeName * typeName; struct Expression * exp; } ecere_gcc_struct cast; struct { struct Expression * cond; struct __ecereNameSpace__ecere__sys__OldList * exp; struct Expression * elseExp; } ecere_gcc_struct cond; struct { struct TypeName * typeName; struct Expression * size; } ecere_gcc_struct _new; struct { struct TypeName * typeName; struct Expression * size; struct Expression * exp; } ecere_gcc_struct _renew; struct { char * table; struct Identifier * id; } ecere_gcc_struct db; struct { struct Expression * ds; struct Expression * name; } ecere_gcc_struct dbopen; struct { struct TypeName * typeName; struct Initializer * initializer; } ecere_gcc_struct initializer; struct { struct Expression * exp; struct TypeName * typeName; } ecere_gcc_struct vaArg; struct { struct TypeName * typeName; struct Identifier * id; } ecere_gcc_struct offset; } ecere_gcc_struct __anon1; unsigned int debugValue; struct __ecereNameSpace__ecere__com__DataValue val; uint64 address; unsigned int hasAddress; struct Type * expType; struct Type * destType; unsigned int usage; int tempCount; unsigned int byReference; unsigned int isConstant; unsigned int addedThis; unsigned int needCast; unsigned int thisPtr; unsigned int opDestType; unsigned int usedInComparison; unsigned int ambiguousUnits; unsigned int parentOpDestType; unsigned int needTemplateCast; } ecere_gcc_struct; struct Instantiation { struct Instantiation * prev; struct Instantiation * next; struct Location loc; struct Specifier * _class; struct Expression * exp; struct __ecereNameSpace__ecere__sys__OldList * members; struct Symbol * symbol; unsigned int fullSet; unsigned int isConstant; unsigned char * data; struct Location nameLoc; struct Location insideLoc; unsigned int built; } ecere_gcc_struct; struct Declaration { struct Declaration * prev; struct Declaration * next; struct Location loc; int type; union { struct { struct __ecereNameSpace__ecere__sys__OldList * specifiers; struct __ecereNameSpace__ecere__sys__OldList * declarators; } ecere_gcc_struct __anon1; struct Instantiation * inst; struct { struct Identifier * id; struct Expression * exp; } ecere_gcc_struct __anon2; } ecere_gcc_struct __anon1; struct Specifier * extStorage; struct Symbol * symbol; int declMode; } ecere_gcc_struct; extern struct Expression * MkExpInstance(struct Instantiation * inst); struct MembersInit; struct MembersInit { struct MembersInit * prev; struct MembersInit * next; struct Location loc; int type; union { struct __ecereNameSpace__ecere__sys__OldList * dataMembers; struct ClassFunction * function; } ecere_gcc_struct __anon1; } ecere_gcc_struct; struct MemberInit; struct MemberInit { struct MemberInit * prev; struct MemberInit * next; struct Location loc; struct Location realLoc; struct __ecereNameSpace__ecere__sys__OldList * identifiers; struct Initializer * initializer; unsigned int used; unsigned int variable; unsigned int takeOutExp; } ecere_gcc_struct; static void CheckPublicExpression(struct Expression * exp, int access); static void CheckPublicInitializer(struct Initializer * init, int access) { switch(init->type) { case 0: CheckPublicExpression(init->__anon1.exp, access); break; case 1: { struct Initializer * i; for(i = (*init->__anon1.list).first; i; i = i->next) CheckPublicInitializer(i, access); break; } } } static void CheckPublicClass(struct Symbol * classSym, int access, const char * word); static void CheckPublicTypeName(struct TypeName * type, int access) { if(type->qualifiers) { struct Specifier * spec; for(spec = (*type->qualifiers).first; spec; spec = spec->next) { if(spec->type == 1) { struct Symbol * classSym = spec->__anon1.__anon1.symbol; CheckPublicClass(classSym, access, "define"); } } } } static void CheckPublicDataType(struct Type * type, int access, const char * word) { if(type) { switch(type->kind) { case 8: { CheckPublicClass(type->__anon1._class, access, word); break; } case 9: case 10: { break; } case 11: { struct Type * param; CheckPublicDataType(type->__anon1.__anon2.returnType, access, word); for(param = type->__anon1.__anon2.params.first; param; param = param->next) CheckPublicDataType(param, access, word); CheckPublicClass(type->__anon1.__anon2.thisClass, access, word); break; } case 12: CheckPublicDataType(type->__anon1.__anon4.arrayType, access, word); if(type->__anon1.__anon4.enumClass) CheckPublicClass(type->__anon1.__anon4.enumClass, access, word); break; case 13: { CheckPublicDataType(type->__anon1.type, access, word); break; } case 16: { break; } case 19: { CheckPublicClass(type->__anon1._class, access, word); break; } } } } static void CheckPublicExpression(struct Expression * exp, int access) { if(exp) { switch(exp->type) { case 0: break; case 2: break; case 3: break; case 4: if(exp->__anon1.op.exp1) CheckPublicExpression(exp->__anon1.op.exp1, access); if(exp->__anon1.op.exp2) CheckPublicExpression(exp->__anon1.op.exp2, access); break; case 5: { struct Expression * e; for(e = (*exp->__anon1.list).first; e; e = e->next) CheckPublicExpression(e, access); break; } case 6: { struct Expression * e; CheckPublicExpression(exp->__anon1.index.exp, access); for(e = (*exp->__anon1.index.index).first; e; e = e->next) CheckPublicExpression(e, access); break; } case 7: { struct Expression * e; CheckPublicExpression(exp->__anon1.call.exp, access); if(exp->__anon1.call.arguments) { for(e = (*exp->__anon1.call.arguments).first; e; e = e->next) CheckPublicExpression(e, access); } break; } case 8: { CheckPublicExpression(exp->__anon1.member.exp, access); break; } case 9: { CheckPublicExpression(exp->__anon1.member.exp, access); break; } case 10: CheckPublicTypeName(exp->__anon1.typeName, access); break; case 11: { CheckPublicTypeName(exp->__anon1.cast.typeName, access); if(exp->__anon1.cast.exp) CheckPublicExpression(exp->__anon1.cast.exp, access); break; } case 12: { struct Expression * e; CheckPublicExpression(exp->__anon1.cond.cond, access); for(e = (*exp->__anon1.cond.exp).first; e; e = e->next) CheckPublicExpression(e, access); CheckPublicExpression(exp->__anon1.cond.elseExp, access); break; } case 13: case 26: CheckPublicExpression(exp->__anon1._new.size, access); break; case 14: case 27: CheckPublicExpression(exp->__anon1._renew.size, access); CheckPublicExpression(exp->__anon1._renew.exp, access); break; case 1: { struct MembersInit * members; CheckPublicClass(exp->__anon1.instance->_class->__anon1.__anon1.symbol, access, "define"); for(members = (*exp->__anon1.instance->members).first; members; members = members->next) { if(members->type == 0) { struct MemberInit * member; for(member = (*members->__anon1.dataMembers).first; member; member = member->next) { CheckPublicInitializer(member->initializer, access); } } } break; } } } } struct PropertyDef; struct ClassDef { struct ClassDef * prev; struct ClassDef * next; struct Location loc; int type; union { struct Declaration * decl; struct ClassFunction * function; struct __ecereNameSpace__ecere__sys__OldList * defProperties; struct PropertyDef * propertyDef; struct PropertyWatch * propertyWatch; char * designer; struct Identifier * defaultProperty; struct { struct Identifier * id; struct Initializer * initializer; } ecere_gcc_struct __anon1; } ecere_gcc_struct __anon1; int memberAccess; void * object; } ecere_gcc_struct; struct PropertyDef { struct PropertyDef * prev; struct PropertyDef * next; struct Location loc; struct __ecereNameSpace__ecere__sys__OldList * specifiers; struct Declarator * declarator; struct Identifier * id; struct Statement * getStmt; struct Statement * setStmt; struct Statement * issetStmt; struct Symbol * symbol; struct Expression * category; struct { unsigned int conversion : 1; unsigned int isWatchable : 1; unsigned int isDBProp : 1; } ecere_gcc_struct __anon1; } ecere_gcc_struct; static void CheckMembersDefinitions(struct __ecereNameSpace__ecere__com__Class * regClass, struct __ecereNameSpace__ecere__com__DataMember * member, struct __ecereNameSpace__ecere__sys__OldList * definitions, int access) { if(definitions != (((void *)0))) { struct ClassDef * def; for(def = definitions->first; def; def = def->next) { if(def->type == 2) { struct Declaration * decl = def->__anon1.decl; struct __ecereNameSpace__ecere__com__DataMember * dataMember; yylloc = def->loc; if(decl->type == 0) { struct Declarator * d; if(decl->__anon1.__anon1.declarators) { for(d = (*decl->__anon1.__anon1.declarators).first; d; d = d->next) { struct Identifier * declId = GetDeclId(d); if(declId) { if(member) { struct __ecereNameSpace__ecere__com__BTNamedLink * link = (struct __ecereNameSpace__ecere__com__BTNamedLink *)__ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FindString(&member->membersAlpha, declId->string); dataMember = link ? link->data : (((void *)0)); } else dataMember = __ecereNameSpace__ecere__com__eClass_FindDataMember(regClass, declId->string, privateModule, (((void *)0)), (((void *)0))); if(dataMember) CheckPublicDataType(dataMember->dataType, (def->memberAccess == 2) ? 2 : access, __ecereNameSpace__ecere__GetTranslatedString("ec", "class data member", (((void *)0)))); } } } else if(decl->__anon1.__anon1.specifiers) { struct Specifier * spec; for(spec = (*decl->__anon1.__anon1.specifiers).first; spec; spec = spec->next) { if(spec->type == 3 || spec->type == 4) { if(spec->__anon1.__anon2.definitions && !spec->__anon1.__anon2.id) { CheckMembersDefinitions(regClass, member, spec->__anon1.__anon2.definitions, (def->memberAccess == 2) ? 2 : access); } else if(spec->__anon1.__anon2.definitions && spec->__anon1.__anon2.id) { if(member) { struct __ecereNameSpace__ecere__com__BTNamedLink * link = (struct __ecereNameSpace__ecere__com__BTNamedLink *)__ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_FindString(&member->membersAlpha, spec->__anon1.__anon2.id->string); dataMember = link ? link->data : (((void *)0)); } else dataMember = __ecereNameSpace__ecere__com__eClass_FindDataMember(regClass, spec->__anon1.__anon2.id->string, privateModule, (((void *)0)), (((void *)0))); if(dataMember) CheckPublicDataType(dataMember->dataType, (def->memberAccess == 2) ? 2 : access, __ecereNameSpace__ecere__GetTranslatedString("ec", "class data member", (((void *)0)))); } } } } } else if(decl->type == 2) { CheckPublicClass(decl->__anon1.inst->_class->__anon1.__anon1.symbol, (def->memberAccess == 2) ? 2 : access, __ecereNameSpace__ecere__GetTranslatedString("ec", "class member instance", (((void *)0)))); } } } } } struct FunctionDefinition; typedef union YYSTYPE { int specifierType; int i; int declMode; struct Identifier * id; struct Expression * exp; struct Specifier * specifier; struct __ecereNameSpace__ecere__sys__OldList * list; struct Enumerator * enumerator; struct Declarator * declarator; struct Pointer * pointer; struct Initializer * initializer; struct InitDeclarator * initDeclarator; struct TypeName * typeName; struct Declaration * declaration; struct Statement * stmt; struct FunctionDefinition * function; struct External * external; struct Context * context; struct AsmField * asmField; struct Attrib * attrib; struct ExtDecl * extDecl; struct Attribute * attribute; struct Instantiation * instance; struct MembersInit * membersInit; struct MemberInit * memberInit; struct ClassFunction * classFunction; struct ClassDefinition * _class; struct ClassDef * classDef; struct PropertyDef * prop; char * string; struct Symbol * symbol; struct PropertyWatch * propertyWatch; struct TemplateParameter * templateParameter; struct TemplateArgument * templateArgument; struct TemplateDatatype * templateDatatype; struct DBTableEntry * dbtableEntry; struct DBIndexItem * dbindexItem; struct DBTableDef * dbtableDef; } ecere_gcc_struct YYSTYPE; extern YYSTYPE yylval; struct External { struct External * prev; struct External * next; struct Location loc; int type; struct Symbol * symbol; union { struct FunctionDefinition * function; struct ClassDefinition * _class; struct Declaration * declaration; char * importString; struct Identifier * id; struct DBTableDef * table; } ecere_gcc_struct __anon1; int importType; struct External * fwdDecl; struct __ecereNameSpace__ecere__com__Instance * outgoing; struct __ecereNameSpace__ecere__com__Instance * incoming; int nonBreakableIncoming; } ecere_gcc_struct; struct FunctionDefinition { struct FunctionDefinition * prev; struct FunctionDefinition * next; struct Location loc; struct __ecereNameSpace__ecere__sys__OldList * specifiers; struct Declarator * declarator; struct __ecereNameSpace__ecere__sys__OldList * declarations; struct Statement * body; struct __ecereNameSpace__ecere__com__Class * _class; struct __ecereNameSpace__ecere__sys__OldList attached; int declMode; struct Type * type; struct Symbol * propSet; int tempCount; unsigned int propertyNoThis; } ecere_gcc_struct; void __ecereMethod_External_CreateUniqueEdge(struct External * this, struct External * from, unsigned int soft); struct __ecereNameSpace__ecere__com__NameSpace; struct __ecereNameSpace__ecere__com__NameSpace { const char * name; struct __ecereNameSpace__ecere__com__NameSpace * btParent; struct __ecereNameSpace__ecere__com__NameSpace * left; struct __ecereNameSpace__ecere__com__NameSpace * right; int depth; struct __ecereNameSpace__ecere__com__NameSpace * parent; struct __ecereNameSpace__ecere__sys__BinaryTree nameSpaces; struct __ecereNameSpace__ecere__sys__BinaryTree classes; struct __ecereNameSpace__ecere__sys__BinaryTree defines; struct __ecereNameSpace__ecere__sys__BinaryTree functions; } ecere_gcc_struct; struct __ecereNameSpace__ecere__com__Class { struct __ecereNameSpace__ecere__com__Class * prev; struct __ecereNameSpace__ecere__com__Class * next; const char * name; int offset; int structSize; void * * _vTbl; int vTblSize; unsigned int (* Constructor)(void * ); void (* Destructor)(void * ); int offsetClass; int sizeClass; struct __ecereNameSpace__ecere__com__Class * base; struct __ecereNameSpace__ecere__sys__BinaryTree methods; struct __ecereNameSpace__ecere__sys__BinaryTree members; struct __ecereNameSpace__ecere__sys__BinaryTree prop; struct __ecereNameSpace__ecere__sys__OldList membersAndProperties; struct __ecereNameSpace__ecere__sys__BinaryTree classProperties; struct __ecereNameSpace__ecere__sys__OldList derivatives; int memberID; int startMemberID; int type; struct __ecereNameSpace__ecere__com__Instance * module; struct __ecereNameSpace__ecere__com__NameSpace * nameSpace; const char * dataTypeString; struct Type * dataType; int typeSize; int defaultAlignment; void (* Initialize)(); int memberOffset; struct __ecereNameSpace__ecere__sys__OldList selfWatchers; const char * designerClass; unsigned int noExpansion; const char * defaultProperty; unsigned int comRedefinition; int count; int isRemote; unsigned int internalDecl; void * data; unsigned int computeSize; short structAlignment; short pointerAlignment; int destructionWatchOffset; unsigned int fixed; struct __ecereNameSpace__ecere__sys__OldList delayedCPValues; int inheritanceAccess; const char * fullName; void * symbol; struct __ecereNameSpace__ecere__sys__OldList conversions; struct __ecereNameSpace__ecere__sys__OldList templateParams; struct __ecereNameSpace__ecere__com__ClassTemplateArgument * templateArgs; struct __ecereNameSpace__ecere__com__Class * templateClass; struct __ecereNameSpace__ecere__sys__OldList templatized; int numParams; unsigned int isInstanceClass; unsigned int byValueSystemClass; } ecere_gcc_struct; struct __ecereNameSpace__ecere__com__Application { int argc; const char * * argv; int exitCode; unsigned int isGUIApp; struct __ecereNameSpace__ecere__sys__OldList allModules; char * parsedCommand; struct __ecereNameSpace__ecere__com__NameSpace systemNameSpace; } ecere_gcc_struct; static unsigned int NameSpaceContained(struct __ecereNameSpace__ecere__com__NameSpace * ns, struct __ecereNameSpace__ecere__com__NameSpace * parent) { if(ns == parent) return 1; else if((*ns).parent) return NameSpaceContained((*ns).parent, parent); else return 0; } static void AddSimpleBaseMembers(struct External * external, struct __ecereNameSpace__ecere__sys__OldList * list, struct __ecereNameSpace__ecere__com__Class * _class, struct __ecereNameSpace__ecere__com__Class * topClass) { if(_class->type != 1000) AddMembers(external, list, _class, 0, (((void *)0)), topClass, (((void *)0))); } extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_Symbol; extern struct __ecereNameSpace__ecere__com__Class * __ecereClass_Instantiation; extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Module; extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__Application; extern struct __ecereNameSpace__ecere__com__Class * __ecereClass___ecereNameSpace__ecere__com__LinkList; struct __ecereNameSpace__ecere__com__Module { struct __ecereNameSpace__ecere__com__Instance * application; struct __ecereNameSpace__ecere__sys__OldList classes; struct __ecereNameSpace__ecere__sys__OldList defines; struct __ecereNameSpace__ecere__sys__OldList functions; struct __ecereNameSpace__ecere__sys__OldList modules; struct __ecereNameSpace__ecere__com__Instance * prev; struct __ecereNameSpace__ecere__com__Instance * next; const char * name; void * library; void * Unload; int importType; int origImportType; struct __ecereNameSpace__ecere__com__NameSpace privateNameSpace; struct __ecereNameSpace__ecere__com__NameSpace publicNameSpace; } ecere_gcc_struct; void __ecereUnregisterModule_pass0(struct __ecereNameSpace__ecere__com__Instance * module) { } static void CheckPublicClass(struct Symbol * classSym, int access, const char * word) { struct __ecereNameSpace__ecere__com__Class * regClass = classSym ? classSym->__anon1.registered : (((void *)0)); if(regClass) { if(regClass->templateClass) regClass = regClass->templateClass; if(classSym->isStatic && access != 3) { Compiler_Error(__ecereNameSpace__ecere__GetTranslatedString("ec", "Non-static %s making use of a static class\n", (((void *)0))), word); } else if(access == 1) { if(!NameSpaceContained(regClass->nameSpace, &((struct __ecereNameSpace__ecere__com__Application *)(((char *)((struct __ecereNameSpace__ecere__com__Module *)(((char *)regClass->module + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->application + sizeof(struct __ecereNameSpace__ecere__com__Module) + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->systemNameSpace)) { if(NameSpaceContained(regClass->nameSpace, &((struct __ecereNameSpace__ecere__com__Module *)(((char *)regClass->module + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->privateNameSpace) || !ModuleAccess(privateModule, regClass->module)) Compiler_Error(__ecereNameSpace__ecere__GetTranslatedString("ec", "Public %s making use of a private class\n", (((void *)0))), word); } } } } static void ProcessClass(int classType, struct __ecereNameSpace__ecere__sys__OldList * definitions, struct Symbol * symbol, struct __ecereNameSpace__ecere__sys__OldList * baseSpecs, struct __ecereNameSpace__ecere__sys__OldList * enumValues, struct Location * loc, struct __ecereNameSpace__ecere__sys__OldList * defs, void * after, struct __ecereNameSpace__ecere__sys__OldList * initDeclarators, struct ExtDecl * extDecl) { char structName[1024]; char className[1024]; char constructorName[1024]; char destructorName[1024]; struct __ecereNameSpace__ecere__com__Class * regClass; struct ClassFunction * destructor = (((void *)0)), * constructor = (((void *)0)); unsigned int isUnion = classType == 6; struct External * external = (((void *)0)); struct ClassDef * def; struct __ecereNameSpace__ecere__sys__OldList * list = (((void *)0)); struct __ecereNameSpace__ecere__sys__OldList * classDataList = (((void *)0)); if(inCompiler) { list = MkList(); classDataList = MkList(); } regClass = __ecereNameSpace__ecere__com__eSystem_FindClass(privateModule, symbol->string); if(!regClass) return ; classType = regClass->type; if(inCompiler && regClass->base) { yylloc = *loc; if(!NameSpaceContained(regClass->nameSpace, &((struct __ecereNameSpace__ecere__com__Module *)(((char *)regClass->module + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->privateNameSpace) && regClass->inheritanceAccess == 1) { if(!regClass->base->symbol) regClass->base->symbol = FindClass(regClass->base->fullName); CheckPublicClass(regClass->base->symbol, 1, __ecereNameSpace__ecere__GetTranslatedString("ec", "class", (((void *)0)))); } else if(!symbol->isStatic && regClass->base) { if(!regClass->base->symbol) regClass->base->symbol = FindClass(regClass->base->fullName); CheckPublicClass(regClass->base->symbol, 2, __ecereNameSpace__ecere__GetTranslatedString("ec", "class", (((void *)0)))); } } if(definitions != (((void *)0))) { for(def = definitions->first; def; def = def->next) { if(def->type == 13) { struct __ecereNameSpace__ecere__com__DataMember * member; struct __ecereNameSpace__ecere__com__Property * prop; struct __ecereNameSpace__ecere__com__Method * method; if((prop = __ecereNameSpace__ecere__com__eClass_FindProperty(regClass, def->__anon1.__anon1.id->string, privateModule))) { __ecereNameSpace__ecere__com__eClass_AddProperty(regClass, def->__anon1.__anon1.id->string, (((void *)0)), (((void *)0)), (((void *)0)), def->memberAccess); } else if((member = __ecereNameSpace__ecere__com__eClass_FindDataMember(regClass, def->__anon1.__anon1.id->string, privateModule, (((void *)0)), (((void *)0))))) { __ecereNameSpace__ecere__com__eClass_AddDataMember(regClass, def->__anon1.__anon1.id->string, (((void *)0)), 0, 0, def->memberAccess); } else if((method = __ecereNameSpace__ecere__com__eClass_FindMethod(regClass, def->__anon1.__anon1.id->string, privateModule))) { __ecereNameSpace__ecere__com__eClass_AddMethod(regClass, def->__anon1.__anon1.id->string, (((void *)0)), (((void *)0)), def->memberAccess); } else { yylloc = def->loc; Compiler_Error(__ecereNameSpace__ecere__GetTranslatedString("ec", "Couldn't find member %s to override\n", (((void *)0))), def->__anon1.__anon1.id->string); } } } } if(inCompiler) { external = MkExternalDeclaration((((void *)0))); __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert(defs, after, external); curExternal = external; curExternal->symbol = symbol; } if((classType == 1 || classType == 5) && inCompiler) { AddSimpleBaseMembers(external, list, regClass->base, regClass); } if(definitions != (((void *)0))) { if(inCompiler) { if(!NameSpaceContained(regClass->nameSpace, &((struct __ecereNameSpace__ecere__com__Module *)(((char *)regClass->module + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->privateNameSpace)) CheckMembersDefinitions(regClass, (((void *)0)), definitions, 1); else if(!symbol->isStatic) CheckMembersDefinitions(regClass, (((void *)0)), definitions, 2); } for(def = definitions->first; def; def = def->next) { yylloc = def->loc; if(def->type == 2) { struct Declaration * decl = def->__anon1.decl; yylloc = decl->loc; if(decl->type == 0) { if(inCompiler && classType != 2) { ListAdd(list, MkClassDefDeclaration(decl)); def->__anon1.decl = (((void *)0)); } } else if(decl->type == 2) { struct Instantiation * inst = decl->__anon1.inst; struct Expression * exp = inst->exp; struct Symbol * classSym; if(exp) { struct __ecereNameSpace__ecere__sys__OldList * specifiers = MkList(); struct Declarator * d; ListAdd(specifiers, MkSpecifierName(inst->_class->__anon1.__anon1.name)); d = MkDeclaratorIdentifier(MkIdentifier(exp->__anon1.__anon1.identifier->string)); if(inCompiler) { struct __ecereNameSpace__ecere__sys__OldList * declarators = MkList(); ListAdd(declarators, d); decl = MkStructDeclaration(specifiers, declarators, (((void *)0))); ListAdd(list, MkClassDefDeclaration(decl)); exp->type = 8; exp->__anon1.member.member = exp->__anon1.__anon1.identifier; exp->__anon1.member.exp = QMkExpId("this"); exp->__anon1.member.memberType = 3; exp->__anon1.member.thisPtr = 1; } else { FreeDeclarator(d); FreeList(specifiers, (void *)(FreeSpecifier)); } } classSym = inst->_class->__anon1.__anon1.symbol; if(classSym && classSym->__anon1.registered && (classSym->__anon1.registered->type == 1 || classSym->__anon1.registered->type == 2 || classSym->__anon1.registered->type == 3)) { if(inst->members && (*inst->members).count) symbol->needConstructor = 1; } else { symbol->needConstructor = 1; symbol->needDestructor = 1; } } } else if(def->type == 9) { struct Declaration * decl = def->__anon1.decl; if(decl->type == 0) { if(inCompiler && classType != 2) { ListAdd(classDataList, MkClassDefDeclaration(decl)); def->__anon1.decl = (((void *)0)); } } } else if(def->type == 1) symbol->needConstructor = 1; else if(def->type == 4) symbol->needConstructor = 1; else if(def->type == 0) { struct ClassFunction * func = def->__anon1.function; if(func->isDestructor) { if(destructor) { yylloc = *loc; Compiler_Error(__ecereNameSpace__ecere__GetTranslatedString("ec", "redefinition of destructor for class %s\n", (((void *)0))), symbol->string); } else { symbol->needDestructor = 1; destructor = func; if(!inCompiler && func->body) { struct Symbol * thisSymbol = (thisSymbol = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Symbol), thisSymbol->string = __ecereNameSpace__ecere__sys__CopyString("this"), thisSymbol->type = MkClassType(regClass->fullName), thisSymbol); __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Add(&func->body->__anon1.compound.context->symbols, (struct __ecereNameSpace__ecere__sys__BTNode *)thisSymbol); } } } if(func->isConstructor) { if(constructor) { yylloc = *loc; Compiler_Error(__ecereNameSpace__ecere__GetTranslatedString("ec", "redefinition of constructor for class %s\n", (((void *)0))), symbol->string); } else { symbol->needConstructor = 1; constructor = func; if(!inCompiler && func->body) { struct Symbol * thisSymbol = (thisSymbol = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Symbol), thisSymbol->string = __ecereNameSpace__ecere__sys__CopyString("this"), thisSymbol->type = MkClassType(regClass->fullName), thisSymbol); __ecereMethod___ecereNameSpace__ecere__sys__BinaryTree_Add(&func->body->__anon1.compound.context->symbols, (struct __ecereNameSpace__ecere__sys__BTNode *)thisSymbol); } } } } } } if(inCompiler) { external->symbol = (((void *)0)); if((*list).count) { struct __ecereNameSpace__ecere__sys__OldList * specs = MkList(), * declarators = (initDeclarators != (((void *)0))) ? initDeclarators : MkList(); initDeclarators = (((void *)0)); strcpy(structName, symbol->string); symbol->structName = __ecereNameSpace__ecere__sys__CopyString(structName); { struct Specifier * spec = MkStructOrUnion(3, MkIdentifier(structName), isUnion ? MkListOne(MkClassDefDeclaration(MkStructDeclaration(MkListOne(MkStructOrUnion(4, (((void *)0)), list)), (((void *)0)), (((void *)0))))) : list); spec->__anon1.__anon2.extDeclStruct = extDecl; ListAdd(specs, spec); } external->symbol = symbol; if(symbol->__anon2.__anon1.structExternal) { { struct TopoEdge * e; struct __ecereNameSpace__ecere__com__Instance * __internalLinkList = symbol->__anon2.__anon1.structExternal->incoming; for(e = ((struct __ecereNameSpace__ecere__com__LinkList *)(((char *)__internalLinkList + 0 + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->first; e; e = (struct TopoEdge *)((struct __ecereNameSpace__ecere__com__IteratorPointer * (*)(struct __ecereNameSpace__ecere__com__Instance *, struct __ecereNameSpace__ecere__com__IteratorPointer * pointer))__extension__ ({ struct __ecereNameSpace__ecere__com__Instance * __internal_ClassInst = __internalLinkList; __internal_ClassInst ? __internal_ClassInst->_vTbl : __ecereClass___ecereNameSpace__ecere__com__LinkList->_vTbl; })[__ecereVMethodID___ecereNameSpace__ecere__com__Container_GetNext])(__internalLinkList, (struct __ecereNameSpace__ecere__com__IteratorPointer *)e)) __ecereMethod_External_CreateUniqueEdge(external, e->from, e->breakable); } { struct TopoEdge * e; struct __ecereNameSpace__ecere__com__Instance * __internalLinkList = symbol->__anon2.__anon1.structExternal->outgoing; for(e = ((struct __ecereNameSpace__ecere__com__LinkList *)(((char *)__internalLinkList + 0 + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->first; e; e = (struct TopoEdge *)((struct __ecereNameSpace__ecere__com__IteratorPointer * (*)(struct __ecereNameSpace__ecere__com__Instance *, struct __ecereNameSpace__ecere__com__IteratorPointer * pointer))__extension__ ({ struct __ecereNameSpace__ecere__com__Instance * __internal_ClassInst = __internalLinkList; __internal_ClassInst ? __internal_ClassInst->_vTbl : __ecereClass___ecereNameSpace__ecere__com__LinkList->_vTbl; })[__ecereVMethodID___ecereNameSpace__ecere__com__Container_GetNext])(__internalLinkList, (struct __ecereNameSpace__ecere__com__IteratorPointer *)e)) __ecereMethod_External_CreateUniqueEdge(e->to, external, e->breakable); } __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove((&*ast), symbol->__anon2.__anon1.structExternal); FreeExternal(symbol->__anon2.__anon1.structExternal); } symbol->__anon2.__anon1.structExternal = external; external->__anon1.declaration = MkDeclaration(specs, declarators); after = external; symbol->declaredStruct = 1; } else { curExternal = external->prev; __ecereMethod___ecereNameSpace__ecere__sys__OldList_Remove(defs, external); FreeExternal(external); (__ecereNameSpace__ecere__com__eSystem_Delete(list), list = 0); } if((*classDataList).count) { char classDataStructName[1024]; struct __ecereNameSpace__ecere__sys__OldList * specs = MkList(); struct External * external; strcpy(classDataStructName, "__ecereClassData_"); FullClassNameCat(classDataStructName, symbol->string, 0); declMode = structDeclMode = 0; ListAdd(specs, MkStructOrUnion(3, MkIdentifier(classDataStructName), classDataList)); external = MkExternalDeclaration(MkDeclaration(specs, (((void *)0)))); __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert(defs, after, external); after = external; symbol->classData = 1; } else (__ecereNameSpace__ecere__com__eSystem_Delete(classDataList), classDataList = 0); } if(inCompiler) { { struct __ecereNameSpace__ecere__sys__OldList * specs = MkList(), * declarators = MkList(); strcpy(className, "__ecereClass_"); FullClassNameCat(className, symbol->string, 1); symbol->className = __ecereNameSpace__ecere__sys__CopyString(className); if(!strstr(sourceFile, ".main.ec")) ListAdd(specs, MkSpecifier(STATIC)); ListAdd(specs, MkStructOrUnion(3, MkIdentifier("__ecereNameSpace__ecere__com__Class"), (((void *)0)))); ListAdd(declarators, MkInitDeclarator(MkDeclaratorPointer(MkPointer((((void *)0)), (((void *)0))), MkDeclaratorIdentifier(MkIdentifier(className))), (((void *)0)))); symbol->__anon2.__anon1.pointerExternal = MkExternalDeclaration(MkDeclaration(specs, declarators)); DeclareStruct(symbol->__anon2.__anon1.pointerExternal, "ecere::com::Class", 0, 1); __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert(defs, after, symbol->__anon2.__anon1.pointerExternal); after = symbol->__anon2.__anon3.methodExternal; } if(symbol->needDestructor) { struct ClassFunction * function; struct __ecereNameSpace__ecere__sys__OldList * specs = MkList(); struct Declarator * decl; struct Statement * body; struct Context * context; struct __ecereNameSpace__ecere__sys__OldList * declarations = (((void *)0)), * statements; strcpy(destructorName, "__ecereDestructor_"); FullClassNameCat(destructorName, symbol->string, 0); symbol->destructorName = __ecereNameSpace__ecere__sys__CopyString(destructorName); ListAdd(specs, MkSpecifier(VOID)); context = PushContext(); statements = MkList(); if(definitions != (((void *)0))) { for(def = definitions->first; def; def = def->next) { if(def->type == 2 && def->__anon1.decl && def->__anon1.decl->type == 2) { struct Instantiation * inst = def->__anon1.decl->__anon1.inst; struct Symbol * classSym = inst->_class->__anon1.__anon1.symbol; if(inst->exp && (!classSym || !classSym->__anon1.registered || classSym->__anon1.registered->type == 0)) { struct Expression * exp = MkExpOp((((void *)0)), DELETE, CopyExpression(inst->exp)); ListAdd(statements, MkExpressionStmt(MkListOne(exp))); } if(inst->exp && (!classSym || !classSym->__anon1.registered || classSym->__anon1.registered->type == 5)) { struct Expression * exp = MkExpOp((((void *)0)), DELETE, CopyExpression(inst->exp)); ListAdd(statements, MkExpressionStmt(MkListOne(exp))); } } } } if(destructor && destructor->body) { __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert((&*statements), (((void *)0)), destructor->body); destructor->body->__anon1.compound.context->parent = context; destructor->body = (((void *)0)); } body = MkCompoundStmt(declarations, statements); PopContext(context); body->__anon1.compound.context = context; decl = MkDeclaratorFunction(MkDeclaratorIdentifier(MkIdentifier(destructorName)), (((void *)0))); decl->symbol = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Symbol); __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add((&*excludedSymbols), decl->symbol); function = MkClassFunction(specs, (((void *)0)), decl, (((void *)0))); ProcessClassFunctionBody(function, body); function->dontMangle = 1; __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert(definitions, (((void *)0)), MkClassDefFunction(function)); } if(symbol->needConstructor && inCompiler) { struct ClassFunction * function; struct __ecereNameSpace__ecere__sys__OldList * specs = MkList(); struct Declarator * decl; struct Statement * body; struct Context * context; struct __ecereNameSpace__ecere__sys__OldList * declarations = (((void *)0)), * statements; strcpy(constructorName, "__ecereConstructor_"); FullClassNameCat(constructorName, symbol->string, 0); symbol->constructorName = __ecereNameSpace__ecere__sys__CopyString(constructorName); ListAdd(specs, MkSpecifierName("bool")); context = PushContext(); statements = MkList(); if(definitions != (((void *)0))) { for(def = definitions->first; def; def = def->next) { if(def->type == 2 && def->__anon1.decl && def->__anon1.decl->type == 2) { struct Instantiation * inst = def->__anon1.decl->__anon1.inst; struct Symbol * classSym = inst->_class->__anon1.__anon1.symbol; if(inst->exp && (!classSym || !classSym->__anon1.registered || classSym->__anon1.registered->type == 0 || classSym->__anon1.registered->type == 5)) { struct Instantiation * newInst = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Instantiation); *newInst = *inst; newInst->members = (((void *)0)); newInst->exp = CopyExpression(inst->exp); newInst->_class = CopySpecifier(inst->_class); ListAdd(statements, MkExpressionStmt(MkListOne(MkExpInstance(newInst)))); inst->built = 1; } if(inst->exp && (!classSym || !classSym->__anon1.registered || classSym->__anon1.registered->type == 0)) { ListAdd(statements, MkExpressionStmt(MkListOne(MkExpCall(MkExpIdentifier(MkIdentifier("ecere::com::eInstance_IncRef")), MkListOne(CopyExpression(inst->exp)))))); } } } for(def = definitions->first; def; def = def->next) { if(def->type == 1 && def->__anon1.defProperties) { struct MemberInit * propertyDef; for(propertyDef = (*def->__anon1.defProperties).first; propertyDef; propertyDef = propertyDef->next) { struct Expression * memberExp; struct Identifier * id = (*propertyDef->identifiers).first; if(id) { memberExp = MkExpMember(MkExpIdentifier(MkIdentifier("this")), id); for(id = id->next; id; id = id->next) memberExp = MkExpMember(memberExp, id); ListAdd(statements, MkExpressionStmt(MkListOne(MkExpOp(memberExp, '=', (propertyDef->initializer && propertyDef->initializer->type == 0 ? propertyDef->initializer->__anon1.exp : (((void *)0))))))); } if(propertyDef->initializer) { if(propertyDef->initializer->type == 0) propertyDef->initializer->__anon1.exp = (((void *)0)); FreeInitializer(propertyDef->initializer); } propertyDef->initializer = (((void *)0)); __ecereMethod___ecereNameSpace__ecere__sys__OldList_Clear((&*propertyDef->identifiers)); } } } for(def = definitions->first; def; def = def->next) { if(def->type == 2 && def->__anon1.decl && def->__anon1.decl->type == 2) { struct Instantiation * inst = def->__anon1.decl->__anon1.inst; struct Symbol * classSym = inst->_class->__anon1.__anon1.symbol; if(inst->exp || (!classSym || !classSym->__anon1.registered || classSym->__anon1.registered->type == 0 || classSym->__anon1.registered->type == 5)) { if(!(inst->exp && (!classSym || !classSym->__anon1.registered || classSym->__anon1.registered->type == 0 || classSym->__anon1.registered->type == 5)) || (inst->members && (*inst->members).count)) { def->__anon1.decl->__anon1.inst = (((void *)0)); ListAdd(statements, MkExpressionStmt(MkListOne(MkExpInstance(inst)))); } } } } } if(constructor && constructor->body) { __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add((&*statements), constructor->body); constructor->body->__anon1.compound.context->parent = context; constructor->body = (((void *)0)); } ListAdd(statements, MkReturnStmt(MkListOne(MkExpIdentifier(MkIdentifier("true"))))); body = MkCompoundStmt(declarations, statements); PopContext(context); body->__anon1.compound.context = context; decl = MkDeclaratorFunction(MkDeclaratorIdentifier(MkIdentifier(constructorName)), (((void *)0))); decl->symbol = __ecereNameSpace__ecere__com__eInstance_New(__ecereClass_Symbol); __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add((&*excludedSymbols), decl->symbol); function = MkClassFunction(specs, (((void *)0)), decl, (((void *)0))); ProcessClassFunctionBody(function, body); function->dontMangle = 1; if(definitions != (((void *)0))) __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert(definitions, (((void *)0)), MkClassDefFunction(function)); } } if(definitions != (((void *)0))) { for(def = definitions->first; def; def = def->next) { if(def->type == 3 && def->__anon1.propertyDef) { struct PropertyDef * propertyDef = def->__anon1.propertyDef; struct ClassDef * after = def; struct ClassDef * newDef; if(inCompiler) { yylloc = propertyDef->loc; if(!NameSpaceContained(regClass->nameSpace, &((struct __ecereNameSpace__ecere__com__Module *)(((char *)regClass->module + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->privateNameSpace) && def->memberAccess == 1) CheckPublicDataType(propertyDef->symbol->type, 1, "class property"); else if(!symbol->isStatic) CheckPublicDataType(propertyDef->symbol->type, 2, "class property"); } { { struct ClassFunction * func; struct Declarator * decl; char name[1024]; struct __ecereNameSpace__ecere__sys__OldList * params; if(propertyDef->getStmt && propertyDef->id) { strcpy(name, "__ecereProp_"); FullClassNameCat(name, symbol->string, 0); strcat(name, "_Get_"); FullClassNameCat(name, propertyDef->id->string, 1); params = MkList(); if(propertyDef->symbol->type && propertyDef->symbol->type->kind == 8 && propertyDef->symbol->type->__anon1._class && propertyDef->symbol->type->__anon1._class->__anon1.registered && propertyDef->symbol->type->__anon1._class->__anon1.registered->type == 1) { ListAdd(params, MkTypeName(CopyList(propertyDef->specifiers, (void *)(CopySpecifier)), MkDeclaratorIdentifier(MkIdentifier("value")))); decl = PlugDeclarator(propertyDef->declarator, MkDeclaratorFunction(MkDeclaratorIdentifier(MkIdentifier(name)), params)); func = MkClassFunction(MkListOne(MkSpecifier(VOID)), (((void *)0)), decl, (((void *)0))); } else { decl = PlugDeclarator(propertyDef->declarator, MkDeclaratorFunction(MkDeclaratorIdentifier(MkIdentifier(name)), params)); func = MkClassFunction(CopyList(propertyDef->specifiers, (void *)(CopySpecifier)), (((void *)0)), decl, (((void *)0))); } ProcessClassFunctionBody(func, propertyDef->getStmt); func->declarator->symbol = propertyDef->symbol; propertyDef->symbol->__anon2.__anon2.externalGet = (struct External *)func; func->dontMangle = 1; newDef = MkClassDefFunction(func); __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert(definitions, after, newDef); after = newDef; if(inCompiler) propertyDef->getStmt = (((void *)0)); else func->body = (((void *)0)); } if(propertyDef->setStmt && propertyDef->id) { struct __ecereNameSpace__ecere__sys__OldList * specifiers = MkList(); strcpy(name, "__ecereProp_"); FullClassNameCat(name, symbol->string, 0); strcat(name, "_Set_"); FullClassNameCat(name, propertyDef->id->string, 1); params = MkList(); ListAdd(params, MkTypeName(CopyList(propertyDef->specifiers, (void *)(CopySpecifier)), PlugDeclarator(propertyDef->declarator, MkDeclaratorIdentifier(MkIdentifier("value"))))); if(propertyDef->__anon1.isDBProp) { struct Specifier * spec; struct __ecereNameSpace__ecere__sys__OldList * specs = ((struct TypeName *)(*params).last)->qualifiers; for(spec = (*specs).first; spec; spec = spec->next) if(spec->type == 0 && spec->__anon1.specifier == CONST) break; if(!spec) __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert((&*specs), (((void *)0)), MkSpecifier(CONST)); } decl = MkDeclaratorFunction(MkDeclaratorIdentifier(MkIdentifier(name)), params); { unsigned int isConversion = propertyDef->symbol->__anon1._property && propertyDef->symbol->__anon1._property->conversion; unsigned int useVoid = 0; switch(regClass->type) { case 1: case 6: useVoid = 1; break; case 5: case 0: useVoid = !isConversion; break; default: useVoid = !isConversion; if(useVoid && !propertyDef->__anon1.isDBProp) Compiler_Warning(__ecereNameSpace__ecere__GetTranslatedString("ec", "set defined on type without storage for non-conversion property\n", (((void *)0)))); } ListAdd(specifiers, useVoid ? MkSpecifier(VOID) : MkSpecifierName(regClass->fullName)); } func = MkClassFunction(specifiers, (((void *)0)), decl, (((void *)0))); ProcessClassFunctionBody(func, propertyDef->setStmt); func->dontMangle = 1; func->declarator->symbol = propertyDef->symbol; propertyDef->symbol->__anon2.__anon2.externalSet = (struct External *)func; if(!propertyDef->__anon1.conversion && regClass->type == 0) func->propSet = propertyDef->symbol; newDef = MkClassDefFunction(func); __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert(definitions, after, newDef); after = newDef; if(inCompiler) propertyDef->setStmt = (((void *)0)); else func->body = (((void *)0)); } if(propertyDef->issetStmt && propertyDef->id) { struct __ecereNameSpace__ecere__sys__OldList * specifiers = MkList(); strcpy(name, "__ecereProp_"); FullClassNameCat(name, symbol->string, 0); strcat(name, "_IsSet_"); FullClassNameCat(name, propertyDef->id->string, 1); params = MkList(); decl = MkDeclaratorFunction(MkDeclaratorIdentifier(MkIdentifier(name)), params); ListAdd(specifiers, MkSpecifierName("bool")); func = MkClassFunction(specifiers, (((void *)0)), decl, (((void *)0))); ProcessClassFunctionBody(func, propertyDef->issetStmt); func->dontMangle = 1; func->declarator->symbol = propertyDef->symbol; propertyDef->symbol->__anon2.__anon2.externalIsSet = (struct External *)func; newDef = MkClassDefFunction(func); __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert(definitions, after, newDef); after = newDef; if(inCompiler) propertyDef->issetStmt = (((void *)0)); else func->body = (((void *)0)); } if(propertyDef->id && inCompiler) { struct __ecereNameSpace__ecere__com__Property * prop = __ecereNameSpace__ecere__com__eClass_FindProperty(symbol->__anon1.registered, propertyDef->id->string, privateModule); struct Declaration * decl; struct External * external; struct __ecereNameSpace__ecere__sys__OldList * specifiers = MkList(); __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert((&*specifiers), (((void *)0)), MkSpecifier(STATIC)); __ecereMethod___ecereNameSpace__ecere__sys__OldList_Add((&*specifiers), MkSpecifierExtended(MkExtDeclAttrib(MkAttrib(ATTRIB, MkListOne(MkAttribute(__ecereNameSpace__ecere__sys__CopyString("unused"), (((void *)0)))))))); ListAdd(specifiers, MkSpecifierName("Property")); strcpy(name, "__ecereProp_"); FullClassNameCat(name, symbol->string, 0); strcat(name, "_"); FullClassNameCat(name, propertyDef->id->string, 1); { struct __ecereNameSpace__ecere__sys__OldList * list = MkList(); ListAdd(list, MkInitDeclarator(MkDeclaratorIdentifier(MkIdentifier(name)), (((void *)0)))); strcpy(name, "__ecerePropM_"); FullClassNameCat(name, symbol->string, 0); strcat(name, "_"); FullClassNameCat(name, propertyDef->id->string, 1); ListAdd(list, MkInitDeclarator(MkDeclaratorIdentifier(MkIdentifier(name)), (((void *)0)))); decl = MkDeclaration(specifiers, list); } external = MkExternalDeclaration(decl); __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert((&*ast), curExternal ? curExternal->prev : (((void *)0)), external); external->symbol = propertyDef->symbol; propertyDef->symbol->__anon2.__anon2.externalPtr = external; if(inCompiler && prop && prop->symbol) ((struct Symbol *)prop->symbol)->__anon2.__anon2.externalPtr = external; } } } } else if(def->type == 10 && def->__anon1.propertyDef) { struct PropertyDef * propertyDef = def->__anon1.propertyDef; struct ClassDef * after = def; struct ClassDef * newDef; { if(inCompiler) { yylloc = propertyDef->loc; if(!NameSpaceContained(regClass->nameSpace, &((struct __ecereNameSpace__ecere__com__Module *)(((char *)regClass->module + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->privateNameSpace)) CheckPublicDataType(propertyDef->symbol->type, 1, "classwide property"); else if(!symbol->isStatic) CheckPublicDataType(propertyDef->symbol->type, 2, "classwide property"); } { struct ClassFunction * func; struct Declarator * decl; char name[1024]; struct __ecereNameSpace__ecere__sys__OldList * params; if(propertyDef->getStmt && propertyDef->id) { struct Declarator * declId; sprintf(name, "class::__ecereClassProp_"); FullClassNameCat(name, symbol->string, 0); strcat(name, "_Get_"); strcat(name, propertyDef->id->string); params = MkList(); declId = MkDeclaratorIdentifier(MkIdentifier(name)); { decl = MkDeclaratorFunction(declId, params); func = MkClassFunction(MkListOne(MkSpecifierName("uint64")), (((void *)0)), decl, (((void *)0))); } ProcessClassFunctionBody(func, propertyDef->getStmt); func->declarator->symbol = propertyDef->symbol; propertyDef->symbol->__anon2.__anon2.externalGet = (struct External *)func; func->dontMangle = 1; newDef = MkClassDefFunction(func); __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert(definitions, after, newDef); after = newDef; decl = PlugDeclarator(propertyDef->declarator, MkDeclaratorFunction((((void *)0)), (((void *)0)))); func->type = ProcessType(propertyDef->specifiers, decl); FreeDeclarator(decl); if(func->type->__anon1.__anon2.returnType->kind == 8 && func->type->__anon1.__anon2.returnType->__anon1._class && func->type->__anon1.__anon2.returnType->__anon1._class->__anon1.registered && func->type->__anon1.__anon2.returnType->__anon1._class->__anon1.registered->type == 1) func->type->__anon1.__anon2.returnType->byReference = 1; func->type->__anon1.__anon2.returnType->passAsTemplate = 1; if(inCompiler) propertyDef->getStmt = (((void *)0)); else func->body = (((void *)0)); } if(propertyDef->setStmt && propertyDef->id) { struct Context * prevCurContext; struct __ecereNameSpace__ecere__sys__OldList * specifiers = MkList(); struct Statement * body = propertyDef->setStmt; struct Declarator * ptrDecl; struct Expression * e; strcpy(name, "class::__ecereClassProp_"); FullClassNameCat(name, symbol->string, 0); strcat(name, "_Set_"); strcat(name, propertyDef->id->string); params = MkList(); prevCurContext = curContext; curContext = body->__anon1.compound.context; ListAdd(params, MkTypeName(MkListOne(MkSpecifierName("uint64")), MkDeclaratorIdentifier(MkIdentifier("_value")))); decl = MkDeclaratorFunction(MkDeclaratorIdentifier(MkIdentifier(name)), params); if(!body->__anon1.compound.declarations) body->__anon1.compound.declarations = MkList(); if(propertyDef->symbol->type && propertyDef->symbol->type->kind == 8 && propertyDef->symbol->type->__anon1._class && propertyDef->symbol->type->__anon1._class->__anon1.registered && propertyDef->symbol->type->__anon1._class->__anon1.registered->type == 1) ptrDecl = MkDeclaratorPointer(MkPointer((((void *)0)), (((void *)0))), PlugDeclarator(propertyDef->declarator, MkDeclaratorIdentifier(MkIdentifier("value")))); else ptrDecl = PlugDeclarator(propertyDef->declarator, MkDeclaratorIdentifier(MkIdentifier("value"))); e = MkExpIdentifier(MkIdentifier("_value")); if(__ecereProp_Type_Get_isPointerType(propertyDef->symbol->type)) e = MkExpCast(MkTypeName(MkListOne(MkSpecifierName("uintptr")), (((void *)0))), e); ListAdd(body->__anon1.compound.declarations, MkDeclaration(CopyList(propertyDef->specifiers, (void *)(CopySpecifier)), MkListOne(MkInitDeclarator(ptrDecl, MkInitializerAssignment(MkExpCast(MkTypeName(CopyList(propertyDef->specifiers, (void *)(CopySpecifier)), CopyDeclarator(propertyDef->declarator)), e)))))); curContext = prevCurContext; { struct Symbol * sym = ptrDecl->symbol; sym->isParam = 1; FreeType(sym->type); sym->type = ProcessType(propertyDef->specifiers, propertyDef->declarator); } ListAdd(specifiers, MkSpecifier(VOID)); func = MkClassFunction(specifiers, (((void *)0)), decl, (((void *)0))); ProcessClassFunctionBody(func, propertyDef->setStmt); func->dontMangle = 1; func->declarator->symbol = propertyDef->symbol; propertyDef->symbol->__anon2.__anon2.externalSet = (struct External *)func; newDef = MkClassDefFunction(func); __ecereMethod___ecereNameSpace__ecere__sys__OldList_Insert(definitions, after, newDef); after = newDef; if(inCompiler) propertyDef->setStmt = (((void *)0)); else func->body = (((void *)0)); } } } } else if(def->type == 0 && def->__anon1.function->declarator) { struct ClassFunction * func = def->__anon1.function; func->_class = regClass; if(!func->dontMangle) { struct Declarator * funcDecl = GetFuncDecl(func->declarator); struct Identifier * id = GetDeclId(funcDecl); struct __ecereNameSpace__ecere__com__Method * method; if(!funcDecl->__anon1.function.parameters || !(*funcDecl->__anon1.function.parameters).first) { if(!funcDecl->__anon1.function.parameters) funcDecl->__anon1.function.parameters = MkList(); ListAdd(funcDecl->__anon1.function.parameters, MkTypeName(MkListOne(MkSpecifier(VOID)), (((void *)0)))); } method = __ecereNameSpace__ecere__com__eClass_FindMethod(regClass, id->string, privateModule); FreeSpecifier(id->_class); id->_class = (((void *)0)); if(inCompiler && method) { char * newId = __ecereNameSpace__ecere__com__eSystem_New(sizeof(char) * (strlen(id->string) + strlen("__ecereMethod___ecereNameSpace__") + strlen(symbol->string) + 2)); newId[0] = '\0'; ProcessMethodType(method); yylloc = def->loc; if(!NameSpaceContained(regClass->nameSpace, &((struct __ecereNameSpace__ecere__com__Module *)(((char *)regClass->module + sizeof(struct __ecereNameSpace__ecere__com__Instance))))->privateNameSpace) && method->memberAccess == 1) CheckPublicDataType(method->dataType, 1, "class method"); strcpy(newId, "__ecereMethod_"); FullClassNameCat(newId, symbol->string, 0); strcat(newId, "_"); strcat(newId, id->string); (__ecereNameSpace__ecere__com__eSystem_Delete(id->string), id->string = 0); id->string = newId; if(method->type != 1) { if(method->symbol) { (__ecereNameSpace__ecere__com__eSystem_Delete(((struct Symbol *)method->symbol)->string), ((struct Symbol *)method->symbol)->string = 0); ((struct Symbol *)method->symbol)->string = __ecereNameSpace__ecere__sys__CopyString(newId); } } } } } } } if(initDeclarators != (((void *)0))) FreeList(initDeclarators, (void *)(FreeInitDeclarator)); } void PreProcessClassDefinitions() { struct External * external, * next; curExternal = (((void *)0)); if(ast) { for(external = (*ast).first; external; external = next) { next = external->next; curExternal = external; if(external->type == 2) { struct ClassDefinition * _class = external->__anon1._class; if(_class->definitions) { ProcessClass(0, _class->definitions, _class->symbol, _class->baseSpecs, (((void *)0)), &_class->loc, ast, external->prev, (((void *)0)), (((void *)0))); } } else if(external->type == 1) { struct Declaration * declaration = external->__anon1.declaration; if(declaration && declaration->type == 1) { if(declaration->__anon1.__anon1.specifiers) { struct Specifier * specifier; for(specifier = (*declaration->__anon1.__anon1.specifiers).first; specifier; specifier = specifier->next) { if((specifier->type == 2 || specifier->type == 3 || specifier->type == 4) && specifier->__anon1.__anon2.id && specifier->__anon1.__anon2.id->string && (declaration->declMode || specifier->__anon1.__anon2.baseSpecs || (specifier->type == 2 && specifier->__anon1.__anon2.definitions))) { struct Symbol * symbol = FindClass(specifier->__anon1.__anon2.id->string); if(symbol) { struct __ecereNameSpace__ecere__sys__OldList * initDeclarators = (((void *)0)); struct ExtDecl * extDecl = specifier->__anon1.__anon2.extDeclStruct; specifier->__anon1.__anon2.extDeclStruct = (((void *)0)); if(inCompiler) { initDeclarators = declaration->__anon1.__anon1.declarators; declaration->__anon1.__anon1.declarators = (((void *)0)); } ProcessClass((specifier->type == 4) ? 6 : 0, specifier->__anon1.__anon2.definitions, symbol, specifier->__anon1.__anon2.baseSpecs, specifier->__anon1.__anon2.list, &specifier->loc, ast, external->prev, initDeclarators, extDecl); } } } } } else if(declaration && inCompiler && declaration->type == 3) { yylloc = declaration->loc; if(declaration->declMode == 1) CheckPublicExpression(declaration->__anon1.__anon2.exp, 1); else if(declaration->declMode != 3) CheckPublicExpression(declaration->__anon1.__anon2.exp, 2); } } else if(external->type == 3) { } else if(inCompiler && external->type == 0) { yylloc = external->__anon1.function->loc; if(!external->__anon1.function->type) external->__anon1.function->type = ProcessType(external->__anon1.function->specifiers, external->__anon1.function->declarator); if(external->__anon1.function->declMode == 1) CheckPublicDataType(external->__anon1.function->type, 1, "function"); else if(external->__anon1.function->declMode != 3) CheckPublicDataType(external->__anon1.function->type, 2, "function"); } } } } void __ecereRegisterModule_pass0(struct __ecereNameSpace__ecere__com__Instance * module) { struct __ecereNameSpace__ecere__com__Class __attribute__((unused)) * class; __ecereNameSpace__ecere__com__eSystem_RegisterFunction("FullClassNameCat", "void FullClassNameCat(char * output, const char * className, bool includeTemplateParams)", FullClassNameCat, module, 1); __ecereNameSpace__ecere__com__eSystem_RegisterFunction("PreProcessClassDefinitions", "void PreProcessClassDefinitions(void)", PreProcessClassDefinitions, module, 1); }