aboutsummaryrefslogtreecommitdiff
path: root/src/common/Collision/Management/MMapManager.cpp
diff options
context:
space:
mode:
authorShauren <shauren.trinity@gmail.com>2017-01-17 20:14:44 +0100
committerShauren <shauren.trinity@gmail.com>2017-01-17 20:14:44 +0100
commit6767bbc95f46df4b62c8131a39a132d3f9bb8a26 (patch)
treee8129b118ec3ae7a3be2afc00dfdd01752e8ecff /src/common/Collision/Management/MMapManager.cpp
parentbc0d82a81e12e802154cdad0833c187de80b3865 (diff)
Fix static analysis issues
CID 1291964 CID 1292775
Diffstat (limited to 'src/common/Collision/Management/MMapManager.cpp')
-rw-r--r--src/common/Collision/Management/MMapManager.cpp11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/common/Collision/Management/MMapManager.cpp b/src/common/Collision/Management/MMapManager.cpp
index 4f9ecdc8364..389e0f9629f 100644
--- a/src/common/Collision/Management/MMapManager.cpp
+++ b/src/common/Collision/Management/MMapManager.cpp
@@ -162,6 +162,17 @@ namespace MMAP
return false;
}
+ long pos = ftell(file);
+ fseek(file, 0, SEEK_END);
+ if (fileHeader.size > ftell(file) - pos)
+ {
+ TC_LOG_ERROR("maps", "MMAP:loadMap: %04u%02i%02i.mmtile has corrupted data size", mapId, x, y);
+ fclose(file);
+ return;
+ }
+
+ fseek(file, pos, SEEK_SET);
+
unsigned char* data = (unsigned char*)dtAlloc(fileHeader.size, DT_ALLOC_PERM);
ASSERT(data);