From da04e0622c37d3d1ec6c3313fb5a82cbf9901329 Mon Sep 17 00:00:00 2001 From: Attila Molnar Date: Fri, 19 Aug 2016 11:21:19 +0200 Subject: m_spanningtree Put command handlers with class names that collide with core commands into the SpanningTree namespace This fixes issues in static builds --- src/modules/m_spanningtree/away.cpp | 2 +- src/modules/m_spanningtree/commands.h | 47 +++++++++++++++++++++++------------ src/modules/m_spanningtree/nick.cpp | 2 +- 3 files changed, 33 insertions(+), 18 deletions(-) (limited to 'src') diff --git a/src/modules/m_spanningtree/away.cpp b/src/modules/m_spanningtree/away.cpp index f14c8ac98..7c514c49e 100644 --- a/src/modules/m_spanningtree/away.cpp +++ b/src/modules/m_spanningtree/away.cpp @@ -23,7 +23,7 @@ #include "utils.h" #include "commands.h" -CmdResult CommandAway::HandleRemote(RemoteUser* u, std::vector& params) +CmdResult CommandAway::HandleRemote(::RemoteUser* u, std::vector& params) { if (params.size()) { diff --git a/src/modules/m_spanningtree/commands.h b/src/modules/m_spanningtree/commands.h index feecc7dd2..8eea02915 100644 --- a/src/modules/m_spanningtree/commands.h +++ b/src/modules/m_spanningtree/commands.h @@ -23,6 +23,21 @@ #include "commandbuilder.h" #include "remoteuser.h" +namespace SpanningTree +{ + class CommandAway; + class CommandNick; + class CommandPing; + class CommandPong; + class CommandServer; +} + +using SpanningTree::CommandAway; +using SpanningTree::CommandNick; +using SpanningTree::CommandPing; +using SpanningTree::CommandPong; +using SpanningTree::CommandServer; + /** Handle /RCONNECT */ class CommandRConnect : public Command @@ -224,11 +239,11 @@ class CommandResync : public ServerOnlyServerCommand RouteDescriptor GetRouting(User* user, const std::vector& parameters) { return ROUTE_LOCALONLY; } }; -class CommandAway : public UserOnlyServerCommand +class SpanningTree::CommandAway : public UserOnlyServerCommand { public: - CommandAway(Module* Creator) : UserOnlyServerCommand(Creator, "AWAY", 0, 2) { } - CmdResult HandleRemote(RemoteUser* user, std::vector& parameters); + CommandAway(Module* Creator) : UserOnlyServerCommand(Creator, "AWAY", 0, 2) { } + CmdResult HandleRemote(::RemoteUser* user, std::vector& parameters); class Builder : public CmdBuilder { @@ -275,14 +290,14 @@ class CommandIdle : public UserOnlyServerCommand RouteDescriptor GetRouting(User* user, const std::vector& parameters) { return ROUTE_UNICAST(parameters[0]); } }; -class CommandNick : public UserOnlyServerCommand +class SpanningTree::CommandNick : public UserOnlyServerCommand { public: - CommandNick(Module* Creator) : UserOnlyServerCommand(Creator, "NICK", 2) { } - CmdResult HandleRemote(RemoteUser* user, std::vector& parameters); + CommandNick(Module* Creator) : UserOnlyServerCommand(Creator, "NICK", 2) { } + CmdResult HandleRemote(::RemoteUser* user, std::vector& parameters); }; -class CommandPing : public ServerCommand +class SpanningTree::CommandPing : public ServerCommand { public: CommandPing(Module* Creator) : ServerCommand(Creator, "PING", 1) { } @@ -290,10 +305,10 @@ class CommandPing : public ServerCommand RouteDescriptor GetRouting(User* user, const std::vector& parameters) { return ROUTE_UNICAST(parameters[0]); } }; -class CommandPong : public ServerOnlyServerCommand +class SpanningTree::CommandPong : public ServerOnlyServerCommand { public: - CommandPong(Module* Creator) : ServerOnlyServerCommand(Creator, "PONG", 1) { } + CommandPong(Module* Creator) : ServerOnlyServerCommand(Creator, "PONG", 1) { } CmdResult HandleServer(TreeServer* server, std::vector& parameters); RouteDescriptor GetRouting(User* user, const std::vector& parameters) { return ROUTE_UNICAST(parameters[0]); } }; @@ -309,12 +324,12 @@ class CommandSave : public ServerCommand CmdResult Handle(User* user, std::vector& parameters); }; -class CommandServer : public ServerOnlyServerCommand +class SpanningTree::CommandServer : public ServerOnlyServerCommand { static void HandleExtra(TreeServer* newserver, const std::vector& params); public: - CommandServer(Module* Creator) : ServerOnlyServerCommand(Creator, "SERVER", 3) { } + CommandServer(Module* Creator) : ServerOnlyServerCommand(Creator, "SERVER", 3) { } CmdResult HandleServer(TreeServer* server, std::vector& parameters); class Builder : public CmdBuilder @@ -393,16 +408,16 @@ class SpanningTreeCommands CommandFHost fhost; CommandFIdent fident; CommandFName fname; - CommandAway away; + SpanningTree::CommandAway away; CommandAddLine addline; CommandDelLine delline; CommandEncap encap; CommandIdle idle; - CommandNick nick; - CommandPing ping; - CommandPong pong; + SpanningTree::CommandNick nick; + SpanningTree::CommandPing ping; + SpanningTree::CommandPong pong; CommandSave save; - CommandServer server; + SpanningTree::CommandServer server; CommandSQuit squit; CommandSNONotice snonotice; CommandEndBurst endburst; diff --git a/src/modules/m_spanningtree/nick.cpp b/src/modules/m_spanningtree/nick.cpp index 1d853a2df..9e290e07f 100644 --- a/src/modules/m_spanningtree/nick.cpp +++ b/src/modules/m_spanningtree/nick.cpp @@ -30,7 +30,7 @@ #include "commands.h" #include "treeserver.h" -CmdResult CommandNick::HandleRemote(RemoteUser* user, std::vector& params) +CmdResult CommandNick::HandleRemote(::RemoteUser* user, std::vector& params) { if ((isdigit(params[0][0])) && (params[0] != user->uuid)) throw ProtocolException("Attempted to change nick to an invalid or non-matching UUID"); -- cgit v1.2.3