diff options
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; + } + } +} + |