From 102d526983724de1b988b64d7f22d2cf350df5f6 Mon Sep 17 00:00:00 2001 From: kramm Date: Sat, 30 Aug 2003 13:09:39 +0000 Subject: [PATCH] * improved hex output * show hex for undefined tags, too. --- src/swfdump.c | 26 +++++++++++++++++++++----- 1 file changed, 21 insertions(+), 5 deletions(-) diff --git a/src/swfdump.c b/src/swfdump.c index 3e15b6a..5679451 100644 --- a/src/swfdump.c +++ b/src/swfdump.c @@ -548,18 +548,30 @@ void fontcallback2(U16 id,U8 * name) fontnum++; } +static U8 printable(U8 a) +{ + if(a<32 || a==127) return '.'; + else return a; +} void hexdumpTag(TAG*tag, char* prefix) { int t; + char ascii[32]; printf(" %s-=> ",prefix); for(t=0;tlen;t++) { printf("%02x ", tag->data[t]); + ascii[t&15] = printable(tag->data[t]); if((t && ((t&15)==15)) || (t==tag->len-1)) { + int s,p=((t-1)&15)+1; + ascii[p] = 0; + for(s=p;s<16;s++) { + printf(" "); + } if(t==tag->len-1) - printf("\n"); + printf(" %s\n", ascii); else - printf("\n %s-=> ",prefix); + printf(" %s\n %s-=> ",ascii,prefix); } } } @@ -749,10 +761,14 @@ int main (int argc,char ** argv) char myprefix[128]; if(!name) { dumperror("Unknown tag:0x%03x", tag->id); - tag = tag->next; - continue; + //tag = tag->next; + //continue; } - printf("[%03x] %9ld %s%s", tag->id, tag->len, prefix, swf_TagGetName(tag)); + if(swf_TagGetName(tag)) { + printf("[%03x] %9ld %s%s", tag->id, tag->len, prefix, swf_TagGetName(tag)); + } else { + printf("[%03x] %9ld %sUNKNOWN TAG %03x", tag->id, tag->len, prefix, tag->id); + } if(tag->id == ST_FREECHARACTER) { U16 id = swf_GetU16(tag); -- 1.7.10.4