diff options
author | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2005-12-07 21:16:47 +0000 |
---|---|---|
committer | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2005-12-07 21:16:47 +0000 |
commit | aea429253a21458b74d1b052e975cd1cc4c1b08a (patch) | |
tree | 6bdb512b3a108dc56033150471844250863ff61c /src | |
parent | 18f04c60d59085ad768f149c8e9e4b650b8dc717 (diff) |
Added OnCleanup function
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@2258 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src')
-rw-r--r-- | src/inspircd.cpp | 9 | ||||
-rw-r--r-- | src/modules.cpp | 1 |
2 files changed, 10 insertions, 0 deletions
diff --git a/src/inspircd.cpp b/src/inspircd.cpp index f47cc339b..75c0833fc 100644 --- a/src/inspircd.cpp +++ b/src/inspircd.cpp @@ -2184,6 +2184,15 @@ bool UnloadModule(const char* filename) snprintf(MODERR,MAXBUF,"Module not unloadable (marked static)"); return false; } + /* Give the module a chance to tidy out all its metadata */ + for (chan_hash::iterator c = chanlist.begin(); c != chanlist.end(); c++) + { + modules[j]->OnCleanup(TYPE_CHANNEL,c->second); + } + for (user_hash::iterator u = userlist.begin(); u != userlist.end(); u++) + { + modules[j]->OnCleanup(TYPE_USER,u->second); + } FOREACH_MOD OnUnloadModule(modules[j],module_names[j]); // found the module log(DEBUG,"Deleting module..."); diff --git a/src/modules.cpp b/src/modules.cpp index f47a2cb4e..6e553167e 100644 --- a/src/modules.cpp +++ b/src/modules.cpp @@ -385,6 +385,7 @@ void Module::OnDelZLine(userrec* source, std::string ipmask) { }; void Module::OnDelKLine(userrec* source, std::string hostmask) { }; void Module::OnDelQLine(userrec* source, std::string nickmask) { }; void Module::OnDelELine(userrec* source, std::string hostmask) { }; +void Module::OnCleanup(int target_type, void* source) { }; /* server is a wrapper class that provides methods to all of the C-style * exports in the core |