diff options
author | danieldg <danieldg@e03df62e-2008-0410-955e-edbf42e46eb7> | 2009-10-18 01:40:26 +0000 |
---|---|---|
committer | danieldg <danieldg@e03df62e-2008-0410-955e-edbf42e46eb7> | 2009-10-18 01:40:26 +0000 |
commit | 93a78a57ada6d5dab410c2bd3c4b02f4fa15684c (patch) | |
tree | 82e2ef7308da4fdc8a24bd91a681fd66898937fe | |
parent | cced60255b08181d35b9bb26545a85feebd6b5cb (diff) |
Add more debug logging of object lifetimes
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@11900 e03df62e-2008-0410-955e-edbf42e46eb7
-rw-r--r-- | include/logger.h | 1 | ||||
-rw-r--r-- | src/base.cpp | 12 | ||||
-rw-r--r-- | src/inspircd.cpp | 8 |
3 files changed, 14 insertions, 7 deletions
diff --git a/include/logger.h b/include/logger.h index 37020a4ff..709d00aed 100644 --- a/include/logger.h +++ b/include/logger.h @@ -157,6 +157,7 @@ class CoreExport LogManager : public classbase { if (noforkstream) delete noforkstream; + Logging = true; } /** Sets up the logstream for -nofork. Called by InspIRCd::OpenLog() and LogManager::OpenFileLogs(). diff --git a/src/base.cpp b/src/base.cpp index 2e2dbfb28..15a642eb4 100644 --- a/src/base.cpp +++ b/src/base.cpp @@ -11,24 +11,32 @@ * --------------------------------------------------- */ -/* $Core */ - #include "inspircd_config.h" #include "base.h" #include <time.h> #include "inspircd.h" +#include <typeinfo> classbase::classbase() { + if (ServerInstance && ServerInstance->Logs) + ServerInstance->Logs->Log("CULLLIST", DEBUG, "classbase::+%s @%p", + typeid(*this).name(), (void*)this); } CullResult classbase::cull() { + if (ServerInstance && ServerInstance->Logs) + ServerInstance->Logs->Log("CULLLIST", DEBUG, "classbase::-%s @%p", + typeid(*this).name(), (void*)this); return CullResult(); } classbase::~classbase() { + if (ServerInstance && ServerInstance->Logs) + ServerInstance->Logs->Log("CULLLIST", DEBUG, "classbase::~%s @%p", + typeid(*this).name(), (void*)this); } CullResult::CullResult() diff --git a/src/inspircd.cpp b/src/inspircd.cpp index c59109724..862aa31d0 100644 --- a/src/inspircd.cpp +++ b/src/inspircd.cpp @@ -83,11 +83,9 @@ const char* ExitCodes[] = template<typename T> static void DeleteZero(T*&n) { - if (n != NULL) - { - delete n; - n = NULL; - } + T* t = n; + n = NULL; + delete t; } void InspIRCd::Cleanup() |