X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=lib%2Fas3%2Fcode.c;h=acccb6a217ee3250fd9886281334238641ff8bf0;hb=304c3ef8189390db54827a514dcbd7dbb7df1a6e;hp=b125c950001182f233ba871734dda882db54c4e4;hpb=e015e101afe19b7638dab7f207f1d5e5082b57eb;p=swftools.git diff --git a/lib/as3/code.c b/lib/as3/code.c index b125c95..acccb6a 100644 --- a/lib/as3/code.c +++ b/lib/as3/code.c @@ -207,20 +207,18 @@ opcode_t opcodes[]={ {0xff, "__break__", "s", 0, 0, 0, OP_RETURN|OP_INTERNAL}, }; -static U8 op2index[256] = {254}; +static opcode_t* op2op[256] = {0,0,0}; -opcode_t* opcode_get(U8 op) +static inline opcode_t* opcode_get(U8 op) { int t; - if(op2index[0]==254) { - memset(op2index, 255, sizeof(op2index)); + if(!op2op[0x02]) { + memset(op2op, 0, sizeof(op2op)); for(t=0;tnext || 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) @@ -1132,7 +1136,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; }