#include "indexparser.h" #include #include #include template void commonParseSqPack(FILE* file, IndexFile& index) { fread(&index.packHeader, sizeof(SqPackHeader), 1, file); if(strcmp(index.packHeader.magic, "SqPack") != 0) { throw std::runtime_error("Invalid sqpack magic."); } // data starts at size fseek(file, index.packHeader.size, SEEK_SET); // read index header fread(&index.indexHeader, sizeof(SqPackIndexHeader), 1, file); if(index.packHeader.version != 1) { throw std::runtime_error("Invalid sqpack version."); } fseek(file, index.indexHeader.indexDataOffset, SEEK_SET); } IndexFile readIndexFile(const std::string_view path) { FILE* file = fopen(path.data(), "rb"); if(!file) { throw std::runtime_error("Failed to read index file from " + std::string(path.data())); } IndexFile index; commonParseSqPack(file, index); uint32_t numEntries = index.indexHeader.indexDataSize / sizeof(IndexHashTableEntry); for(uint32_t i = 0; i < numEntries; i++) { IndexHashTableEntry entry = {}; fread(&entry, sizeof(IndexHashTableEntry), 1, file); index.entries.push_back(entry); } return index; } IndexFile readIndex2File(const std::string_view path) { FILE* file = fopen(path.data(), "rb"); if(!file) { throw std::runtime_error("Failed to read index2 file from " + std::string(path.data())); } IndexFile index; commonParseSqPack(file, index); for(int i = 0; i < index.indexHeader.indexDataSize; i++) { Index2HashTableEntry entry = {}; fread(&entry, sizeof entry, 1, file); index.entries.push_back(entry); } return index; }