bool LoadEntsFromMapFile( char const *pFilename ) { // // Dummy this up for the texture handling. This can be removed when old .MAP file // support is removed. // g_nMapFileVersion = 400; // // Open the file. // CChunkFile File; ChunkFileResult_t eResult = File.Open( pFilename, ChunkFile_Read ); if(eResult == ChunkFile_Ok) { num_entities = 0; // // Set up handlers for the subchunks that we are interested in. // CChunkHandlerMap Handlers; Handlers.AddHandler("entity", (ChunkHandler_t)LoadEntityCallback, 0); File.PushHandlers(&Handlers); // // Read the sub-chunks. We ignore keys in the root of the file. // while (eResult == ChunkFile_Ok) { eResult = File.ReadChunk(); } File.PopHandlers(); return true; } else { Error("Error in LoadEntsFromMapFile (in-memory file): %s.\n", File.GetErrorText(eResult)); return false; } }
void TestChunkFileNameing(void) { CChunkFile cChunkFile; int iChunkNum; char acTwentyOne[] = {0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09}; char acTwentyTwo[] = {0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19}; char acTwentyThree[] = {0x20, 0x21, 0x22, 0x23, 0x24, 0x25, 0x26, 0x27, 0x28, 0x29}; char acActual[10]; cChunkFile.Init(MemoryFile()); AssertTrue(cChunkFile.WriteOpen()); AssertTrue(cChunkFile.WriteChunkBegin()); AssertLongLongInt(1, cChunkFile.Write(acTwentyOne, 10, 1)); AssertTrue(cChunkFile.WriteChunkBegin()); AssertLongLongInt(1, cChunkFile.Write(acTwentyTwo, 10, 1)); AssertTrue(cChunkFile.WriteChunkEnd("Floopy")); AssertTrue(cChunkFile.WriteChunkBegin()); AssertLongLongInt(1, cChunkFile.Write(acTwentyThree, 10, 1)); AssertTrue(cChunkFile.WriteChunkEnd("Floopy")); AssertTrue(cChunkFile.WriteChunkEnd("Rise")); AssertTrue(cChunkFile.WriteClose()); AssertTrue(cChunkFile.ReadOpen()); iChunkNum = cChunkFile.FindFirstChunkWithName("Rise"); AssertInt(0, iChunkNum); AssertTrue(cChunkFile.ReadChunkBegin(iChunkNum)); AssertLongLongInt(1, cChunkFile.Read(acActual, 10, 1)); AssertMemory(acTwentyOne, acActual, 10); iChunkNum = cChunkFile.FindFirstChunkWithName("Floopy"); AssertInt(0, iChunkNum); AssertTrue(cChunkFile.ReadChunkBegin(iChunkNum)); AssertLongLongInt(1, cChunkFile.Read(acActual, 10, 1)); AssertMemory(acTwentyTwo, acActual, 10); AssertTrue(cChunkFile.ReadChunkEnd()); iChunkNum = cChunkFile.FindNextChunkWithName(); AssertInt(1, iChunkNum); AssertTrue(cChunkFile.ReadChunkBegin(iChunkNum)); AssertLongLongInt(1, cChunkFile.Read(acActual, 10, 1)); AssertMemory(acTwentyThree, acActual, 10); AssertTrue(cChunkFile.ReadChunkEnd()); AssertTrue(cChunkFile.ReadChunkEnd()); AssertTrue(cChunkFile.ReadClose()); cChunkFile.Kill(); }
void TestChunkFileMD5ing(void) { char szFox[] = "The quick brown fox jumps over the lazy dog"; unsigned char ucFoxMD5[] = {0x9e, 0x10, 0x7d, 0x9d, 0x37, 0x2b, 0xb6, 0x82, 0x6b, 0xd8, 0x1d, 0x35, 0x42, 0xa4, 0x19, 0xd6}; int iFoxLen; char szLorem[] = "Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum."; unsigned char ucLoremMD5[] = {0xfa, 0x5c, 0x89, 0xf3, 0xc8, 0x8b, 0x81, 0xbf, 0xd5, 0xe8, 0x21, 0xb0, 0x31, 0x65, 0x69, 0xaf}; int iLoremLen; CChunkFile cChunkFile; iFoxLen = (int)strlen(szFox); iLoremLen = (int)strlen(szLorem); cChunkFile.Init(MemoryFile()); AssertTrue(cChunkFile.WriteOpen()); AssertTrue(cChunkFile.WriteChunkBegin()); AssertTrue(cChunkFile.Write(szFox, 1, iFoxLen) > 0); AssertTrue(cChunkFile.WriteChunkEnd("ChunkName")); AssertTrue(cChunkFile.Write(szLorem, 1, iLoremLen) > 0); AssertTrue(cChunkFile.WriteClose()); AssertTrue(cChunkFile.ReadOpen()); AssertMD5(ucLoremMD5, (unsigned char *)cChunkFile.GetMD5Hash()); AssertTrue(cChunkFile.ReadChunkBegin(0)); AssertMD5(ucFoxMD5, (unsigned char *)cChunkFile.GetMD5Hash()); AssertTrue(cChunkFile.ReadChunkEnd()); AssertTrue(cChunkFile.ReadClose()); cChunkFile.Kill(); }
void TestChunkFileSimple(void) { CChunkFile cChunkFile; CFileUtil cFileUtil; int iChunkNum; cFileUtil.MakeDir("Output"); cFileUtil.Delete("Output/ChunkFile.bin"); cChunkFile.Init(DiskFile("Output/ChunkFile.bin")); AssertFalse(cChunkFile.IsOpen()); AssertTrue(cChunkFile.WriteOpen()); AssertTrue(cChunkFile.IsOpen()); AssertTrue(cChunkFile.WriteChunkBegin()); AssertTrue(cChunkFile.WriteChunkEnd("ThisChunk")); AssertTrue(cChunkFile.WriteClose()); AssertFalse(cChunkFile.IsOpen()); cChunkFile.Kill(); cChunkFile.Init(DiskFile("Output/ChunkFile.bin")); AssertFalse(cChunkFile.IsOpen()); AssertTrue(cChunkFile.ReadOpen()); AssertTrue(cChunkFile.IsOpen()); iChunkNum = cChunkFile.FindFirstChunkWithName("ThisChunk"); AssertInt(0, iChunkNum); AssertTrue(cChunkFile.ReadChunkBegin(iChunkNum)); AssertTrue(cChunkFile.ReadClose()); AssertFalse(cChunkFile.IsOpen()); cChunkFile.Kill(); }
void TestChunkFileFileRead(void) { CChunkFile cChunkFile; int iChunkNum; char szZ[] = {"Z"}; CChunkFileFile cChunkFileFile; char cz; cChunkFile.Init(MemoryFile()); AssertTrue(cChunkFile.WriteOpen()); AssertTrue(cChunkFile.WriteChunkBegin()); AssertLongLongInt(1, cChunkFile.Write(szZ, 1, 1)); AssertTrue(cChunkFile.WriteChunkEnd("Zynaps")); AssertTrue(cChunkFile.WriteClose()); AssertTrue(cChunkFile.ReadOpen()); iChunkNum = cChunkFile.FindFirstChunkWithName("Zynaps"); AssertInt(0, iChunkNum); AssertTrue(cChunkFile.ReadChunkBegin(iChunkNum)); cChunkFileFile.Init(&cChunkFile); AssertTrue(cChunkFileFile.Open(EFM_Read)); AssertLongLongInt(1, cChunkFileFile.Size()); AssertLongLongInt(0, cChunkFileFile.Tell()); AssertLongLongInt(1, cChunkFileFile.Read(&cz, 1, 1)); AssertChar('Z', cz); cz = 'Q'; AssertTrue(cChunkFileFile.Seek(0, EFSO_SET)); AssertLongLongInt(0, cChunkFileFile.Tell()); AssertLongLongInt(1, cChunkFileFile.Read(&cz, 1, 1)); AssertChar('Z', cz); cz = 'Q'; AssertLongLongInt(1, cChunkFileFile.Tell()); AssertFalse(cChunkFileFile.Eof()); AssertLongLongInt(0, cChunkFileFile.Read(&cz, 1, 1)); AssertTrue(cChunkFileFile.Eof()); AssertLongLongInt(1, cChunkFileFile.Tell()); AssertTrue(cChunkFileFile.Seek(0, EFSO_SET)); AssertFalse(cChunkFileFile.Eof()); AssertLongLongInt(1, cChunkFileFile.Read(&cz, 1, 2)); AssertChar('Z', cz); cz = 'Q'; AssertLongLongInt(1, cChunkFileFile.Tell()); AssertTrue(cChunkFileFile.Eof()); AssertTrue(cChunkFileFile.Close()); AssertTrue(cChunkFile.ReadChunkEnd()); AssertTrue(cChunkFile.ReadClose()); cChunkFile.Kill(); }
void TestMapStringUnknownLoad(void) { MemoryInit(); UnknownsInit(); CMapStringUnknown cMap; CTestUnknownJobbie* pcTest; CChunkFile cFile; CFileUtil cFileUtil; BOOL bResult; gcUnknowns.AddConstructor<CTestUnknownJobbie>(); AssertInt(0, gcUnknowns.NumElements()); cFileUtil.RemoveDir("MapStringUnknown"); cFileUtil.MakeDir("MapStringUnknown"); cMap.Init(); pcTest = cMap.Put<CTestUnknownJobbie>("Hello"); pcTest->Init(7, "1st"); pcTest = cMap.Put<CTestUnknownJobbie>("World"); pcTest->Init(19, "A pony"); pcTest = cMap.Put<CTestUnknownJobbie>("Aardvark"); pcTest->Init(4, "Restore"); pcTest = cMap.Put<CTestUnknownJobbie>("Yurk"); pcTest->Init(8, "Yurk"); cFile.Init(DiskFile("MapStringUnknown/Map.dat")); bResult = cFile.WriteOpen(); AssertTrue(bResult); bResult = cMap.Save(&cFile); AssertTrue(bResult); bResult = cFile.WriteClose(); AssertTrue(bResult); cFile.Kill(); cMap.Kill(); AssertInt(0, gcUnknowns.NumElements()); cFile.Init(DiskFile("MapStringUnknown/Map.dat")); bResult = cFile.ReadOpen(); AssertTrue(bResult); bResult = cMap.Load(&cFile); AssertTrue(bResult); bResult = cFile.ReadClose(); AssertTrue(bResult); cFile.Kill(); AssertInt(4, cMap.NumElements()); AssertInt(4, gcUnknowns.NumElements()); pcTest = (CTestUnknownJobbie*)cMap.Get("Hello"); AssertInt(7, pcTest->miANumber); AssertString("1st", pcTest->mszText.Text()); pcTest = (CTestUnknownJobbie*)cMap.Get("World"); AssertInt(19, pcTest->miANumber); AssertString("A pony", pcTest->mszText.Text()); pcTest = (CTestUnknownJobbie*)cMap.Get("Aardvark"); AssertInt(4, pcTest->miANumber); AssertString("Restore", pcTest->mszText.Text()); pcTest = (CTestUnknownJobbie*)cMap.Get("Yurk"); AssertInt(8, pcTest->miANumber); AssertString("Yurk", pcTest->mszText.Text()); cMap.Kill(); AssertInt(0, gcUnknowns.NumElements()); cFileUtil.RemoveDir("MapStringUnknown"); UnknownsKill(); MemoryKill(); }