aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorShauren <shauren.trinity@gmail.com>2020-05-10 15:22:58 +0200
committerShauren <shauren.trinity@gmail.com>2020-05-10 15:22:58 +0200
commitfe7a0c9ad85481f34371be8cdab54aec14967f27 (patch)
tree4b26bc43b5ca1d7f56f48e1cac2b2561dcd0363b /src
parent885d2a7213f7e6c6acfec58076315133b6dccea2 (diff)
Tools/Extractors: Don't try extracting maps that have no wdt defined in Map.db2
Diffstat (limited to 'src')
-rw-r--r--src/tools/map_extractor/System.cpp30
-rw-r--r--src/tools/vmap4_extractor/vmapexport.cpp69
2 files changed, 58 insertions, 41 deletions
diff --git a/src/tools/map_extractor/System.cpp b/src/tools/map_extractor/System.cpp
index 16fb142ff08..ecb4d00358e 100644
--- a/src/tools/map_extractor/System.cpp
+++ b/src/tools/map_extractor/System.cpp
@@ -238,19 +238,21 @@ void ReadMapDBC()
exit(1);
}
- map_ids.resize(db2.GetRecordCount());
- std::unordered_map<uint32, uint32> idToIndex;
+ map_ids.reserve(db2.GetRecordCount());
+ std::unordered_map<uint32, std::size_t> idToIndex;
for (uint32 x = 0; x < db2.GetRecordCount(); ++x)
{
DB2Record record = db2.GetRecord(x);
if (!record)
continue;
- map_ids[x].Id = record.GetId();
- map_ids[x].WdtFileDataId = record.GetInt32("WdtFileDataID");
- map_ids[x].Name = record.GetString("MapName");
- map_ids[x].Directory = record.GetString("Directory");
- idToIndex[map_ids[x].Id] = x;
+ MapEntry map;
+ map.Id = record.GetId();
+ map.WdtFileDataId = record.GetInt32("WdtFileDataID");
+ map.Name = record.GetString("MapName");
+ map.Directory = record.GetString("Directory");
+ idToIndex[map.Id] = map_ids.size();
+ map_ids.push_back(map);
}
for (uint32 x = 0; x < db2.GetRecordCopyCount(); ++x)
@@ -259,15 +261,17 @@ void ReadMapDBC()
auto itr = idToIndex.find(copy.SourceRowId);
if (itr != idToIndex.end())
{
- MapEntry id;
- id.Id = copy.NewRowId;
- id.WdtFileDataId = map_ids[itr->second].WdtFileDataId;
- id.Name = map_ids[itr->second].Name;
- id.Directory = map_ids[itr->second].Directory;
- map_ids.push_back(id);
+ MapEntry map;
+ map.Id = copy.NewRowId;
+ map.WdtFileDataId = map_ids[itr->second].WdtFileDataId;
+ map.Name = map_ids[itr->second].Name;
+ map.Directory = map_ids[itr->second].Directory;
+ map_ids.push_back(map);
}
}
+ map_ids.erase(std::remove_if(map_ids.begin(), map_ids.end(), [](MapEntry const& map) { return !map.WdtFileDataId; }), map_ids.end());
+
printf("Done! (" SZFMTD " maps loaded)\n", map_ids.size());
}
diff --git a/src/tools/vmap4_extractor/vmapexport.cpp b/src/tools/vmap4_extractor/vmapexport.cpp
index 96a3e4d03f3..954854da27f 100644
--- a/src/tools/vmap4_extractor/vmapexport.cpp
+++ b/src/tools/vmap4_extractor/vmapexport.cpp
@@ -43,24 +43,20 @@
#define mkdir _mkdir
#endif
-//------------------------------------------------------------------------------
-// Defines
-
-#define MPQ_BLOCK_SIZE 0x1000
-
//-----------------------------------------------------------------------------
std::shared_ptr<CASC::Storage> CascStorage;
struct MapEntry
{
+ uint32 Id = 0;
int32 WdtFileDataId = 0;
int16 ParentMapID = 0;
std::string Name;
std::string Directory;
};
-std::map<uint32, MapEntry> map_ids;
+std::vector<MapEntry> map_ids; // partitioned by parent maps first
std::unordered_set<uint32> maps_that_are_parents;
boost::filesystem::path input_path;
bool preciseVectorData = false;
@@ -253,12 +249,16 @@ void ParsMapFiles()
auto itr = wdts.find(mapId);
if (itr == wdts.end())
{
- uint32 fileDataId = map_ids[mapId].WdtFileDataId;
+ auto mapEntryItr = std::find_if(map_ids.begin(), map_ids.end(), [mapId](MapEntry const& mapEntry) { return mapEntry.Id == mapId; });
+ if (mapEntryItr == map_ids.end())
+ return nullptr;
+
+ uint32 fileDataId = mapEntryItr->WdtFileDataId;
if (!fileDataId)
return nullptr;
- std::string description = Trinity::StringFormat("WDT for map %u - %s (FileDataID %u)", mapId, map_ids[mapId].Name.c_str(), fileDataId);
- std::string directory = map_ids[mapId].Directory;
+ std::string description = Trinity::StringFormat("WDT for map %u - %s (FileDataID %u)", mapId, mapEntryItr->Name.c_str(), fileDataId);
+ std::string directory = mapEntryItr->Directory;
itr = wdts.emplace(std::piecewise_construct, std::forward_as_tuple(mapId), std::forward_as_tuple(fileDataId, description, std::move(directory), maps_that_are_parents.count(mapId) > 0)).first;
if (!itr->second.init(mapId))
{
@@ -272,10 +272,10 @@ void ParsMapFiles()
for (auto itr = map_ids.begin(); itr != map_ids.end(); ++itr)
{
- if (WDTFile* WDT = getWDT(itr->first))
+ if (WDTFile* WDT = getWDT(itr->Id))
{
- WDTFile* parentWDT = itr->second.ParentMapID >= 0 ? getWDT(itr->second.ParentMapID) : nullptr;
- printf("Processing Map %u\n[", itr->first);
+ WDTFile* parentWDT = itr->ParentMapID >= 0 ? getWDT(itr->ParentMapID) : nullptr;
+ printf("Processing Map %u\n[", itr->Id);
for (int32 x = 0; x < 64; ++x)
{
for (int32 y = 0; y < 64; ++y)
@@ -283,14 +283,14 @@ void ParsMapFiles()
bool success = false;
if (ADTFile* ADT = WDT->GetMap(x, y))
{
- success = ADT->init(itr->first, itr->first);
+ success = ADT->init(itr->Id, itr->Id);
WDT->FreeADT(ADT);
}
if (!success && parentWDT)
{
if (ADTFile* ADT = parentWDT->GetMap(x, y))
{
- ADT->init(itr->first, itr->second.ParentMapID);
+ ADT->init(itr->Id, itr->ParentMapID);
parentWDT->FreeADT(ADT);
}
}
@@ -487,35 +487,48 @@ int main(int argc, char ** argv)
exit(1);
}
+ map_ids.reserve(db2.GetRecordCount());
+ std::unordered_map<uint32, std::size_t> idToIndex;
for (uint32 x = 0; x < db2.GetRecordCount(); ++x)
{
DB2Record record = db2.GetRecord(x);
if (!record)
continue;
- MapEntry& m = map_ids[record.GetId()];
- m.WdtFileDataId = record.GetInt32("WdtFileDataID");
- m.ParentMapID = int16(record.GetUInt16("ParentMapID"));
- m.Name = record.GetString("MapName");
- m.Directory = record.GetString("Directory");
- if (m.ParentMapID >= 0)
- maps_that_are_parents.insert(m.ParentMapID);
+ MapEntry map;
+ map.Id = record.GetId();
+ map.WdtFileDataId = record.GetInt32("WdtFileDataID");
+ map.ParentMapID = int16(record.GetUInt16("ParentMapID"));
+ map.Name = record.GetString("MapName");
+ map.Directory = record.GetString("Directory");
+ if (map.ParentMapID >= 0)
+ maps_that_are_parents.insert(map.ParentMapID);
+
+ idToIndex[map.Id] = map_ids.size();
+ map_ids.push_back(map);
}
for (uint32 x = 0; x < db2.GetRecordCopyCount(); ++x)
{
DB2RecordCopy copy = db2.GetRecordCopy(x);
- auto itr = map_ids.find(copy.SourceRowId);
- if (itr != map_ids.end())
+ auto itr = idToIndex.find(copy.SourceRowId);
+ if (itr != idToIndex.end())
{
- MapEntry& id = map_ids[copy.NewRowId];
- id.WdtFileDataId = itr->second.WdtFileDataId;
- id.ParentMapID = itr->second.ParentMapID;
- id.Name = itr->second.Name;
- id.Directory = itr->second.Directory;
+ MapEntry map;
+ map.Id = copy.NewRowId;
+ map.WdtFileDataId = map_ids[itr->second].WdtFileDataId;
+ map.ParentMapID = map_ids[itr->second].ParentMapID;
+ map.Name = map_ids[itr->second].Name;
+ map.Directory = map_ids[itr->second].Directory;
+ map_ids.push_back(map);
}
}
+ map_ids.erase(std::remove_if(map_ids.begin(), map_ids.end(), [](MapEntry const& map) { return !map.WdtFileDataId; }), map_ids.end());
+
+ // force parent maps to be extracted first
+ std::stable_partition(map_ids.begin(), map_ids.end(), [](MapEntry const& map) { return maps_that_are_parents.count(map.Id) > 0; });
+
printf("Done! (" SZFMTD " maps loaded)\n", map_ids.size());
ParsMapFiles();
}