]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_spanningtree/num.cpp
Optimize some behaviour in the core (#1476).
[user/henk/code/inspircd.git] / src / modules / m_spanningtree / num.cpp
index 047dba4322b9826528f3e5c02190ea8e18875a3c..2c8697c9a5b6b64704db6fd8a3cd1a435fd954c8 100644 (file)
@@ -21,6 +21,7 @@
 
 #include "utils.h"
 #include "commands.h"
+#include "remoteuser.h"
 
 CmdResult CommandNum::HandleServer(TreeServer* server, std::vector<std::string>& params)
 {
@@ -45,3 +46,17 @@ RouteDescriptor CommandNum::GetRouting(User* user, const std::vector<std::string
 {
        return ROUTE_UNICAST(params[1]);
 }
+
+CommandNum::Builder::Builder(SpanningTree::RemoteUser* target, const Numeric::Numeric& numeric)
+       : CmdBuilder("NUM")
+{
+       TreeServer* const server = (numeric.GetServer() ? (static_cast<TreeServer*>(numeric.GetServer())) : Utils->TreeRoot);
+       push(server->GetID()).push(target->uuid).push(InspIRCd::Format("%03u", numeric.GetNumeric()));
+       const std::vector<std::string>& params = numeric.GetParams();
+       if (!params.empty())
+       {
+               for (std::vector<std::string>::const_iterator i = params.begin(); i != params.end()-1; ++i)
+                       push(*i);
+               push_last(params.back());
+       }
+}