From ad9d6ad02a7f6f35e02870f50035d54bc2231f04 Mon Sep 17 00:00:00 2001 From: attilamolnar Date: Sun, 24 Jun 2012 17:09:03 +0200 Subject: m_opermodes Remove unused OnRehash hook, don't touch remote opers, send mode changes with SendMode --- src/modules/m_opermodes.cpp | 27 ++++++++------------------- 1 file changed, 8 insertions(+), 19 deletions(-) (limited to 'src') diff --git a/src/modules/m_opermodes.cpp b/src/modules/m_opermodes.cpp index d029fda64..0b04ff576 100644 --- a/src/modules/m_opermodes.cpp +++ b/src/modules/m_opermodes.cpp @@ -29,13 +29,7 @@ class ModuleModesOnOper : public Module public: ModuleModesOnOper() { - Implementation eventlist[] = { I_OnPostOper, I_OnRehash }; - ServerInstance->Modules->Attach(eventlist, this, 2); - } - - - virtual void OnRehash(User* user) - { + ServerInstance->Modules->Attach(I_OnPostOper, this); } virtual ~ModuleModesOnOper() @@ -49,6 +43,9 @@ class ModuleModesOnOper : public Module virtual void OnPostOper(User* user, const std::string &opertype, const std::string &opername) { + if (!IS_LOCAL(user)) + return; + // whenever a user opers, go through the oper types, find their , // and if they have one apply their modes. The mode string can contain +modes // to add modes to the user or -modes to take modes from the user. @@ -67,22 +64,14 @@ class ModuleModesOnOper : public Module std::string buf; std::stringstream ss(smodes); - std::vector tokens; + std::vector modes; + modes.push_back(u->nick); // split into modes and mode params while (ss >> buf) - tokens.push_back(buf); - - std::vector modes; - modes.push_back(u->nick); - - // process mode params - for (unsigned int k = 0; k < tokens.size(); k++) - { - modes.push_back(tokens[k]); - } + modes.push_back(buf); - ServerInstance->SendGlobalMode(modes, u); + ServerInstance->SendMode(modes, u); } }; -- cgit v1.2.3