bool WDTFile::init(char *map_id) { if (WDT.isEof()) { //printf("Can't find WDT file.\n"); return false; } char fourcc[5]; size_t size; const char dirname[] = "buildings\\dir"; FILE *dirfile; dirfile = fopen(dirname, "ab"); if(!dirfile) { printf("Can't open dirfile!'%s'\n"); return false; } while (!WDT.isEof()) { WDT.read(fourcc,4); WDT.read(&size, 4); flipcc(fourcc); fourcc[4] = 0; size_t nextpos = WDT.getPos() + size; if (!strcmp(fourcc,"MAIN")) { } if (!strcmp(fourcc,"MWMO")) { // global map objects if (size) { char *buf = new char[size]; WDT.read(buf, size); char *p=buf; int q = 0; gWmoInstansName = new string[size]; while (p<buf+size) { string path(p); char* s=wdtGetPlainName(p); fixnamen(s,strlen(s)); p=p+strlen(p)+1; gWmoInstansName[q++] = s; } delete[] buf; } } else if (!strcmp(fourcc,"MODF")) { // global wmo instance data if (size) { gnWMO = (int)size / 64; string gWMO_mapname; string fake_mapname; fake_mapname = "65 65 "; //gWMO_mapname = fake_mapname + filename; gWMO_mapname = fake_mapname + std::string(map_id); for (int i=0; i<gnWMO; i++) { int id; WDT.read(&id, 4); WMOInstance inst(WDT,gWmoInstansName[id].c_str(),gWMO_mapname.c_str(), dirfile); } delete[] gWmoInstansName; } } WDT.seek((int)nextpos); } WDT.close(); fclose(dirfile); return true; }
bool WDTFile::init(char* /*map_id*/, unsigned int mapID) { if (WDT.isEof()) { //printf("Can't find WDT file.\n"); return false; } char fourcc[5]; uint32 size; std::string dirname = std::string(szWorkDirWmo) + "/dir_bin"; FILE *dirfile; dirfile = fopen(dirname.c_str(), "ab"); if(!dirfile) { printf("Can't open dirfile!'%s'\n", dirname.c_str()); return false; } while (!WDT.isEof()) { WDT.read(fourcc,4); WDT.read(&size, 4); flipcc(fourcc); fourcc[4] = 0; size_t nextpos = WDT.getPos() + size; if (!strcmp(fourcc,"MAIN")) { } if (!strcmp(fourcc,"MWMO")) { // global map objects if (size) { char *buf = new char[size]; WDT.read(buf, size); char *p=buf; int q = 0; gWmoInstansName = new string[size]; while (p < buf + size) { char* s=wdtGetPlainName(p); fixnamen(s,strlen(s)); p=p+strlen(p)+1; gWmoInstansName[q++] = s; } delete[] buf; } } else if (!strcmp(fourcc, "MODF")) { // global wmo instance data if (size) { gnWMO = (int)size / 64; for (int i = 0; i < gnWMO; ++i) { int id; WDT.read(&id, 4); WMOInstance inst(WDT,gWmoInstansName[id].c_str(), mapID, 65, 65, dirfile); } delete[] gWmoInstansName; } } WDT.seek((int)nextpos); } WDT.close(); fclose(dirfile); return true; }
bool WDTFile::init(uint32 mapId) { if (_file.isEof()) return false; char fourcc[5]; uint32 size; std::string dirname = std::string(szWorkDirWmo) + "/dir_bin"; FILE* dirfile = fopen(dirname.c_str(), "ab"); if (!dirfile) { printf("Can't open dirfile!'%s'\n", dirname.c_str()); return false; } while (!_file.isEof()) { _file.read(fourcc,4); _file.read(&size, 4); flipcc(fourcc); fourcc[4] = 0; size_t nextpos = _file.getPos() + size; if (!strcmp(fourcc,"MAIN")) { } if (!strcmp(fourcc,"MWMO")) { // global map objects if (size) { char *buf = new char[size]; _file.read(buf, size); char *p = buf; while (p < buf + size) { std::string path(p); char* s = wdtGetPlainName(p); FixNameCase(s, strlen(s)); FixNameSpaces(s, strlen(s)); p = p + strlen(p) + 1; _wmoNames.push_back(s); ExtractSingleWmo(path); } delete[] buf; } } else if (!strcmp(fourcc, "MODF")) { // global wmo instance data if (size) { int32 gnWMO = (int)size / 64; for (int i = 0; i < gnWMO; ++i) { int id; _file.read(&id, 4); WMOInstance inst(_file, _wmoNames[id].c_str(), mapId, 65, 65, mapId, dirfile, nullptr); } } } _file.seek((int)nextpos); } _file.close(); fclose(dirfile); return true; }