summaryrefslogtreecommitdiff
path: root/src/modules
diff options
context:
space:
mode:
authorAttila Molnar <attilamolnar@hush.com>2014-02-22 14:00:04 +0100
committerAttila Molnar <attilamolnar@hush.com>2014-02-22 14:00:04 +0100
commit7affd6453d9d564636da5fe5c0fe7baba5fecf7a (patch)
tree4fd4c2992e67dfaf6f63935ec9e07b738abb789d /src/modules
parent7ffef79f97c8dc9f21da35dff9f822be7f62edf3 (diff)
Add ModeParser::GetModes(), returns all user/chanmodes
Diffstat (limited to 'src/modules')
-rw-r--r--src/modules/m_namedmodes.cpp7
-rw-r--r--src/modules/m_spanningtree/fjoin.cpp8
2 files changed, 7 insertions, 8 deletions
diff --git a/src/modules/m_namedmodes.cpp b/src/modules/m_namedmodes.cpp
index e8b90caa3..5c0ffeea5 100644
--- a/src/modules/m_namedmodes.cpp
+++ b/src/modules/m_namedmodes.cpp
@@ -22,11 +22,10 @@
static void DisplayList(User* user, Channel* channel)
{
std::stringstream items;
- for(char letter = 'A'; letter <= 'z'; letter++)
+ const ModeParser::ModeHandlerMap& mhs = ServerInstance->Modes->GetModes(MODETYPE_CHANNEL);
+ for (ModeParser::ModeHandlerMap::const_iterator i = mhs.begin(); i != mhs.end(); ++i)
{
- ModeHandler* mh = ServerInstance->Modes->FindMode(letter, MODETYPE_CHANNEL);
- if (!mh || mh->IsListMode())
- continue;
+ ModeHandler* mh = i->second;
if (!channel->IsModeSet(mh))
continue;
items << " +" << mh->name;
diff --git a/src/modules/m_spanningtree/fjoin.cpp b/src/modules/m_spanningtree/fjoin.cpp
index d697af63d..ea7711332 100644
--- a/src/modules/m_spanningtree/fjoin.cpp
+++ b/src/modules/m_spanningtree/fjoin.cpp
@@ -214,16 +214,16 @@ void CommandFJoin::RemoveStatus(Channel* c)
{
irc::modestacker stack(false);
- for (char modeletter = 'A'; modeletter <= 'z'; ++modeletter)
+ const ModeParser::ModeHandlerMap& mhs = ServerInstance->Modes->GetModes(MODETYPE_CHANNEL);
+ for (ModeParser::ModeHandlerMap::const_iterator i = mhs.begin(); i != mhs.end(); ++i)
{
- ModeHandler* mh = ServerInstance->Modes->FindMode(modeletter, MODETYPE_CHANNEL);
+ ModeHandler* mh = i->second;
/* Passing a pointer to a modestacker here causes the mode to be put onto the mode stack,
* rather than applied immediately. Module unloads require this to be done immediately,
* for this function we require tidyness instead. Fixes bug #493
*/
- if (mh)
- mh->RemoveMode(c, stack);
+ mh->RemoveMode(c, stack);
}
ApplyModeStack(ServerInstance->FakeClient, c, stack);