summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/inspircd.cpp5
-rw-r--r--src/servers.cpp62
2 files changed, 67 insertions, 0 deletions
diff --git a/src/inspircd.cpp b/src/inspircd.cpp
index 194bd29c2..a5bbdcfa0 100644
--- a/src/inspircd.cpp
+++ b/src/inspircd.cpp
@@ -14,6 +14,9 @@
* ---------------------------------------------------
$Log$
+ Revision 1.4 2003/01/26 20:15:03 brain
+ Added server classes for linking
+
Revision 1.3 2003/01/25 20:17:53 brain
Fixed WHOWAS memory leak
@@ -210,6 +213,7 @@
#include <errno.h>
#include <deque>
#include "users.h"
+#include "servers.h"
#include "ctables.h"
#include "globals.h"
#include "modules.h"
@@ -301,6 +305,7 @@ typedef DLLFactory<ModuleFactory> ircd_module;
user_hash clientlist;
chan_hash chanlist;
user_hash whowas;
+server_list servers;
command_table cmdlist;
file_cache MOTD;
file_cache RULES;
diff --git a/src/servers.cpp b/src/servers.cpp
new file mode 100644
index 000000000..44bd2e0c3
--- /dev/null
+++ b/src/servers.cpp
@@ -0,0 +1,62 @@
+/*
+
+$Log$
+Revision 1.1 2003/01/26 20:15:03 brain
+Added server classes for linking
+
+
+*/
+
+#include "inspircd_config.h"
+#include "servers.h"
+#include "inspircd.h"
+#include <stdio.h>
+
+serverrec::serverrec()
+{
+ leaf.clear();
+ strcpy(name,"");
+ pingtime = 0;
+ linktype = LINK_ACTIVE;
+ lastping = time(NULL);
+ usercount_i = usercount = opercount = version = 0;
+ hops_away = 1;
+ connected_at = time(NULL);
+ jupiter = false;
+}
+
+
+serverrec::~serverrec()
+{
+}
+
+serverrec::serverrec(char* n, int link_t, long ver, bool jupe)
+{
+ leaf.clear();
+ strcpy(name,n);
+ linktype = link_t;
+ lastping = time(NULL);
+ usercount_i = usercount = opercount = 0;
+ version = ver;
+ hops_away = 1;
+ connected_at = time(NULL);
+ jupiter = jupe;
+}
+
+void serverrec::AddLeaf(serverrec *child)
+{
+ leaf.push_back(child);
+}
+
+void serverrec::DelLeaf(char* n)
+{
+ for (server_list::iterator i = leaf.begin(); i != leaf.end(); i++)
+ {
+ if (strcasecmp(n,i->name))
+ {
+ leaf.erase(i);
+ return;
+ }
+ }
+}
+