diff options
-rw-r--r-- | src/cmd_modules.cpp | 31 | ||||
-rw-r--r-- | src/inspircd.cpp | 10 |
2 files changed, 37 insertions, 4 deletions
diff --git a/src/cmd_modules.cpp b/src/cmd_modules.cpp index ac25f1888..e9483ea65 100644 --- a/src/cmd_modules.cpp +++ b/src/cmd_modules.cpp @@ -98,11 +98,34 @@ void cmd_modules::Handle (char **parameters, int pcnt, userrec *user) strlcpy(modulename,Config->module_names[i].c_str(),256); if (strchr(user->modes,'o')) { - if ((pcnt > 0) && (!strcasecmp(parameters[0],"debug"))) + if ((pcnt >= 2) && (!strcasecmp(parameters[0],"debug"))) { - WriteServ(user->fd,"900 %s :0x%08lx %d.%d.%d.%d %s (%s)",user->nick,modules[i],V.Major,V.Minor,V.Revision,V.Build,CleanFilename(modulename),flagstate+2); - for (int it = 0; itab[it]; it++) - WriteServ(user->fd,"900 %s :%s [%s = %d]",user->nick,CleanFilename(modulename),itab[it],Config->implement_lists[i]); + if (match(Config->module_names[i].c_str(),parameters[1])) + { + WriteServ(user->fd,"900 %s :0x%08lx %d.%d.%d.%d %s (%s)",user->nick,modules[i],V.Major,V.Minor,V.Revision,V.Build,CleanFilename(modulename),flagstate+2); + for (int it = 0; itab[it];) + { + char data[MAXBUF]; + char dlist[MAXBUF]; + *dlist = 0; + for (int v = 0; v < 4; v++) + { + if (itab[it]) + { + snprintf(data,MAXBUF,"%s=>%c ",itab[it],(Config->implement_lists[i][it] ? '1' : '0')); + strncat(dlist,data,MAXBUF); + it++; + } + } + if (*dlist) + WriteServ(user->fd,"900 %s :%s [ %s]",user->nick,CleanFilename(modulename),dlist); + } + WriteServ(user->fd,"900 %s :=== DEBUG: Implementation counts ===",user->nick); + for (int it = 0; itab[it]; it++) + { + WriteServ(user->fd,"900 %s :%s: %d times",user->nick, itab[it],(int)Config->global_implementation[it]); + } + } } else { diff --git a/src/inspircd.cpp b/src/inspircd.cpp index 24effa62a..b68f4934e 100644 --- a/src/inspircd.cpp +++ b/src/inspircd.cpp @@ -196,6 +196,8 @@ InspIRCd::InspIRCd(int argc, char** argv) for(int t = 0; t < 255; t++) Config->global_implementation[t] = 0; + memset(&Config->implement_lists,0,sizeof(Config->implement_lists)); + printf("\n"); if (!Config->nofork) { @@ -299,7 +301,9 @@ bool InspIRCd::UnloadModule(const char* filename) } for(int t = 0; t < 255; t++) + { Config->global_implementation[t] -= Config->implement_lists[j][t]; + } FOREACH_MOD(I_OnUnloadModule,OnUnloadModule(modules[j],Config->module_names[j])); // found the module @@ -374,7 +378,13 @@ bool InspIRCd::LoadModule(const char* filename) modules[MODCOUNT+1]->Implements(x); for(int t = 0; t < 255; t++) + { Config->global_implementation[t] += Config->implement_lists[MODCOUNT+1][t]; + if (Config->implement_lists[MODCOUNT+1][t]) + { + log(DEBUG,"Add global implementation: %d %d => %d",MODCOUNT+1,t,Config->global_implementation[t]); + } + } } else { |