From 147507afe4e4bf84a4fa7ab9bc32531f8e4e2289 Mon Sep 17 00:00:00 2001 From: Treeki Date: Sat, 18 Feb 2012 01:17:10 +0100 Subject: fixed memory leaks --- src/koopatlas/core.cpp | 2 ++ src/koopatlas/mapdata.cpp | 11 ++++++++--- src/msgbox.cpp | 2 ++ 3 files changed, 12 insertions(+), 3 deletions(-) diff --git a/src/koopatlas/core.cpp b/src/koopatlas/core.cpp index 03b64dc..7eaa339 100644 --- a/src/koopatlas/core.cpp +++ b/src/koopatlas/core.cpp @@ -360,6 +360,8 @@ int dScKoopatlas_c::onDelete() { DVD_FreeFile(GetDVDClass2(), "SI_propeller"); DVD_FreeFile(GetDVDClass2(), "SI_star"); + levelInfoLoader.unload(); + return true; } diff --git a/src/koopatlas/mapdata.cpp b/src/koopatlas/mapdata.cpp index a6031b1..fb09f1b 100644 --- a/src/koopatlas/mapdata.cpp +++ b/src/koopatlas/mapdata.cpp @@ -34,9 +34,9 @@ dKPMapData_c::dKPMapData_c() { } dKPMapData_c::~dKPMapData_c() { - m_fileLoader.unload(); - unloadTilesets(); + + m_fileLoader.unload(); } bool dKPMapData_c::load(const char *filename) { @@ -81,8 +81,13 @@ bool dKPMapData_c::loadTilesets() { } void dKPMapData_c::unloadTilesets() { - if (tilesetLoaders != 0) + if (tilesetLoaders != 0) { + for (int i = 0; i < data->tilesetCount; i++) { + tilesetLoaders[i].unload(); + } + delete[] tilesetLoaders; + } } void dKPMapData_c::fixup() { diff --git a/src/msgbox.cpp b/src/msgbox.cpp index a576189..99dd8c6 100644 --- a/src/msgbox.cpp +++ b/src/msgbox.cpp @@ -119,6 +119,8 @@ int dMsgBoxManager_c::onDraw() { int dMsgBoxManager_c::onDelete() { instance = 0; + msgDataLoader.unload(); + return layout.free(); } -- cgit v1.2.3