first try to get all MODL and their sub chunks,
This commit is contained in:
parent
443675aeaa
commit
4f1ff65f71
|
@ -17,12 +17,13 @@ public:
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
std::list<chunkHeader*> lChunk;
|
std::list<chunkHeader*> lChunkMsh2;
|
||||||
|
std::list<chunkHeader*> lChunkModl;
|
||||||
std::fstream fsMesh;
|
std::fstream fsMesh;
|
||||||
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void readChunks();
|
void loadChunks(std::list<chunkHeader*> &destination, std::streampos start, const char end[5]);
|
||||||
|
|
||||||
public:
|
public:
|
||||||
|
|
||||||
|
|
|
@ -14,8 +14,24 @@ Object::Object(const char* path)
|
||||||
if (!fsMesh.is_open())
|
if (!fsMesh.is_open())
|
||||||
throw std::invalid_argument(std::string("file not found: ") += path);
|
throw std::invalid_argument(std::string("file not found: ") += path);
|
||||||
|
|
||||||
// get Chunks
|
fsMesh.seekg(8);
|
||||||
readChunks();
|
char tempChunkName[5] = { 0 };
|
||||||
|
fsMesh.read(reinterpret_cast<char*>(&tempChunkName[0]), sizeof(tempChunkName) - 1);
|
||||||
|
|
||||||
|
if (strcmp(tempChunkName, "MSH2"))
|
||||||
|
throw std::invalid_argument(std::string("corrupted file MSH2 expected instead of ") += tempChunkName);
|
||||||
|
|
||||||
|
fsMesh.seekg(4, std::ios_base::cur);
|
||||||
|
|
||||||
|
loadChunks(lChunkMsh2, fsMesh.tellg(), "CL1L");
|
||||||
|
|
||||||
|
for (std::list<chunkHeader*>::iterator it = lChunkMsh2.begin(); it != lChunkMsh2.end(); it++)
|
||||||
|
{
|
||||||
|
if (!strcmp("MODL", (*it)->name))
|
||||||
|
{
|
||||||
|
loadChunks(lChunkModl, (*it)->position, "CL1L");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// close file
|
// close file
|
||||||
fsMesh.close();
|
fsMesh.close();
|
||||||
|
@ -27,13 +43,14 @@ Object::~Object()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////
|
||||||
// private functions
|
// private functions
|
||||||
|
|
||||||
void Object::readChunks()
|
void Object::loadChunks(std::list<chunkHeader*>& destination, std::streampos start, const char end[5])
|
||||||
{
|
{
|
||||||
// Jump into Mesh2
|
// Jump into Mesh2
|
||||||
fsMesh.seekg(16, std::ios_base::cur);
|
fsMesh.seekg(start);
|
||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
|
@ -43,15 +60,16 @@ void Object::readChunks()
|
||||||
fsMesh.read(reinterpret_cast<char*>(&tempHeader->size), sizeof(tempHeader->size));
|
fsMesh.read(reinterpret_cast<char*>(&tempHeader->size), sizeof(tempHeader->size));
|
||||||
tempHeader->position = fsMesh.tellg();
|
tempHeader->position = fsMesh.tellg();
|
||||||
|
|
||||||
lChunk.push_back(tempHeader);
|
destination.push_back(tempHeader);
|
||||||
|
|
||||||
fsMesh.seekg(tempHeader->size, std::ios_base::cur);
|
fsMesh.seekg(tempHeader->size, std::ios_base::cur);
|
||||||
|
|
||||||
if (!std::strcmp(tempHeader->name, "CL1L"))
|
if (!std::strcmp(tempHeader->name, end))
|
||||||
break;
|
break;
|
||||||
} while (!fsMesh.eof());
|
} while (fsMesh.good());
|
||||||
|
|
||||||
|
std::cout << "got all chunks, totaly found: " << destination.size() << std::endl;
|
||||||
|
|
||||||
std::cout << "got all chunks, totaly found: " << lChunk.size() << std::endl;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue