X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=src%2Fswfdump.c;h=0cc845d52894e7167b7dd57174763c21458a57d9;hb=7cecd180801fb48c42540fcdd77c3e75b528552c;hp=ca8ee2716e2ae8510d16c0b050e912b7e6ec9500;hpb=e448c7a56df8e289c9dbd5b8d87753addd541091;p=swftools.git diff --git a/src/swfdump.c b/src/swfdump.c index ca8ee27..0cc845d 100644 --- a/src/swfdump.c +++ b/src/swfdump.c @@ -33,11 +33,16 @@ char * filename = 0; to detect errors in the file. (i.e. ids which are defined more than once */ char idtab[65536]; + int action = 0; +int html = 0; +int xy = 0; struct options_t options[] = { {"a","action"}, + {"XY","size"}, + {"e","html"}, {"v","verbose"}, {"V","version"}, {0,0} @@ -54,6 +59,18 @@ int args_callback_option(char*name,char*val) action = 1; return 0; } + else if(name[0]=='e') { + html = 1; + return 0; + } + else if(name[0]=='X') { + xy |= 1; + return 0; + } + else if(name[0]=='Y') { + xy |= 2; + return 0; + } else { printf("Unknown option: -%s\n", name); } @@ -68,6 +85,9 @@ void args_callback_usage(char*name) { printf("Usage: %s [-a] file.swf\n", name); printf("-h , --help\t\t\t Print help and exit\n"); + printf("-e , --html\t\t\t Create a html embedding the file (simple, but useful)\n"); + printf("-X , --width\t\t\t Prints out a string of the form \"-X width\"\n"); + printf("-Y , --height\t\t\t Prints out a string of the form \"-Y height\"\n"); printf("-a , --action\t\t\t Disassemble action tags\n"); printf("-V , --version\t\t\t Print program version and exit\n"); } @@ -81,6 +101,13 @@ int args_callback_command(char*name,char*val) return 0; } +char* what; +char* testfunc(char*str) +{ + printf("%s: %s\n", what, str); + return 0; +} + int main (int argc,char ** argv) { SWF swf; @@ -89,6 +116,7 @@ int main (int argc,char ** argv) struct stat statbuf; #endif int f; + int xsize,ysize; char prefix[128]; prefix[0] = 0; memset(idtab,0,65536); @@ -117,13 +145,43 @@ int main (int argc,char ** argv) #ifdef HAVE_STAT fstat(f, &statbuf); - if(statbuf.st_size != swf.fileSize) + if(statbuf.st_size != swf.FileSize) fprintf(stderr, "Error: Real Filesize (%d) doesn't match header Filesize (%d)", - statbuf.st_size, swf.fileSize); + statbuf.st_size, swf.FileSize); #endif close(f); + xsize = (swf.movieSize.xmax-swf.movieSize.xmin)/20; + ysize = (swf.movieSize.ymax-swf.movieSize.ymin)/20; + if(xy) + { + if(xy&1) + printf("-X %d", xsize); + if(xy==3) + printf(" "); + if(xy&2) + printf("-Y %d", ysize); + printf("\n"); + return 0; + } + if(html) + { + printf("\n" + " \n" + " \n" + " \n" + " \n" + " \n" + " \n" + "\n", xsize, ysize, swf.fileVersion, filename, filename, xsize, ysize); + return 0; + } printf("[HEADER] File version: %d\n", swf.fileVersion); printf("[HEADER] File size: %ld\n", swf.fileSize); printf("[HEADER] Frame rate: %f\n",swf.frameRate/256.0); @@ -152,8 +210,8 @@ int main (int argc,char ** argv) else if(tag->id == ST_PLACEOBJECT || tag->id == ST_PLACEOBJECT2) { printf(" places id %04x at depth %04x", swf_GetPlaceID(tag), swf_GetDepth(tag)); - if(swf_TagGetName(tag)) - printf(" name \"%s\"",swf_TagGetName(tag)); + if(swf_GetName(tag)) + printf(" name \"%s\"",swf_GetName(tag)); } else if(tag->id == ST_REMOVEOBJECT) { printf(" removes id %04x from depth %04x", swf_GetPlaceID(tag), swf_GetDepth(tag)); @@ -178,6 +236,13 @@ int main (int argc,char ** argv) actions = swf_GetActions(tag); swf_DumpActions(actions, myprefix); + +/* what = "URL"; + ActionEnumerateURLs(actions, testfunc); + what = "String"; + ActionEnumerateStrings(actions, testfunc); + what = "Target"; + ActionEnumerateTargets(actions, testfunc);*/ } tag = tag->next; }