Mercurial > otakunoraifu
view scn2k/gandump.cc @ 46:3aa3d244ad90
Brand new README!
author | thib |
---|---|
date | Thu, 26 Mar 2009 18:06:32 +0000 |
parents | 6d1a5b7f0838 |
children | 15a18fbe6f21 |
line wrap: on
line source
/* * Copyright (c) 2004-2006 Kazunori "jagarl" Ueno * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * 3. The name of the author may not be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #include<stdio.h> #include<string.h> char* ganname[6] = {"ptn", "x", "y", "time", "alpha", "?"}; int main(int argc, char** argv) { if (argc != 2) return 0; FILE* f = fopen(argv[1],"rb"); if (f==0) return 0; fseek(f,0,2); int sz=ftell(f); fseek(f,0,0); char* buf = new char[sz]; char* bufo = buf; fread(buf,1,sz,f); fclose(f); int i; for (i=0; i<16; i++) { printf("%02x ",int(buf[i])&0xff); } printf("\n"); buf+=16; printf("file '%s'\n",buf); buf += strlen(buf)+1; printf("N1 = %3d\n", *(int*)buf); buf+=4; int ptns = *(int*)buf; buf += 4; for (i=0; i<ptns; i++) { int j; printf("\tN2 = %3d\n",*(int*)buf); buf += 4; int n = *(int*)buf; buf += 4; for (j=0; j<n; j++) { printf("\t%3d: ",j); int k; int d1,d2; for (k=0; k<6; k++) { d1 = *(int*)(buf+k*8); d2 = *(int*)(buf+k*8+4); if (d1 != 30100+k) printf("err: d1 %d\n",d1); printf("%s: %5d, ",ganname[k],d2); } printf("\n"); buf += 6*8; int d = *(int*)buf; buf += 4; if (d != 999999) printf("err: dd %d\n",d); } } if (buf != bufo+sz) { printf("orig sz %d read %d\n",sz,buf-bufo);} }