summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2003-01-26 20:15:03 +0000
committerbrain <brain@e03df62e-2008-0410-955e-edbf42e46eb7>2003-01-26 20:15:03 +0000
commit114b15864ac8cf4143ed415dd90b7550e2b5687c (patch)
tree05cb985ce22632b845d1a5e1b841aea72db793b7 /src
parent76b2090ea3960ac4768ea8e9722c3e00e4c8b185 (diff)
Added server classes for linking
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@149 e03df62e-2008-0410-955e-edbf42e46eb7
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;
+ }
+ }
+}
+