]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_spanningtree/treeserver.h
Remove InspIRCd* parameters and fields
[user/henk/code/inspircd.git] / src / modules / m_spanningtree / treeserver.h
index 28e36252d905a6cd18e5a309d0d7aee2dd2d0b85..24f9c0499131e873d3e1dd5f1bcdf8d2c3389b77 100644 (file)
@@ -2,8 +2,8 @@
  *       | Inspire Internet Relay Chat Daemon |
  *       +------------------------------------+
  *
- *  InspIRCd: (C) 2002-2007 InspIRCd Development Team
- * See: http://www.inspircd.org/wiki/index.php/Credits
+ *  InspIRCd: (C) 2002-2009 InspIRCd Development Team
+ * See: http://wiki.inspircd.org/Credits
  *
  * This program is free but copyrighted software; see
  *            the file COPYING for details.
@@ -30,7 +30,6 @@
  */
 class TreeServer : public classbase
 {
-       InspIRCd* ServerInstance;               /* Creator */
        TreeServer* Parent;                     /* Parent entry */
        TreeServer* Route;                      /* Route entry */
        std::vector<TreeServer*> Children;      /* List of child objects */
@@ -44,7 +43,6 @@ class TreeServer : public classbase
        bool LastPingWasGood;                   /* True if the server responded to the last PING with a PONG */
        SpanningTreeUtilities* Utils;           /* Utility class */
        std::string sid;                        /* Server ID */
-       bool DupError;                          /* True if the server ID is duplicated (!) */
 
        /** Set server ID
         * @param id Server ID
@@ -53,25 +51,22 @@ class TreeServer : public classbase
        void SetID(const std::string &id);
 
  public:
+       time_t age;
 
        bool Warned;                            /* True if we've warned opers about high latency on this server */
-
-       /** We don't use this constructor. Its a dummy, and won't cause any insertion
-        * of the TreeServer into the hash_map. See below for the two we DO use.
-        */
-       TreeServer(SpanningTreeUtilities* Util, InspIRCd* Instance, const std::string &id);
+       bool bursting;                          /* whether or not this server is bursting */
 
        /** We use this constructor only to create the 'root' item, Utils->TreeRoot, which
         * represents our own server. Therefore, it has no route, no parent, and
         * no socket associated with it. Its version string is our own local version.
         */
-       TreeServer(SpanningTreeUtilities* Util, InspIRCd* Instance, std::string Name, std::string Desc, const std::string &id);
-       
+       TreeServer(SpanningTreeUtilities* Util, std::string Name, std::string Desc, const std::string &id);
+
        /** When we create a new server, we call this constructor to initialize it.
         * This constructor initializes the server's Route and Parent, and sets up
         * its ping counters so that it will be pinged one minute from now.
         */
-       TreeServer(SpanningTreeUtilities* Util, InspIRCd* Instance, std::string Name, std::string Desc, const std::string &id, TreeServer* Above, TreeSocket* Sock, bool Hide);
+       TreeServer(SpanningTreeUtilities* Util, std::string Name, std::string Desc, const std::string &id, TreeServer* Above, TreeSocket* Sock, bool Hide);
 
        int QuitUsers(const std::string &reason);
 
@@ -113,10 +108,6 @@ class TreeServer : public classbase
         */
        time_t NextPingTime();
 
-       /** Time of last ping used to calculate this->rtt below
-        */
-       time_t LastPing;
-
        /** Last ping time in microseconds, used to calculate round trip time
         */
        unsigned long LastPingMsec;
@@ -125,6 +116,10 @@ class TreeServer : public classbase
         */
        unsigned long rtt;
 
+       /** When we recieved BURST from this server, used to calculate total burst time at ENDBURST.
+        */
+       unsigned long StartBurst;
+
        /** True if this server is hidden
         */
        bool Hidden;
@@ -193,9 +188,11 @@ class TreeServer : public classbase
         */
        std::string& GetID();
 
-       /** True on duplicate server ID (server not usable)
+       /** Marks a server as having finished bursting and performs appropriate actions.
         */
-       bool DuplicateID();
+       void FinishBurst();
+       /** Recursive call for child servers */
+       void FinishBurstInternal();
 
        /** Destructor
         */