#include #include #include #include #include #include "rw.h" #include "src/gtaplg.h" using namespace std; using namespace rw; int main(int argc, char *argv[]) { rw::version = 0x33002; gta::registerEnvSpecPlugin(); rw::registerMatFXPlugin(); rw::registerMaterialRightsPlugin(); rw::registerAtomicRightsPlugin(); rw::registerHAnimPlugin(); gta::registerNodeNamePlugin(); gta::registerBreakableModelPlugin(); gta::registerExtraVertColorPlugin(); rw::ps2::registerADCPlugin(); rw::ps2::registerPDSPlugin(); rw::registerSkinPlugin(); rw::registerNativeDataPlugin(); rw::registerMeshPlugin(); rw::Atomic::init(); // rw::platform = rw::PLATFORM_PS2; rw::platform = rw::PLATFORM_OGL; int uninstance = 0; int arg = 1; if(argc < 2){ printf("usage: %s [-u] ps2.dff\n", argv[0]); return 0; } if(strcmp(argv[arg], "-u") == 0){ uninstance++; arg++; if(argc < 3){ printf("usage: %s [-u] ps2.dff\n", argv[0]); return 0; } } Clump *c; uint32 len; uint8 *data = getFileContents(argv[arg], &len); assert(data != NULL); StreamMemory in; in.open(data, len); findChunk(&in, ID_CLUMP, NULL, NULL); debugFile = argv[arg]; c = Clump::streamRead(&in); assert(c != NULL); // printf("%s\n", argv[arg]); /* for(int32 i = 0; i < c->numAtomics; i++){ Atomic *a = c->atomicList[i]; Pipeline *ap = a->pipeline; Geometry *g = a->geometry; for(int32 j = 0; j < g->numMaterials; j++){ Pipeline *mp = g->materialList[j]->pipeline; if(ap && mp) printf("%s %x %x\n", argv[arg], ap->pluginData, mp->pluginData); } } */ for(int32 i = 0; i < c->numAtomics; i++){ Atomic *a = c->atomicList[i]; ObjPipeline *p = a->getPipeline(); if(uninstance) p->uninstance(a); else p->instance(a); } data = new rw::uint8[512*1024]; rw::StreamMemory out; out.open(data, 0, 512*1024); c->streamWrite(&out); FILE *cf = fopen("out.dff", "wb"); assert(cf != NULL); fwrite(data, out.getLength(), 1, cf); fclose(cf); out.close(); delete[] data; delete c; return 0; }