From: Attila Molnar Date: Tue, 29 Mar 2016 14:39:06 +0000 (+0200) Subject: m_spanningtree Add CommandNum::Builder X-Git-Url: https://git.netwichtig.de/gitweb/?a=commitdiff_plain;ds=sidebyside;h=484b30f67b1479de72ff99532b7b91e775686e97;p=user%2Fhenk%2Fcode%2Finspircd.git m_spanningtree Add CommandNum::Builder --- diff --git a/src/modules/m_spanningtree/commands.h b/src/modules/m_spanningtree/commands.h index a65639434..4810e9d4b 100644 --- a/src/modules/m_spanningtree/commands.h +++ b/src/modules/m_spanningtree/commands.h @@ -21,6 +21,7 @@ #include "servercommand.h" #include "commandbuilder.h" +#include "remoteuser.h" /** Handle /RCONNECT */ @@ -375,6 +376,12 @@ class CommandNum : public ServerOnlyServerCommand CommandNum(Module* Creator) : ServerOnlyServerCommand(Creator, "NUM", 3) { } CmdResult HandleServer(TreeServer* server, std::vector& parameters); RouteDescriptor GetRouting(User* user, const std::vector& parameters); + + class Builder : public CmdBuilder + { + public: + Builder(SpanningTree::RemoteUser* target, const Numeric::Numeric& numeric); + }; }; class SpanningTreeCommands diff --git a/src/modules/m_spanningtree/num.cpp b/src/modules/m_spanningtree/num.cpp index 047dba432..2c8697c9a 100644 --- a/src/modules/m_spanningtree/num.cpp +++ b/src/modules/m_spanningtree/num.cpp @@ -21,6 +21,7 @@ #include "utils.h" #include "commands.h" +#include "remoteuser.h" CmdResult CommandNum::HandleServer(TreeServer* server, std::vector& params) { @@ -45,3 +46,17 @@ RouteDescriptor CommandNum::GetRouting(User* user, const std::vector(numeric.GetServer())) : Utils->TreeRoot); + push(server->GetID()).push(target->uuid).push(InspIRCd::Format("%03u", numeric.GetNumeric())); + const std::vector& params = numeric.GetParams(); + if (!params.empty()) + { + for (std::vector::const_iterator i = params.begin(); i != params.end()-1; ++i) + push(*i); + push_last(params.back()); + } +}