From 32cb484b7ab86d4bd866d50ff95875e05a9f8b0d Mon Sep 17 00:00:00 2001 From: brain Date: Tue, 17 Oct 2006 20:37:46 +0000 Subject: Add a ton of comments to make this much more useful now (putting it all in a class essentially forward-declares the lot and gives opportunity to comment) remove 'using namespace std' which we dont need. git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@5490 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/modules/m_spanningtree.cpp | 68 +++++++++++++++++++++++++++++++++++------- 1 file changed, 58 insertions(+), 10 deletions(-) (limited to 'src/modules/m_spanningtree.cpp') diff --git a/src/modules/m_spanningtree.cpp b/src/modules/m_spanningtree.cpp index c4708ab38..b81e2e95a 100644 --- a/src/modules/m_spanningtree.cpp +++ b/src/modules/m_spanningtree.cpp @@ -16,8 +16,6 @@ /* $ModDesc: Povides a spanning tree server link protocol */ -using namespace std; - #include "configreader.h" #include "users.h" #include "channels.h" @@ -91,38 +89,88 @@ typedef nspace::hash_map, irc::St class SpanningTreeUtilities { private: + /** Creator server + */ InspIRCd* ServerInstance; public: + /** Creator module + */ ModuleSpanningTree* Creator; - bool FlatLinks; /* Flatten links and /MAP for non-opers */ - bool HideULines; /* Hide U-Lined servers in /MAP and /LINKS */ - bool AnnounceTSChange; /* Announce TS changes to channels on merge */ - std::vector Bindings; /* Socket bindings */ - /* This variable represents the root of the server tree */ + /** Flatten links and /MAP for non-opers + */ + bool FlatLinks; + /** Hide U-Lined servers in /MAP and /LINKS + */ + bool HideULines; + /** Announce TS changes to channels on merge + */ + bool AnnounceTSChange; + /** Socket bindings for listening sockets + */ + std::vector Bindings; + /** This variable represents the root of the server tree + */ TreeServer *TreeRoot; - /* IPs allowed to link to us */ + /** IPs allowed to link to us + */ std::vector ValidIPs; - /* Hash of currently connected servers by name */ + /** Hash of currently connected servers by name + */ server_hash serverlist; - /* Holds the data from the tags in the conf */ + /** Holds the data from the tags in the conf + */ std::vector LinkBlocks; + /** Initialise utility class + */ SpanningTreeUtilities(InspIRCd* Instance, ModuleSpanningTree* Creator); + /** Destroy class and free listeners etc + */ ~SpanningTreeUtilities(); + /** Send a message from this server to one other local or remote + */ bool DoOneToOne(std::string prefix, std::string command, std::deque ¶ms, std::string target); + /** Send a message from this server to all but one other, local or remote + */ bool DoOneToAllButSender(std::string prefix, std::string command, std::deque ¶ms, std::string omit); + /** Send a message from this server to all but one other, local or remote + */ bool DoOneToAllButSender(const char* prefix, const char* command, std::deque ¶ms, std::string omit); + /** Send a message from this server to all others + */ bool DoOneToMany(std::string prefix, std::string command, std::deque ¶ms); + /** Send a message from this server to all others + */ bool DoOneToMany(const char* prefix, const char* command, std::deque ¶ms); + /** Send a message from this server to all others, without doing any processing on the command (e.g. send it as-is with colons and all) + */ bool DoOneToAllButSenderRaw(std::string data, std::string omit, std::string prefix, irc::string command, std::deque ¶ms); + /** Read the spanningtree module's tags from the config file + */ void ReadConfiguration(bool rebind); + /** Add a server to the server list for GetListOfServersForChannel + */ void AddThisServer(TreeServer* server, std::deque &list); + /** Compile a list of servers which contain members of channel c + */ void GetListOfServersForChannel(chanrec* c, std::deque &list); + /** Find a server by name + */ TreeServer* FindServer(std::string ServerName); + /** Find a route to a server by name + */ TreeServer* BestRouteTo(std::string ServerName); + /** Find a server by glob mask + */ TreeServer* FindServerMask(std::string ServerName); + /** Returns true if this is a server name we recognise + */ bool IsServer(std::string ServerName); + /** Attempt to connect to the failover link of link x + */ void DoFailOver(Link* x); + /** Find a link tag from a server name + */ Link* FindLink(const std::string& name); }; -- cgit v1.2.3