diff options
-rw-r--r-- | src/modules/m_joinflood.cpp | 23 | ||||
-rw-r--r-- | src/modules/m_messageflood.cpp | 23 | ||||
-rw-r--r-- | src/modules/m_redirect.cpp | 23 |
3 files changed, 12 insertions, 57 deletions
diff --git a/src/modules/m_joinflood.cpp b/src/modules/m_joinflood.cpp index a15c48bc9..ca19bf14a 100644 --- a/src/modules/m_joinflood.cpp +++ b/src/modules/m_joinflood.cpp @@ -221,25 +221,10 @@ class ModuleJoinFlood : public Module List[I_On005Numeric] = List[I_OnExtendedMode] = List[I_OnChannelDelete] = List[I_OnUserPreJoin] = List[I_OnUserJoin] = 1; } - virtual void On005Numeric(std::string &output) - { - std::stringstream line(output); - std::string temp1, temp2; - while (!line.eof()) - { - line >> temp1; - if (temp1.substr(0,10) == "CHANMODES=") - { - // By doing this we're *assuming* no other module has fucked up the CHANMODES= - // section of the 005 numeric. If they have, we're going DOWN in a blaze of glory, - // with a honking great EXCEPTION :) - temp1.insert(temp1.find(",")+1,"j"); - } - temp2 = temp2 + temp1 + " "; - } - if (temp2.length()) - output = temp2.substr(0,temp2.length()-1); - } + virtual void On005Numeric(std::string &output) + { + InsertMode(output, "j", 3); + } virtual ~ModuleJoinFlood() { diff --git a/src/modules/m_messageflood.cpp b/src/modules/m_messageflood.cpp index 9e2f2a030..f2c55d584 100644 --- a/src/modules/m_messageflood.cpp +++ b/src/modules/m_messageflood.cpp @@ -226,25 +226,10 @@ class ModuleMsgFlood : public Module List[I_On005Numeric] = List[I_OnExtendedMode] = List[I_OnChannelDelete] = List[I_OnUserNotice] = List[I_OnUserMessage] = 1; } - virtual void On005Numeric(std::string &output) - { - std::stringstream line(output); - std::string temp1, temp2; - while (!line.eof()) - { - line >> temp1; - if (temp1.substr(0,10) == "CHANMODES=") - { - // By doing this we're *assuming* no other module has fucked up the CHANMODES= - // section of the 005 numeric. If they have, we're going DOWN in a blaze of glory, - // with a honking great EXCEPTION :) - temp1.insert(temp1.find(",")+1,"f"); - } - temp2 = temp2 + temp1 + " "; - } - if (temp2.length()) - output = temp2.substr(0,temp2.length()-1); - } + virtual void On005Numeric(std::string &output) + { + InsertMode(output, "f", 3); + } virtual ~ModuleMsgFlood() { diff --git a/src/modules/m_redirect.cpp b/src/modules/m_redirect.cpp index bedb90077..a7115a15e 100644 --- a/src/modules/m_redirect.cpp +++ b/src/modules/m_redirect.cpp @@ -66,25 +66,10 @@ class ModuleRedirect : public Module List[I_On005Numeric] = List[I_OnUserPreJoin] = List[I_OnExtendedMode] = 1; } - virtual void On005Numeric(std::string &output) - { - std::stringstream line(output); - std::string temp1, temp2; - while (!line.eof()) - { - line >> temp1; - if (temp1.substr(0,10) == "CHANMODES=") - { - // By doing this we're *assuming* no other module has fucked up the CHANMODES= - // section of the 005 numeric. If they have, we're going DOWN in a blaze of glory, - // with a honking great EXCEPTION :) - temp1.insert(temp1.find(",")+1,"L"); - } - temp2 = temp2 + temp1 + " "; - } - if (temp2.length()) - output = temp2.substr(0,temp2.length()-1); - } + virtual void On005Numeric(std::string &output) + { + InsertMode(output, "L", 3); + } virtual int OnUserPreJoin(userrec* user, chanrec* chan, const char* cname) { |