aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorShauren <shauren.trinity@gmail.com>2025-09-25 00:32:39 +0200
committerShauren <shauren.trinity@gmail.com>2025-09-25 00:55:33 +0200
commit4fbf78df1294be5b81d0f92f8081f81741e814ba (patch)
treeecf37fd12b273e73e3d157e5751663c3bf1a7c73
parentefff24d20eadb5080727e23746f80d9113d99936 (diff)
Tools/vmap_extractor: Fixed duplicate output files with .m2 and .m2.vmo extensions
(cherry picked from commit 4a3f22948c91b74de3f43a9cd674597904780f35)
-rw-r--r--src/tools/vmap4_extractor/adtfile.cpp2
-rw-r--r--src/tools/vmap4_extractor/model.cpp3
2 files changed, 4 insertions, 1 deletions
diff --git a/src/tools/vmap4_extractor/adtfile.cpp b/src/tools/vmap4_extractor/adtfile.cpp
index c07757295b8..d6803c45380 100644
--- a/src/tools/vmap4_extractor/adtfile.cpp
+++ b/src/tools/vmap4_extractor/adtfile.cpp
@@ -45,7 +45,7 @@ void FixNameCase(char* name, size_t len)
char* ptr = name + len - 1;
//extension in lowercase
- for (; *ptr != '.'; --ptr)
+ for (; *ptr != '.' && ptr >= name; --ptr)
*ptr |= 0x20;
for (; ptr >= name; --ptr)
diff --git a/src/tools/vmap4_extractor/model.cpp b/src/tools/vmap4_extractor/model.cpp
index 431428d9e1b..a598a8cf727 100644
--- a/src/tools/vmap4_extractor/model.cpp
+++ b/src/tools/vmap4_extractor/model.cpp
@@ -204,7 +204,10 @@ void Doodad::ExtractSet(WMODoodadData const& doodadData, ADT::MODF const& wmo, u
FixNameCase(ModelInstName.data(), nlen);
FixNameSpaces(ModelInstName.data(), nlen);
if (ModelInstName.ends_with(".mdx") || ModelInstName.ends_with(".mdl"))
+ {
ModelInstName.replace(ModelInstName.length() - 2, 2, "2");
+ nlen = ModelInstName.length();
+ }
std::string tempname = Trinity::StringFormat("{}/{}", szWorkDirWmo, ModelInstName);
FILE* input = fopen(tempname.c_str(), "r+b");