X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Fas3%2Fimport.c;h=b5290bd672055b15e0000b0b86199dbe6425c23d;hb=639ac6b9f7a89f10d02c5d9ef41bca3bad4eaf2b;hp=c93826f91b49d16d66b3e6c3a8c5bbd1ad1b9aab;hpb=a1dde8db3bde6aa26562dadae696d5d54ef752d2;p=swftools.git diff --git a/lib/as3/import.c b/lib/as3/import.c index c93826f..b5290bd 100644 --- a/lib/as3/import.c +++ b/lib/as3/import.c @@ -103,7 +103,9 @@ static int compare_traits(const void*v1, const void*v2) static classinfo_t*resolve_class(char*filename, char*what, multiname_t*n) { if(!n) return 0; - if(!n->name[0] || !strcmp(n->name, "void")) return 0; + if(!n->name[0]) return 0; + if(!strcmp(n->name, "void")) + return &voidclass; classinfo_t*c = 0; if(n->ns && n->ns->name) { @@ -143,7 +145,7 @@ static void import_code(void*_abc, char*filename, int pass) const char*package = strdup(cls->classname->ns->name); const char*name = strdup(cls->classname->name); - + multiname_list_t*i=cls->interfaces; classinfo_t*c = classinfo_register(access, package, name, list_length(i)); c->flags|=FLAG_BUILTIN; @@ -180,13 +182,15 @@ static void import_code(void*_abc, char*filename, int pass) l = cls->static_traits; is_static = 1; } + dict_t*names = dict_new(); while(l) { trait_t*trait = l->trait; U8 access = trait->name->ns->access; + if(access==ACCESS_PRIVATE) goto cont; const char*name = trait->name->name; - char* ns= ACCESS_NAMESPACE?strdup(trait->name->ns->name):""; + char* ns = access==ACCESS_NAMESPACE?strdup(trait->name->ns->name):""; if(registry_findmember(c, ns, name, 0)) goto cont; name = strdup(name); @@ -195,20 +199,29 @@ static void import_code(void*_abc, char*filename, int pass) if(trait->kind == TRAIT_METHOD) { s = (memberinfo_t*)methodinfo_register_onclass(c, access, ns, name); s->return_type = resolve_class(filename, "return type", trait->method->return_type); - } else if(trait->kind == TRAIT_SLOT || - trait->kind == TRAIT_GETTER) { + dict_put(names, name, 0); + } else if(trait->kind == TRAIT_SLOT) { s = (memberinfo_t*)varinfo_register_onclass(c, access, ns, name); s->type = resolve_class(filename, "type", trait->type_name); -#if 0 // some variables are apparently both a static const and a slot - // needs split of static/non-static first + dict_put(names, name, 0); + } else if(trait->kind == TRAIT_GETTER) { + s = (memberinfo_t*)varinfo_register_onclass(c, access, ns, name); + s->type = resolve_class(filename, "type", trait->method->return_type); + dict_put(names, name, 0); } else if(trait->kind == TRAIT_CONST) { - varinfo_t*v = (varinfo_t*)varinfo_register_onclass(c, access, ns, name); - v->type = resolve_class(filename, "type", trait->type_name); - v->flags |= FLAG_CONST; - /* leave this alone for now- it blows up the file too much - v->value = constant_clone(trait->value);*/ - s = (memberinfo_t*)v; -#endif + /* some variables (e.g. XML.length) are apparently both a method and a slot. + needs split of static/non-static first */ + if(!dict_contains(names, name)) { + varinfo_t*v = (varinfo_t*)varinfo_register_onclass(c, access, ns, name); + v->type = resolve_class(filename, "type", trait->type_name); + v->flags |= FLAG_CONST; + /* leave this alone for now- it blows up the file too much + v->value = constant_clone(trait->value);*/ + s = (memberinfo_t*)v; + dict_put(names, name, 0); + } else + goto cont; + } else { goto cont; } @@ -224,6 +237,7 @@ static void import_code(void*_abc, char*filename, int pass) is_static = 1; } } + dict_destroy(names); } # define IS_PUBLIC_MEMBER(trait) ((trait)->kind != TRAIT_CLASS && (trait)->name->ns->access != ACCESS_PRIVATE)