mirror of
https://github.com/aap/librw.git
synced 2024-11-30 15:45:42 +00:00
107 lines
2.1 KiB
C++
107 lines
2.1 KiB
C++
#include <cstdio>
|
|
#include <cstdlib>
|
|
#include <cstring>
|
|
#include <cassert>
|
|
#include <new>
|
|
|
|
#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;
|
|
|
|
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]);
|
|
|
|
// only opengl:
|
|
for(int32 i = 0; i < c->numAtomics; i++){
|
|
Atomic *a = c->atomicList[i];
|
|
gl::printPipeinfo(a);
|
|
}
|
|
return 0;
|
|
|
|
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[256*1024];
|
|
rw::StreamMemory out;
|
|
out.open(data, 0, 256*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;
|
|
}
|