X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Fas3%2Fcode.c;h=6ef68a33e95c27fe49b452dc5f160332a3d8d6e5;hb=6d87a7d85f89d5b6a22fe6f1e8891ec73ed682f6;hp=233b996ea8286df5b97c2b21e6c1a469dc38a221;hpb=804043c4154176a5158403b9437bf3c17996054e;p=swftools.git diff --git a/lib/as3/code.c b/lib/as3/code.c index 233b996..6ef68a3 100644 --- a/lib/as3/code.c +++ b/lib/as3/code.c @@ -201,9 +201,10 @@ opcode_t opcodes[]={ {0x53, "applytype", "n", -1, 1, 0, OP_STACK_ARGS}, /* dummy instructions. Warning: these are not actually supported by flash */ +{0xfb, "__pushpackage__", "s", 0, 1, 0, OP_INTERNAL}, {0xfc, "__rethrow__", "", 0, 0, 0, OP_THROW|OP_INTERNAL}, -{0xfd, "__fallthrough__", "s", 0, 0, 0, OP_INTERNAL}, -{0xfe, "__continue__", "s", 0, 0, 0, OP_RETURN|OP_INTERNAL}, +{0xfd, "__fallthrough__", "s", 0, 0, 0, OP_INTERNAL}, +{0xfe, "__continue__", "s", 0, 0, 0, OP_RETURN|OP_INTERNAL}, {0xff, "__break__", "s", 0, 0, 0, OP_RETURN|OP_INTERNAL}, }; @@ -847,6 +848,12 @@ void stats_free(currentstats_t*stats) int code_dump(code_t*c) { + code_t*cc = code_start(c); + while(cc) { + assert(!cc->next || cc->next->prev == cc); + cc = cc->next; + } + return code_dump2(c, 0, 0, "", stdout); } int code_dump2(code_t*c, abc_exception_list_t*exceptions, abc_file_t*file, char*prefix, FILE*fo) @@ -1130,7 +1137,7 @@ code_t*code_cut(code_t*c) if(prev) prev->next=next; if(next) next->prev=prev; code_free(c); - + if(next) return code_end(next); else return prev; }