diff options
author | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2003-01-26 20:15:03 +0000 |
---|---|---|
committer | brain <brain@e03df62e-2008-0410-955e-edbf42e46eb7> | 2003-01-26 20:15:03 +0000 |
commit | 114b15864ac8cf4143ed415dd90b7550e2b5687c (patch) | |
tree | 05cb985ce22632b845d1a5e1b841aea72db793b7 /src | |
parent | 76b2090ea3960ac4768ea8e9722c3e00e4c8b185 (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.cpp | 5 | ||||
-rw-r--r-- | src/servers.cpp | 62 |
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; + } + } +} + |