X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;ds=sidebyside;f=lib%2Fas3%2Fimport.c;h=59dbac0e89a2fcdc6287bee42a2d61c77a3a3100;hb=b6ebc39257e2814f08a17d8c179c3991c16053ba;hp=b5290bd672055b15e0000b0b86199dbe6425c23d;hpb=639ac6b9f7a89f10d02c5d9ef41bca3bad4eaf2b;p=swftools.git diff --git a/lib/as3/import.c b/lib/as3/import.c index b5290bd..59dbac0 100644 --- a/lib/as3/import.c +++ b/lib/as3/import.c @@ -23,11 +23,11 @@ #include "abc.h" #include "registry.h" #include "common.h" -#include "common.h" #include "tokenizer.h" +#include "assets.h" #include "../os.h" -static void import_code(void*_abc, char*filename, int pass); +static void import_code(void*_abc, char*filename, int pass, asset_bundle_t*a); void as3_import_abc(char*filename) { @@ -36,8 +36,8 @@ void as3_import_abc(char*filename) tag->data = file->data; tag->len = file->len; abc_file_t*abc = swf_ReadABC(tag); - import_code(abc, filename, 0); - import_code(abc, filename, 1); + import_code(abc, filename, 0, 0); + import_code(abc, filename, 1, 0); swf_FreeABC(abc); memfile_close(file); free(tag); @@ -48,13 +48,17 @@ void as3_import_swf(char*filename) SWF* swf = swf_OpenSWF(filename); if(!swf) return; + swf_FoldAll(swf); + TAG*tag = swf->firstTag; + asset_resolver_t* assets = swf_ParseAssets(swf); + /* pass 1 */ while(tag) { if(tag->id == ST_DOABC || tag->id == ST_RAWABC) { abc_file_t*abc = swf_ReadABC(tag); - import_code(abc, filename, 0); + import_code(abc, filename, 0, 0); swf_FreeABC(abc); } tag = tag->next; @@ -64,15 +68,19 @@ void as3_import_swf(char*filename) /* pass 2 */ while(tag) { if(tag->id == ST_DOABC || tag->id == ST_RAWABC) { - abc_file_t*abc = swf_ReadABC(tag); - import_code(abc, filename, 1); - swf_FreeABC(abc); + abc_file_t*abc = swf_ReadABC(tag); //FIXME: mem leak + swf_ResolveAssets(assets, abc); + NEW(asset_bundle_t, a); + a->file = abc; + registry_add_asset(a); + import_code(abc, filename, 1, a); } tag = tag->next; } - swf_FreeTags(swf); + //swf_FreeTags(swf); // FIXME: mem leak free(swf); + } void as3_import_file(char*filename) @@ -129,7 +137,7 @@ static classinfo_t*resolve_class(char*filename, char*what, multiname_t*n) return c; } -static void import_code(void*_abc, char*filename, int pass) +static void import_code(void*_abc, char*filename, int pass, asset_bundle_t*asset_bundle) { abc_file_t*abc = _abc; int t; @@ -167,6 +175,8 @@ static void import_code(void*_abc, char*filename, int pass) classinfo_t*c = (classinfo_t*)registry_find(package, name); if(!c) continue; + c->assets = asset_bundle; + int nr = 0; multiname_list_t*i = cls->interfaces; while(i) { @@ -191,28 +201,30 @@ static void import_code(void*_abc, char*filename, int pass) goto cont; const char*name = trait->name->name; char* ns = access==ACCESS_NAMESPACE?strdup(trait->name->ns->name):""; - if(registry_findmember(c, ns, name, 0)) + + if(registry_findmember(c, ns, name, 0, is_static)) goto cont; + name = strdup(name); memberinfo_t*s = 0; if(trait->kind == TRAIT_METHOD) { - s = (memberinfo_t*)methodinfo_register_onclass(c, access, ns, name); + s = (memberinfo_t*)methodinfo_register_onclass(c, access, ns, name, is_static); s->return_type = resolve_class(filename, "return type", trait->method->return_type); dict_put(names, name, 0); } else if(trait->kind == TRAIT_SLOT) { - s = (memberinfo_t*)varinfo_register_onclass(c, access, ns, name); + s = (memberinfo_t*)varinfo_register_onclass(c, access, ns, name, is_static); s->type = resolve_class(filename, "type", trait->type_name); dict_put(names, name, 0); } else if(trait->kind == TRAIT_GETTER) { - s = (memberinfo_t*)varinfo_register_onclass(c, access, ns, name); + s = (memberinfo_t*)varinfo_register_onclass(c, access, ns, name, is_static); s->type = resolve_class(filename, "type", trait->method->return_type); dict_put(names, name, 0); } else if(trait->kind == TRAIT_CONST) { /* 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); + varinfo_t*v = (varinfo_t*)varinfo_register_onclass(c, access, ns, name, is_static); 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 @@ -287,6 +299,6 @@ static void import_code(void*_abc, char*filename, int pass) void as3_import_code(void*_abc) { - import_code(_abc, "", 0); - import_code(_abc, "", 1); + import_code(_abc, "", 0, 0); + import_code(_abc, "", 1, 0); }