From 996f461157bdc94b134e3647d995379b645f9d0b Mon Sep 17 00:00:00 2001 From: David Anderson Date: Thu, 16 Jun 2005 20:20:24 +0000 Subject: [PATCH] Fixed a memory leak on plugun unload --- amxmodx/CPlugin.cpp | 33 ++++++++++++++++++++++++++++++++- 1 file changed, 32 insertions(+), 1 deletion(-) diff --git a/amxmodx/CPlugin.cpp b/amxmodx/CPlugin.cpp index e55ad0ff..f1480d6b 100755 --- a/amxmodx/CPlugin.cpp +++ b/amxmodx/CPlugin.cpp @@ -33,6 +33,7 @@ #include "CPlugin.h" #include "CForward.h" #include "CFile.h" +#include "amx.h" CPluginMngr::CPlugin* CPluginMngr::loadPlugin(const char* path, const char* name, char* error, int debug) { CPlugin** a = &head; @@ -170,7 +171,37 @@ CPluginMngr::CPlugin::CPlugin(int i, const char* p,const char* n, char* e, int d next = 0; id = i; } -CPluginMngr::CPlugin::~CPlugin( ){ + +CPluginMngr::CPlugin::~CPlugin( ) +{ + AMX_DBG *pDbg = (AMX_DBG *)amx.userdata[0]; + + if (pDbg) + { + if (pDbg->files) + { + for (int i=0; inumFiles; i++) + { + if (pDbg->files[i]) + { + free(pDbg->files[i]); + pDbg->files[i] = NULL; + } + } + free(pDbg->files); + } + AMX_TRACE *pTrace = pDbg->head; + AMX_TRACE *pNext = NULL; + while (pTrace) + { + pNext = pTrace->next; + free(pTrace); + pTrace = pNext; + } + free(pDbg); + amx.userdata[0] = NULL; + } + unload_amxscript( &amx, &code ); }