summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2008-03-18 23:54:33 +0000
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2008-03-18 23:54:33 +0000
commit525eeb51a52ca9dbd001f0897222f6e5a3dccfb1 (patch)
tree971f1c206b59b12baa41d1cf476ecf385aa98e57
parent9a2481ebf1109adc4b626414108d92674793cd5d (diff)
Crash fixes from nenolod
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@9126 e03df62e-2008-0410-955e-edbf42e46eb7
-rw-r--r--src/modules/m_cap.cpp9
-rw-r--r--src/modules/m_namesx.cpp4
2 files changed, 9 insertions, 4 deletions
diff --git a/src/modules/m_cap.cpp b/src/modules/m_cap.cpp
index 5673c7f62..86f79103c 100644
--- a/src/modules/m_cap.cpp
+++ b/src/modules/m_cap.cpp
@@ -98,8 +98,13 @@ class CommandCAP : public Command
Event event((char*) &Data, (Module*)this->Creator, subcommand == "LS" ? "cap_ls" : "cap_list");
event.Send(this->ServerInstance);
- std::string Result = irc::stringjoiner(" ", Data.wanted, 0, Data.wanted.size() - 1).GetJoined();
- user->WriteServ("CAP * LS :%s", Result.c_str());
+ std::string Result;
+ if (Data.wanted.size() > 0)
+ Result = irc::stringjoiner(" ", Data.wanted, 0, Data.wanted.size() - 1).GetJoined();
+ else
+ Result = "";
+
+ user->WriteServ("CAP * %s :%s", subcommand.c_str(), Result.c_str());
}
else if (subcommand == "CLEAR")
{
diff --git a/src/modules/m_namesx.cpp b/src/modules/m_namesx.cpp
index a1ae48b70..2e79d6a06 100644
--- a/src/modules/m_namesx.cpp
+++ b/src/modules/m_namesx.cpp
@@ -129,8 +129,8 @@ class ModuleNamesX : public Module
if ((it = std::find(data->wanted.begin(), data->wanted.end(), "multi-prefix")) != data->wanted.end())
{
// we can handle this, so ACK it, and remove it from the wanted list
- data->wanted.erase(it);
data->ack.push_back(*it);
+ data->wanted.erase(it);
data->user->Extend("NAMESX",dummy);
}
}
@@ -146,7 +146,7 @@ class ModuleNamesX : public Module
CapData *data = (CapData *) ev->GetData();
if (data->user->GetExt("NAMESX"))
- data->ack.push_back("multi-prefix");
+ data->wanted.push_back("multi-prefix");
}
if (ev->GetEventID() == "cap_clear")