From d63e0473ba5b9117d484cf58af78832515334e3a Mon Sep 17 00:00:00 2001 From: brain Date: Mon, 26 Dec 2005 21:45:15 +0000 Subject: Added global_implementation array, bypasses calls which *NO* modules are currently implementing git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@2670 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/inspircd.cpp | 10 ++++++++++ 1 file changed, 10 insertions(+) (limited to 'src/inspircd.cpp') diff --git a/src/inspircd.cpp b/src/inspircd.cpp index f15fba3a0..b560a2de6 100644 --- a/src/inspircd.cpp +++ b/src/inspircd.cpp @@ -193,6 +193,9 @@ InspIRCd::InspIRCd(int argc, char** argv) CheckDie(); stats->BoundPortCount = BindPorts(); + for(int t = 0; t < 255; t++) + Config->global_implementation[t] = 0; + printf("\n"); if (!Config->nofork) { @@ -294,6 +297,10 @@ bool InspIRCd::UnloadModule(const char* filename) { modules[j]->OnCleanup(TYPE_USER,u->second); } + + for(int t = 0; t < 255; t++) + Config->global_implementation[t] -= implement_lists[j][t]; + FOREACH_MOD(I_OnUnloadModule,OnUnloadModule(modules[j],Config->module_names[j])); // found the module log(DEBUG,"Deleting module..."); @@ -365,6 +372,9 @@ bool InspIRCd::LoadModule(const char* filename) x[t] = 0; modules[MODCOUNT+1]->Implements(x); + + for(int t = 0; t < 255; t++) + Config->global_implementation[t] += implement_lists[MODCOUNT+1][t]; } else { -- cgit v1.2.3