From 4d5a17380bc71cabe544b41c7c8a26a292384f3d Mon Sep 17 00:00:00 2001 From: brain Date: Sun, 15 May 2005 17:05:15 +0000 Subject: [PATCH] Added docs for hashcomp git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@1396 e03df62e-2008-0410-955e-edbf42e46eb7 --- docs/man/man3/Admin.3 | 6 +- docs/man/man3/BanItem.3 | 2 +- docs/man/man3/ConfigReader.3 | 274 +-- docs/man/man3/ConnectClass.3 | 2 +- docs/man/man3/DNS.3 | 2 +- docs/man/man3/ELine.3 | 2 +- docs/man/man3/Event.3 | 40 +- docs/man/man3/ExemptItem.3 | 2 +- docs/man/man3/ExtMode.3 | 18 +- docs/man/man3/Extensible.3 | 2 +- docs/man/man3/FileReader.3 | 84 +- docs/man/man3/GLine.3 | 2 +- docs/man/man3/HostItem.3 | 2 +- docs/man/man3/InAddr_HashComp.3 | 33 +- docs/man/man3/InviteItem.3 | 2 +- docs/man/man3/Invited.3 | 2 +- docs/man/man3/KLine.3 | 2 +- docs/man/man3/ModeParameter.3 | 2 +- docs/man/man3/Module.3 | 226 +- docs/man/man3/ModuleFactory.3 | 12 +- docs/man/man3/ModuleMessage.3 | 2 +- docs/man/man3/QLine.3 | 2 +- docs/man/man3/Request.3 | 52 +- docs/man/man3/Server.3 | 769 +++---- docs/man/man3/StrHashComp.3 | 32 +- docs/man/man3/Version.3 | 6 +- docs/man/man3/WhoWasUser.3 | 18 +- docs/man/man3/XLine.3 | 2 +- docs/man/man3/ZLine.3 | 2 +- docs/man/man3/base.h.3 | 2 +- docs/man/man3/channels.cpp.3 | 90 +- docs/man/man3/channels.h.3 | 2 +- docs/man/man3/chanrec.3 | 216 +- docs/man/man3/classbase.3 | 2 +- docs/man/man3/command_t.3 | 2 +- docs/man/man3/commands.h.3 | 98 +- docs/man/man3/connection.3 | 38 +- docs/man/man3/connection.h.3 | 13 +- docs/man/man3/ctables.h.3 | 2 +- docs/man/man3/dns.h.3 | 2 +- docs/man/man3/dns_ip4list.3 | 2 +- docs/man/man3/hashcomp.h.3 | 50 + docs/man/man3/irc.3 | 36 + docs/man/man3/irc_irc_char_traits.3 | 66 + docs/man/man3/ircd_connector.3 | 24 +- docs/man/man3/message.h.3 | 2 +- docs/man/man3/mode.h.3 | 2 +- docs/man/man3/modules.cpp.3 | 299 ++- docs/man/man3/modules.h.3 | 12 +- docs/man/man3/nspace.3 | 2 +- docs/man/man3/nspace_nspace_hash_ in_addr _.3 | 15 +- docs/man/man3/nspace_nspace_hash_ string _.3 | 17 +- docs/man/man3/serverrec.3 | 60 +- docs/man/man3/servers.cpp.3 | 6 +- docs/man/man3/servers.h.3 | 2 +- docs/man/man3/std.3 | 2 +- docs/man/man3/std_char_traits.3 | 15 + docs/man/man3/ucrec.3 | 2 +- docs/man/man3/userrec.3 | 475 ++-- docs/man/man3/users.cpp.3 | 8 +- docs/man/man3/users.h.3 | 4 +- docs/man/man3/xline.h.3 | 2 +- docs/module-doc/annotated.html | 10 +- docs/module-doc/base_8h-source.html | 4 +- docs/module-doc/base_8h.html | 4 +- docs/module-doc/channels_8cpp-source.html | 401 ++-- docs/module-doc/channels_8cpp.html | 183 +- docs/module-doc/channels_8cpp__incl.gif | Bin 40063 -> 37708 bytes docs/module-doc/channels_8h-source.html | 4 +- docs/module-doc/channels_8h.html | 4 +- docs/module-doc/classAdmin-members.html | 4 +- docs/module-doc/classAdmin.html | 8 +- docs/module-doc/classBanItem-members.html | 4 +- docs/module-doc/classBanItem.html | 4 +- .../module-doc/classConfigReader-members.html | 4 +- docs/module-doc/classConfigReader.html | 322 +-- .../module-doc/classConnectClass-members.html | 4 +- docs/module-doc/classConnectClass.html | 4 +- docs/module-doc/classDNS-members.html | 4 +- docs/module-doc/classDNS.html | 4 +- docs/module-doc/classELine-members.html | 4 +- docs/module-doc/classELine.html | 4 +- docs/module-doc/classEvent-members.html | 4 +- docs/module-doc/classEvent.html | 48 +- docs/module-doc/classExemptItem-members.html | 4 +- docs/module-doc/classExemptItem.html | 4 +- docs/module-doc/classExtMode-members.html | 4 +- docs/module-doc/classExtMode.html | 32 +- docs/module-doc/classExtensible-members.html | 4 +- docs/module-doc/classExtensible.html | 4 +- docs/module-doc/classFileReader-members.html | 4 +- docs/module-doc/classFileReader.html | 98 +- docs/module-doc/classGLine-members.html | 4 +- docs/module-doc/classGLine.html | 4 +- docs/module-doc/classHostItem-members.html | 4 +- docs/module-doc/classHostItem.html | 4 +- docs/module-doc/classInviteItem-members.html | 4 +- docs/module-doc/classInviteItem.html | 4 +- docs/module-doc/classInvited-members.html | 4 +- docs/module-doc/classInvited.html | 6 +- docs/module-doc/classKLine-members.html | 4 +- docs/module-doc/classKLine.html | 4 +- .../classModeParameter-members.html | 4 +- docs/module-doc/classModeParameter.html | 10 +- docs/module-doc/classModule-members.html | 4 +- docs/module-doc/classModule.html | 234 +- .../classModuleFactory-members.html | 4 +- docs/module-doc/classModuleFactory.html | 14 +- .../classModuleMessage-members.html | 4 +- docs/module-doc/classModuleMessage.html | 4 +- docs/module-doc/classQLine-members.html | 4 +- docs/module-doc/classQLine.html | 4 +- docs/module-doc/classRequest-members.html | 4 +- docs/module-doc/classRequest.html | 62 +- docs/module-doc/classServer-members.html | 81 +- docs/module-doc/classServer.html | 1082 ++++----- docs/module-doc/classVersion-members.html | 4 +- docs/module-doc/classVersion.html | 8 +- docs/module-doc/classWhoWasUser-members.html | 4 +- docs/module-doc/classWhoWasUser.html | 20 +- docs/module-doc/classXLine-members.html | 4 +- docs/module-doc/classXLine.html | 4 +- docs/module-doc/classZLine-members.html | 4 +- docs/module-doc/classZLine.html | 4 +- docs/module-doc/classchanrec-members.html | 4 +- docs/module-doc/classchanrec.html | 256 +-- docs/module-doc/classclassbase-members.html | 4 +- docs/module-doc/classclassbase.html | 4 +- docs/module-doc/classcommand__t-members.html | 4 +- docs/module-doc/classcommand__t.html | 4 +- docs/module-doc/classconnection-members.html | 6 +- docs/module-doc/classconnection.html | 74 +- docs/module-doc/classes.html | 30 +- .../classircd__connector-members.html | 4 +- docs/module-doc/classircd__connector.html | 26 +- docs/module-doc/classserverrec-members.html | 6 +- docs/module-doc/classserverrec.html | 86 +- docs/module-doc/classstd_1_1char__traits.html | 22 + ...assstd_1_1char__traits__inherit__graph.gif | Bin 0 -> 1074 bytes docs/module-doc/classucrec-members.html | 4 +- docs/module-doc/classucrec.html | 8 +- docs/module-doc/classuserrec-members.html | 7 +- docs/module-doc/classuserrec.html | 582 ++--- docs/module-doc/commands_8h-source.html | 52 +- docs/module-doc/commands_8h.html | 248 ++- docs/module-doc/connection_8h-source.html | 256 +-- docs/module-doc/connection_8h.html | 36 +- docs/module-doc/ctables_8h-source.html | 4 +- docs/module-doc/ctables_8h.html | 4 +- docs/module-doc/dns_8h-source.html | 4 +- docs/module-doc/dns_8h.html | 4 +- docs/module-doc/files.html | 5 +- docs/module-doc/functions.html | 107 +- docs/module-doc/functions_func.html | 104 +- docs/module-doc/functions_vars.html | 4 +- docs/module-doc/globals.html | 135 +- docs/module-doc/globals_defs.html | 6 +- docs/module-doc/globals_func.html | 31 +- docs/module-doc/globals_type.html | 18 +- docs/module-doc/globals_vars.html | 96 +- docs/module-doc/graph_legend.html | 4 +- docs/module-doc/hashcomp_8h-source.html | 97 + docs/module-doc/hashcomp_8h.html | 69 + docs/module-doc/hashcomp_8h__dep__incl.gif | Bin 0 -> 912 bytes docs/module-doc/hashcomp_8h__incl.gif | Bin 0 -> 1512 bytes docs/module-doc/hierarchy.html | 8 +- docs/module-doc/inherit__graph__0.gif | Bin 12716 -> 761 bytes docs/module-doc/inherit__graph__1.gif | Bin 304 -> 12716 bytes docs/module-doc/inherit__graph__2.gif | Bin 397 -> 304 bytes docs/module-doc/inherit__graph__3.gif | Bin 560 -> 397 bytes docs/module-doc/inherit__graph__4.gif | Bin 619 -> 560 bytes docs/module-doc/inherit__graph__5.gif | Bin 590 -> 619 bytes docs/module-doc/inherit__graph__6.gif | Bin 487 -> 590 bytes docs/module-doc/inherit__graph__7.gif | Bin 513 -> 487 bytes docs/module-doc/inherit__graph__8.gif | Bin 0 -> 513 bytes docs/module-doc/inherits.html | 25 +- docs/module-doc/main.html | 4 +- docs/module-doc/message_8h-source.html | 4 +- docs/module-doc/message_8h.html | 16 +- docs/module-doc/mode_8h-source.html | 4 +- docs/module-doc/mode_8h.html | 4 +- docs/module-doc/modules_8cpp-source.html | 1971 ++++++++--------- docs/module-doc/modules_8cpp.html | 698 +++--- docs/module-doc/modules_8cpp__incl.gif | Bin 42186 -> 40960 bytes docs/module-doc/modules_8h-source.html | 283 +-- docs/module-doc/modules_8h.html | 52 +- docs/module-doc/namespaceirc.html | 57 + docs/module-doc/namespacemembers.html | 19 + docs/module-doc/namespacemembers_type.html | 19 + docs/module-doc/namespacenspace.html | 4 +- docs/module-doc/namespaces.html | 5 +- docs/module-doc/namespacestd.html | 4 +- docs/module-doc/servers_8cpp-source.html | 77 +- docs/module-doc/servers_8cpp.html | 7 +- docs/module-doc/servers_8cpp__incl.gif | Bin 3329 -> 3785 bytes docs/module-doc/servers_8h-source.html | 4 +- docs/module-doc/servers_8h.html | 4 +- .../structInAddr__HashComp-members.html | 6 +- docs/module-doc/structInAddr__HashComp.html | 40 +- .../module-doc/structStrHashComp-members.html | 6 +- docs/module-doc/structStrHashComp.html | 39 +- .../structdns__ip4list-members.html | 4 +- docs/module-doc/structdns__ip4list.html | 4 +- ...tructirc_1_1irc__char__traits-members.html | 19 + .../structirc_1_1irc__char__traits.html | 267 +++ ...tirc_1_1irc__char__traits__coll__graph.gif | Bin 0 -> 1111 bytes ...c_1_1irc__char__traits__inherit__graph.gif | Bin 0 -> 1111 bytes ...ace_1_1hash_3_01in__addr_01_4-members.html | 6 +- ...e_1_1nspace_1_1hash_3_01in__addr_01_4.html | 23 +- ...space_1_1hash_3_01string_01_4-members.html | 6 +- ...ace_1_1nspace_1_1hash_3_01string_01_4.html | 25 +- docs/module-doc/tree.html | 35 +- docs/module-doc/users_8cpp-source.html | 510 ++--- docs/module-doc/users_8cpp.html | 9 +- docs/module-doc/users_8cpp__incl.gif | Bin 3872 -> 4396 bytes docs/module-doc/users_8h-source.html | 35 +- docs/module-doc/users_8h.html | 8 +- docs/module-doc/xline_8h-source.html | 4 +- docs/module-doc/xline_8h.html | 24 +- 219 files changed, 6820 insertions(+), 5901 deletions(-) create mode 100644 docs/man/man3/hashcomp.h.3 create mode 100644 docs/man/man3/irc.3 create mode 100644 docs/man/man3/irc_irc_char_traits.3 create mode 100644 docs/man/man3/std_char_traits.3 create mode 100644 docs/module-doc/classstd_1_1char__traits.html create mode 100644 docs/module-doc/classstd_1_1char__traits__inherit__graph.gif create mode 100644 docs/module-doc/hashcomp_8h-source.html create mode 100644 docs/module-doc/hashcomp_8h.html create mode 100644 docs/module-doc/hashcomp_8h__dep__incl.gif create mode 100644 docs/module-doc/hashcomp_8h__incl.gif create mode 100644 docs/module-doc/inherit__graph__8.gif create mode 100644 docs/module-doc/namespaceirc.html create mode 100644 docs/module-doc/namespacemembers.html create mode 100644 docs/module-doc/namespacemembers_type.html create mode 100644 docs/module-doc/structirc_1_1irc__char__traits-members.html create mode 100644 docs/module-doc/structirc_1_1irc__char__traits.html create mode 100644 docs/module-doc/structirc_1_1irc__char__traits__coll__graph.gif create mode 100644 docs/module-doc/structirc_1_1irc__char__traits__inherit__graph.gif diff --git a/docs/man/man3/Admin.3 b/docs/man/man3/Admin.3 index 60dde5bf6..e2001754e 100644 --- a/docs/man/man3/Admin.3 +++ b/docs/man/man3/Admin.3 @@ -1,4 +1,4 @@ -.TH "Admin" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Admin" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -43,10 +43,10 @@ Definition at line 123 of file modules.h. .PP .SS "Admin::Admin (std::string name, std::string email, std::string nick)" .PP -Definition at line 314 of file modules.cpp. +Definition at line 238 of file modules.cpp. .PP .nf -314 : Name(name), Email(email), Nick(nick) { }; +238 : Name(name), Email(email), Nick(nick) { }; .fi .SH "Member Data Documentation" .PP diff --git a/docs/man/man3/BanItem.3 b/docs/man/man3/BanItem.3 index 1d3720576..8fb296ba1 100644 --- a/docs/man/man3/BanItem.3 +++ b/docs/man/man3/BanItem.3 @@ -1,4 +1,4 @@ -.TH "BanItem" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "BanItem" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/ConfigReader.3 b/docs/man/man3/ConfigReader.3 index fe2042e0c..23b16d688 100644 --- a/docs/man/man3/ConfigReader.3 +++ b/docs/man/man3/ConfigReader.3 @@ -1,4 +1,4 @@ -.TH "ConfigReader" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ConfigReader" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -84,239 +84,239 @@ Allows reading of values from configuration files This class allows a module to It may either be instantiated with one parameter or none. Constructing the class using one parameter allows you to specify a path to your own configuration file, otherwise, inspircd.conf is read. .PP -Definition at line 1147 of file modules.h. +Definition at line 1150 of file modules.h. .SH "Constructor & Destructor Documentation" .PP .SS "ConfigReader::ConfigReader ()" .PP -Default constructor. This constructor initialises the ConfigReader class to read the inspircd.conf file as specified when running ./configure.Definition at line 870 of file modules.cpp. +Default constructor. This constructor initialises the ConfigReader class to read the inspircd.conf file as specified when running ./configure.Definition at line 799 of file modules.cpp. .PP References cache, CONF_FILE_NOT_FOUND, error, errorlog, and readerror. .PP .nf -871 { -872 this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out); -873 this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out); -874 this->readerror = LoadConf(CONFIG_FILE,this->cache,this->errorlog); -875 if (!this->readerror) -876 this->error = CONF_FILE_NOT_FOUND; -877 } +800 { +801 this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out); +802 this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out); +803 this->readerror = LoadConf(CONFIG_FILE,this->cache,this->errorlog); +804 if (!this->readerror) +805 this->error = CONF_FILE_NOT_FOUND; +806 } .fi .SS "ConfigReader::ConfigReader (std::string filename)" .PP -Overloaded constructor. This constructor initialises the ConfigReader class to read a user-specified config fileDefinition at line 889 of file modules.cpp. +Overloaded constructor. This constructor initialises the ConfigReader class to read a user-specified config fileDefinition at line 818 of file modules.cpp. .PP References cache, CONF_FILE_NOT_FOUND, error, errorlog, and readerror. .PP .nf -890 { -891 this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out); -892 this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out); -893 this->readerror = LoadConf(filename.c_str(),this->cache,this->errorlog); -894 if (!this->readerror) -895 this->error = CONF_FILE_NOT_FOUND; -896 }; +819 { +820 this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out); +821 this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out); +822 this->readerror = LoadConf(filename.c_str(),this->cache,this->errorlog); +823 if (!this->readerror) +824 this->error = CONF_FILE_NOT_FOUND; +825 }; .fi .SS "ConfigReader::~\fBConfigReader\fP ()" .PP -Default destructor. This method destroys the ConfigReader class.Definition at line 880 of file modules.cpp. +Default destructor. This method destroys the ConfigReader class.Definition at line 809 of file modules.cpp. .PP References cache, and errorlog. .PP .nf -881 { -882 if (this->cache) -883 delete this->cache; -884 if (this->errorlog) -885 delete this->errorlog; -886 } +810 { +811 if (this->cache) +812 delete this->cache; +813 if (this->errorlog) +814 delete this->errorlog; +815 } .fi .SH "Member Function Documentation" .PP .SS "void ConfigReader::DumpErrors (bool bail, \fBuserrec\fP * user)" .PP -Dumps the list of errors in a config file to an output location. If bail is true, then the program will abort. If bail is false and user points to a valid user record, the error report will be spooled to the given user by means of NOTICE. if bool is false AND user is false, the error report will be spooled to all opers by means of a NOTICE to all opers.Definition at line 967 of file modules.cpp. +Dumps the list of errors in a config file to an output location. If bail is true, then the program will abort. If bail is false and user points to a valid user record, the error report will be spooled to the given user by means of NOTICE. if bool is false AND user is false, the error report will be spooled to all opers by means of a NOTICE to all opers.Definition at line 896 of file modules.cpp. .PP References errorlog, connection::fd, and userrec::nick. .PP .nf -968 { -969 if (bail) -970 { -971 printf('There were errors in your configuration:\n%s',errorlog->str().c_str()); -972 exit(0); -973 } -974 else -975 { -976 char dataline[1024]; -977 if (user) -978 { -979 WriteServ(user->fd,'NOTICE %s :There were errors in the configuration file:',user->nick); -980 while (!errorlog->eof()) -981 { -982 errorlog->getline(dataline,1024); -983 WriteServ(user->fd,'NOTICE %s :%s',user->nick,dataline); -984 } -985 } -986 else -987 { -988 WriteOpers('There were errors in the configuration file:',user->nick); -989 while (!errorlog->eof()) -990 { -991 errorlog->getline(dataline,1024); -992 WriteOpers(dataline); -993 } -994 } -995 return; -996 } -997 } +897 { +898 if (bail) +899 { +900 printf('There were errors in your configuration:\n%s',errorlog->str().c_str()); +901 exit(0); +902 } +903 else +904 { +905 char dataline[1024]; +906 if (user) +907 { +908 WriteServ(user->fd,'NOTICE %s :There were errors in the configuration file:',user->nick); +909 while (!errorlog->eof()) +910 { +911 errorlog->getline(dataline,1024); +912 WriteServ(user->fd,'NOTICE %s :%s',user->nick,dataline); +913 } +914 } +915 else +916 { +917 WriteOpers('There were errors in the configuration file:',user->nick); +918 while (!errorlog->eof()) +919 { +920 errorlog->getline(dataline,1024); +921 WriteOpers(dataline); +922 } +923 } +924 return; +925 } +926 } .fi .SS "int ConfigReader::Enumerate (std::string tag)" .PP -Counts the number of times a given tag appears in the config file. This method counts the number of times a tag appears in a config file, for use where there are several tags of the same kind, e.g. with opers and connect types. It can be used with the index value of \fBConfigReader::ReadValue\fP to loop through all copies of a multiple instance tag.Definition at line 1000 of file modules.cpp. +Counts the number of times a given tag appears in the config file. This method counts the number of times a tag appears in a config file, for use where there are several tags of the same kind, e.g. with opers and connect types. It can be used with the index value of \fBConfigReader::ReadValue\fP to loop through all copies of a multiple instance tag.Definition at line 929 of file modules.cpp. .PP References cache. .PP .nf -1001 { -1002 return EnumConf(cache,tag.c_str()); -1003 } +930 { +931 return EnumConf(cache,tag.c_str()); +932 } .fi .SS "int ConfigReader::EnumerateValues (std::string tag, int index)" .PP -Returns the number of items within a tag. For example if the tag was then this function would return 2. Spaces and newlines both qualify as valid seperators between values.Definition at line 1005 of file modules.cpp. +Returns the number of items within a tag. For example if the tag was then this function would return 2. Spaces and newlines both qualify as valid seperators between values.Definition at line 934 of file modules.cpp. .PP References cache. .PP .nf -1006 { -1007 return EnumValues(cache, tag.c_str(), index); -1008 } +935 { +936 return EnumValues(cache, tag.c_str(), index); +937 } .fi .SS "long ConfigReader::GetError ()" .PP -Returns the last error to occur. Valid errors can be found by looking in \fBmodules.h\fP. Any nonzero value indicates an error condition. A call to \fBGetError()\fP resets the error flag back to 0.Definition at line 960 of file modules.cpp. +Returns the last error to occur. Valid errors can be found by looking in \fBmodules.h\fP. Any nonzero value indicates an error condition. A call to \fBGetError()\fP resets the error flag back to 0.Definition at line 889 of file modules.cpp. .PP References error. .PP .nf -961 { -962 long olderr = this->error; -963 this->error = 0; -964 return olderr; -965 } +890 { +891 long olderr = this->error; +892 this->error = 0; +893 return olderr; +894 } .fi .SS "bool ConfigReader::ReadFlag (std::string tag, std::string name, int index)" .PP -Retrieves a boolean value from the config file. This method retrieves a boolean value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve. The values '1', 'yes' and 'true' in the config file count as true to ReadFlag, and any other value counts as false.Definition at line 914 of file modules.cpp. +Retrieves a boolean value from the config file. This method retrieves a boolean value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve. The values '1', 'yes' and 'true' in the config file count as true to ReadFlag, and any other value counts as false.Definition at line 843 of file modules.cpp. .PP References cache, CONF_VALUE_NOT_FOUND, and error. .PP .nf -915 { -916 char val[MAXBUF]; -917 char t[MAXBUF]; -918 char n[MAXBUF]; -919 strlcpy(t,tag.c_str(),MAXBUF); -920 strlcpy(n,name.c_str(),MAXBUF); -921 int res = ReadConf(cache,t,n,index,val); -922 if (!res) -923 { -924 this->error = CONF_VALUE_NOT_FOUND; -925 return false; -926 } -927 std::string s = val; -928 return ((s == 'yes') || (s == 'YES') || (s == 'true') || (s == 'TRUE') || (s == '1')); -929 } +844 { +845 char val[MAXBUF]; +846 char t[MAXBUF]; +847 char n[MAXBUF]; +848 strlcpy(t,tag.c_str(),MAXBUF); +849 strlcpy(n,name.c_str(),MAXBUF); +850 int res = ReadConf(cache,t,n,index,val); +851 if (!res) +852 { +853 this->error = CONF_VALUE_NOT_FOUND; +854 return false; +855 } +856 std::string s = val; +857 return ((s == 'yes') || (s == 'YES') || (s == 'true') || (s == 'TRUE') || (s == '1')); +858 } .fi .SS "long ConfigReader::ReadInteger (std::string tag, std::string name, int index, bool needs_unsigned)" .PP -Retrieves an integer value from the config file. This method retrieves an integer value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve. Any invalid integer values in the tag will cause the objects error value to be set, and any call to \fBGetError()\fP will return CONF_INVALID_NUMBER to be returned. needs_unsigned is set if the number must be unsigned. If a signed number is placed into a tag which is specified unsigned, 0 will be returned and \fBGetError()\fP will return CONF_NOT_UNSIGNEDDefinition at line 931 of file modules.cpp. +Retrieves an integer value from the config file. This method retrieves an integer value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve. Any invalid integer values in the tag will cause the objects error value to be set, and any call to \fBGetError()\fP will return CONF_INVALID_NUMBER to be returned. needs_unsigned is set if the number must be unsigned. If a signed number is placed into a tag which is specified unsigned, 0 will be returned and \fBGetError()\fP will return CONF_NOT_UNSIGNEDDefinition at line 860 of file modules.cpp. .PP References cache, CONF_NOT_A_NUMBER, CONF_NOT_UNSIGNED, CONF_VALUE_NOT_FOUND, and error. .PP .nf -932 { -933 char val[MAXBUF]; -934 char t[MAXBUF]; -935 char n[MAXBUF]; -936 strlcpy(t,tag.c_str(),MAXBUF); -937 strlcpy(n,name.c_str(),MAXBUF); -938 int res = ReadConf(cache,t,n,index,val); -939 if (!res) -940 { -941 this->error = CONF_VALUE_NOT_FOUND; -942 return 0; -943 } -944 for (int i = 0; i < strlen(val); i++) -945 { -946 if (!isdigit(val[i])) -947 { -948 this->error = CONF_NOT_A_NUMBER; -949 return 0; -950 } -951 } -952 if ((needs_unsigned) && (atoi(val)<0)) -953 { -954 this->error = CONF_NOT_UNSIGNED; -955 return 0; -956 } -957 return atoi(val); -958 } +861 { +862 char val[MAXBUF]; +863 char t[MAXBUF]; +864 char n[MAXBUF]; +865 strlcpy(t,tag.c_str(),MAXBUF); +866 strlcpy(n,name.c_str(),MAXBUF); +867 int res = ReadConf(cache,t,n,index,val); +868 if (!res) +869 { +870 this->error = CONF_VALUE_NOT_FOUND; +871 return 0; +872 } +873 for (int i = 0; i < strlen(val); i++) +874 { +875 if (!isdigit(val[i])) +876 { +877 this->error = CONF_NOT_A_NUMBER; +878 return 0; +879 } +880 } +881 if ((needs_unsigned) && (atoi(val)<0)) +882 { +883 this->error = CONF_NOT_UNSIGNED; +884 return 0; +885 } +886 return atoi(val); +887 } .fi .SS "std::string ConfigReader::ReadValue (std::string tag, std::string name, int index)" .PP -Retrieves a value from the config file. This method retrieves a value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve.Definition at line 898 of file modules.cpp. +Retrieves a value from the config file. This method retrieves a value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve.Definition at line 827 of file modules.cpp. .PP References cache, CONF_VALUE_NOT_FOUND, and error. .PP .nf -899 { -900 char val[MAXBUF]; -901 char t[MAXBUF]; -902 char n[MAXBUF]; -903 strlcpy(t,tag.c_str(),MAXBUF); -904 strlcpy(n,name.c_str(),MAXBUF); -905 int res = ReadConf(cache,t,n,index,val); -906 if (!res) -907 { -908 this->error = CONF_VALUE_NOT_FOUND; -909 return ''; -910 } -911 return val; -912 } +828 { +829 char val[MAXBUF]; +830 char t[MAXBUF]; +831 char n[MAXBUF]; +832 strlcpy(t,tag.c_str(),MAXBUF); +833 strlcpy(n,name.c_str(),MAXBUF); +834 int res = ReadConf(cache,t,n,index,val); +835 if (!res) +836 { +837 this->error = CONF_VALUE_NOT_FOUND; +838 return ''; +839 } +840 return val; +841 } .fi .SS "bool ConfigReader::Verify ()" .PP -Returns true if a config file is valid. This method is partially implemented and will only return false if the config file does not exist or could not be opened.Definition at line 1010 of file modules.cpp. +Returns true if a config file is valid. This method is partially implemented and will only return false if the config file does not exist or could not be opened.Definition at line 939 of file modules.cpp. .PP References readerror. .PP .nf -1011 { -1012 return this->readerror; -1013 } +940 { +941 return this->readerror; +942 } .fi .SH "Member Data Documentation" .PP .SS "std::stringstream* \fBConfigReader::cache\fP\fC [protected]\fP" .PP -The contents of the configuration file This protected member should never be accessed by a module (and cannot be accessed unless the core is changed). It will contain a pointer to the configuration file data with unneeded data (such as comments) stripped from it.Definition at line 1155 of file modules.h. +The contents of the configuration file This protected member should never be accessed by a module (and cannot be accessed unless the core is changed). It will contain a pointer to the configuration file data with unneeded data (such as comments) stripped from it.Definition at line 1158 of file modules.h. .PP Referenced by ConfigReader(), Enumerate(), EnumerateValues(), ReadFlag(), ReadInteger(), ReadValue(), and ~ConfigReader(). .SS "long \fBConfigReader::error\fP\fC [protected]\fP" .PP -Definition at line 1160 of file modules.h. +Definition at line 1163 of file modules.h. .PP Referenced by ConfigReader(), GetError(), ReadFlag(), ReadInteger(), and ReadValue(). .SS "std::stringstream* \fBConfigReader::errorlog\fP\fC [protected]\fP" .PP -Definition at line 1156 of file modules.h. +Definition at line 1159 of file modules.h. .PP Referenced by ConfigReader(), DumpErrors(), and ~ConfigReader(). .SS "bool \fBConfigReader::readerror\fP\fC [protected]\fP" .PP -Used to store errors. Definition at line 1159 of file modules.h. +Used to store errors. Definition at line 1162 of file modules.h. .PP Referenced by ConfigReader(), and Verify(). diff --git a/docs/man/man3/ConnectClass.3 b/docs/man/man3/ConnectClass.3 index 3a7c5d1f5..c71050d3c 100644 --- a/docs/man/man3/ConnectClass.3 +++ b/docs/man/man3/ConnectClass.3 @@ -1,4 +1,4 @@ -.TH "ConnectClass" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ConnectClass" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/DNS.3 b/docs/man/man3/DNS.3 index 7af2610b6..f70f13979 100644 --- a/docs/man/man3/DNS.3 +++ b/docs/man/man3/DNS.3 @@ -1,4 +1,4 @@ -.TH "DNS" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "DNS" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/ELine.3 b/docs/man/man3/ELine.3 index dd20df94f..cf223c4a7 100644 --- a/docs/man/man3/ELine.3 +++ b/docs/man/man3/ELine.3 @@ -1,4 +1,4 @@ -.TH "ELine" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ELine" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/Event.3 b/docs/man/man3/Event.3 index dabb4c1d4..249e9bcba 100644 --- a/docs/man/man3/Event.3 +++ b/docs/man/man3/Event.3 @@ -1,4 +1,4 @@ -.TH "Event" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Event" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -63,59 +63,59 @@ Definition at line 194 of file modules.h. .PP .SS "Event::Event (char * anydata, \fBModule\fP * src, std::string eventid)" .PP -Create a new Event. Definition at line 345 of file modules.cpp. +Create a new Event. Definition at line 269 of file modules.cpp. .PP .nf -345 : data(anydata), source(src), id(eventid) { }; +269 : data(anydata), source(src), id(eventid) { }; .fi .SH "Member Function Documentation" .PP .SS "char * Event::GetData ()" .PP -Get the Event data. Definition at line 347 of file modules.cpp. +Get the Event data. Definition at line 271 of file modules.cpp. .PP References data. .PP .nf -348 { -349 return this->data; -350 } +272 { +273 return this->data; +274 } .fi .SS "std::string Event::GetEventID ()" .PP -Get the event ID. Use this to determine the event type for safe casting of the data Definition at line 363 of file modules.cpp. +Get the event ID. Use this to determine the event type for safe casting of the data Definition at line 287 of file modules.cpp. .PP References id. .PP .nf -364 { -365 return this->id; -366 } +288 { +289 return this->id; +290 } .fi .SS "\fBModule\fP * Event::GetSource ()" .PP -Get the event Source. Definition at line 352 of file modules.cpp. +Get the event Source. Definition at line 276 of file modules.cpp. .PP References source. .PP .nf -353 { -354 return this->source; -355 } +277 { +278 return this->source; +279 } .fi .SS "char * Event::Send ()\fC [virtual]\fP" .PP Send the Event. The return result of an \fBEvent::Send()\fP will always be NULL as no replies are expected. Implements \fBModuleMessage\fP. .PP -Definition at line 357 of file modules.cpp. +Definition at line 281 of file modules.cpp. .PP References FOREACH_MOD. .PP .nf -358 { -359 FOREACH_MOD OnEvent(this); -360 return NULL; -361 } +282 { +283 FOREACH_MOD OnEvent(this); +284 return NULL; +285 } .fi .SH "Member Data Documentation" .PP diff --git a/docs/man/man3/ExemptItem.3 b/docs/man/man3/ExemptItem.3 index bd9e59b1e..b30ba6601 100644 --- a/docs/man/man3/ExemptItem.3 +++ b/docs/man/man3/ExemptItem.3 @@ -1,4 +1,4 @@ -.TH "ExemptItem" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ExemptItem" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/ExtMode.3 b/docs/man/man3/ExtMode.3 index cb5210120..353b17ce3 100644 --- a/docs/man/man3/ExtMode.3 +++ b/docs/man/man3/ExtMode.3 @@ -1,4 +1,4 @@ -.TH "ExtMode" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ExtMode" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -41,41 +41,41 @@ Inherits \fBclassbase\fP. .PP .SS "ExtMode::ExtMode (char mc, int ty, bool oper, int p_on, int p_off)\fC [inline]\fP" .PP -Definition at line 212 of file modules.cpp. +Definition at line 136 of file modules.cpp. .PP References modechar, needsoper, params_when_off, params_when_on, and type. .PP .nf -212 : modechar(mc), type(ty), needsoper(oper), params_when_on(p_on), params_when_off(p_off) { }; +136 : modechar(mc), type(ty), needsoper(oper), params_when_on(p_on), params_when_off(p_off) { }; .fi .SH "Member Data Documentation" .PP .SS "bool \fBExtMode::list\fP" .PP -Definition at line 211 of file modules.cpp. +Definition at line 135 of file modules.cpp. .SS "char \fBExtMode::modechar\fP" .PP -Definition at line 206 of file modules.cpp. +Definition at line 130 of file modules.cpp. .PP Referenced by ExtMode(). .SS "bool \fBExtMode::needsoper\fP" .PP -Definition at line 210 of file modules.cpp. +Definition at line 134 of file modules.cpp. .PP Referenced by ExtMode(). .SS "int \fBExtMode::params_when_off\fP" .PP -Definition at line 209 of file modules.cpp. +Definition at line 133 of file modules.cpp. .PP Referenced by ExtMode(). .SS "int \fBExtMode::params_when_on\fP" .PP -Definition at line 208 of file modules.cpp. +Definition at line 132 of file modules.cpp. .PP Referenced by ExtMode(). .SS "int \fBExtMode::type\fP" .PP -Definition at line 207 of file modules.cpp. +Definition at line 131 of file modules.cpp. .PP Referenced by ExtMode(). diff --git a/docs/man/man3/Extensible.3 b/docs/man/man3/Extensible.3 index 530de1651..46a699705 100644 --- a/docs/man/man3/Extensible.3 +++ b/docs/man/man3/Extensible.3 @@ -1,4 +1,4 @@ -.TH "Extensible" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Extensible" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/FileReader.3 b/docs/man/man3/FileReader.3 index d22ca3912..1df4ff063 100644 --- a/docs/man/man3/FileReader.3 +++ b/docs/man/man3/FileReader.3 @@ -1,4 +1,4 @@ -.TH "FileReader" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "FileReader" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -57,100 +57,100 @@ Caches a text file into memory and can be used to retrieve lines from it. This class contains methods for read-only manipulation of a text file in memory. Either use the constructor type with one parameter to load a file into memory at construction, or use the LoadFile method to load a file. .PP -Definition at line 1236 of file modules.h. +Definition at line 1239 of file modules.h. .SH "Constructor & Destructor Documentation" .PP .SS "FileReader::FileReader ()" .PP -Default constructor. This method does not load any file into memory, you must use the LoadFile method after constructing the class this way.Definition at line 1023 of file modules.cpp. +Default constructor. This method does not load any file into memory, you must use the LoadFile method after constructing the class this way.Definition at line 952 of file modules.cpp. .PP .nf -1024 { -1025 } +953 { +954 } .fi .SS "FileReader::FileReader (std::string filename)" .PP -Secondary constructor. This method initialises the class with a file loaded into it ready for GetLine and and other methods to be called. If the file could not be loaded, \fBFileReader::FileSize\fP returns 0.Definition at line 1016 of file modules.cpp. +Secondary constructor. This method initialises the class with a file loaded into it ready for GetLine and and other methods to be called. If the file could not be loaded, \fBFileReader::FileSize\fP returns 0.Definition at line 945 of file modules.cpp. .PP References fc, and file_cache. .PP .nf -1017 { -1018 file_cache c; -1019 readfile(c,filename.c_str()); -1020 this->fc = c; -1021 } +946 { +947 file_cache c; +948 readfile(c,filename.c_str()); +949 this->fc = c; +950 } .fi .SS "FileReader::~\fBFileReader\fP ()" .PP -Default destructor. This deletes the memory allocated to the file.Definition at line 1035 of file modules.cpp. +Default destructor. This deletes the memory allocated to the file.Definition at line 964 of file modules.cpp. .PP .nf -1036 { -1037 } +965 { +966 } .fi .SH "Member Function Documentation" .PP .SS "bool FileReader::Exists ()" .PP -Returns true if the file exists This function will return false if the file could not be opened. Definition at line 1039 of file modules.cpp. +Returns true if the file exists This function will return false if the file could not be opened. Definition at line 968 of file modules.cpp. .PP References fc. .PP .nf -1040 { -1041 if (fc.size() == 0) -1042 { -1043 return(false); -1044 } -1045 else -1046 { -1047 return(true); -1048 } -1049 } +969 { +970 if (fc.size() == 0) +971 { +972 return(false); +973 } +974 else +975 { +976 return(true); +977 } +978 } .fi .SS "int FileReader::FileSize ()" .PP -Returns the size of the file in lines. This method returns the number of lines in the read file. If it is 0, no lines have been read into memory, either because the file is empty or it does not exist, or cannot be opened due to permission problems.Definition at line 1058 of file modules.cpp. +Returns the size of the file in lines. This method returns the number of lines in the read file. If it is 0, no lines have been read into memory, either because the file is empty or it does not exist, or cannot be opened due to permission problems.Definition at line 987 of file modules.cpp. .PP References fc. .PP .nf -1059 { -1060 return fc.size(); -1061 } +988 { +989 return fc.size(); +990 } .fi .SS "std::string FileReader::GetLine (int x)" .PP -Retrieve one line from the file. This method retrieves one line from the text file. If an empty non-NULL string is returned, the index was out of bounds, or the line had no data on it.Definition at line 1051 of file modules.cpp. +Retrieve one line from the file. This method retrieves one line from the text file. If an empty non-NULL string is returned, the index was out of bounds, or the line had no data on it.Definition at line 980 of file modules.cpp. .PP References fc. .PP .nf -1052 { -1053 if ((x<0) || (x>fc.size())) -1054 return ''; -1055 return fc[x]; -1056 } +981 { +982 if ((x<0) || (x>fc.size())) +983 return ''; +984 return fc[x]; +985 } .fi .SS "void FileReader::LoadFile (std::string filename)" .PP -Used to load a file. This method loads a file into the class ready for GetLine and and other methods to be called. If the file could not be loaded, \fBFileReader::FileSize\fP returns 0.Definition at line 1027 of file modules.cpp. +Used to load a file. This method loads a file into the class ready for GetLine and and other methods to be called. If the file could not be loaded, \fBFileReader::FileSize\fP returns 0.Definition at line 956 of file modules.cpp. .PP References fc, and file_cache. .PP .nf -1028 { -1029 file_cache c; -1030 readfile(c,filename.c_str()); -1031 this->fc = c; -1032 } +957 { +958 file_cache c; +959 readfile(c,filename.c_str()); +960 this->fc = c; +961 } .fi .SH "Member Data Documentation" .PP .SS "\fBfile_cache\fP \fBFileReader::fc\fP\fC [private]\fP" .PP -Definition at line 1238 of file modules.h. +Definition at line 1241 of file modules.h. .PP Referenced by Exists(), FileReader(), FileSize(), GetLine(), and LoadFile(). diff --git a/docs/man/man3/GLine.3 b/docs/man/man3/GLine.3 index 720e44cf2..e781013fa 100644 --- a/docs/man/man3/GLine.3 +++ b/docs/man/man3/GLine.3 @@ -1,4 +1,4 @@ -.TH "GLine" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "GLine" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/HostItem.3 b/docs/man/man3/HostItem.3 index eeab03ac9..37b11a714 100644 --- a/docs/man/man3/HostItem.3 +++ b/docs/man/man3/HostItem.3 @@ -1,4 +1,4 @@ -.TH "HostItem" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "HostItem" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/InAddr_HashComp.3 b/docs/man/man3/InAddr_HashComp.3 index 284f16016..38bfe4075 100644 --- a/docs/man/man3/InAddr_HashComp.3 +++ b/docs/man/man3/InAddr_HashComp.3 @@ -1,36 +1,35 @@ -.TH "InAddr_HashComp" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "InAddr_HashComp" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME -InAddr_HashComp \- +InAddr_HashComp \- This class returns true if two in_addr structs match. + +.PP .SH SYNOPSIS .br .PP +\fC#include \fP +.PP .SS "Public Member Functions" .in +1c .ti -1c .RI "bool \fBoperator()\fP (const in_addr &s1, const in_addr &s2) const" .br +.RI "\fIThe operator () does the actual comparison in hash_map. \fP" .in -1c -.SH "Member Function Documentation" +.SH "Detailed Description" .PP -.SS "bool InAddr_HashComp::operator() (const in_addr & s1, const in_addr & s2) const\fC [inline]\fP" +This class returns true if two in_addr structs match. + +Checking is done by copying both into a size_t then doing a numeric comparison of the two. .PP -Definition at line 171 of file modules.cpp. +Definition at line 71 of file hashcomp.h. +.SH "Member Function Documentation" +.PP +.SS "bool InAddr_HashComp::operator() (const in_addr & s1, const in_addr & s2) const" .PP -.nf -172 { -173 size_t q; -174 size_t p; -175 -176 memcpy(&q,&s1,sizeof(size_t)); -177 memcpy(&p,&s2,sizeof(size_t)); -178 -179 return (q == p); -180 } -.fi - +The operator () does the actual comparison in hash_map. .SH "Author" .PP diff --git a/docs/man/man3/InviteItem.3 b/docs/man/man3/InviteItem.3 index 301a0d350..50608345f 100644 --- a/docs/man/man3/InviteItem.3 +++ b/docs/man/man3/InviteItem.3 @@ -1,4 +1,4 @@ -.TH "InviteItem" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "InviteItem" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/Invited.3 b/docs/man/man3/Invited.3 index 3040a4902..e09d4d9b5 100644 --- a/docs/man/man3/Invited.3 +++ b/docs/man/man3/Invited.3 @@ -1,4 +1,4 @@ -.TH "Invited" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Invited" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/KLine.3 b/docs/man/man3/KLine.3 index 4281b3d43..ed73e3e15 100644 --- a/docs/man/man3/KLine.3 +++ b/docs/man/man3/KLine.3 @@ -1,4 +1,4 @@ -.TH "KLine" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "KLine" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/ModeParameter.3 b/docs/man/man3/ModeParameter.3 index 1b6cfe6ed..2a85198db 100644 --- a/docs/man/man3/ModeParameter.3 +++ b/docs/man/man3/ModeParameter.3 @@ -1,4 +1,4 @@ -.TH "ModeParameter" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ModeParameter" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/Module.3 b/docs/man/man3/Module.3 index 49fa49d4b..b33e933cd 100644 --- a/docs/man/man3/Module.3 +++ b/docs/man/man3/Module.3 @@ -1,4 +1,4 @@ -.TH "Module" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Module" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -251,35 +251,35 @@ Definition at line 236 of file modules.h. .PP .SS "Module::Module ()" .PP -Default constructor creates a module class. Definition at line 370 of file modules.cpp. +Default constructor creates a module class. Definition at line 294 of file modules.cpp. .PP .nf -370 { } +294 { } .fi .SS "Module::~\fBModule\fP ()\fC [virtual]\fP" .PP -Default destructor destroys a module class. Definition at line 371 of file modules.cpp. +Default destructor destroys a module class. Definition at line 295 of file modules.cpp. .PP .nf -371 { } +295 { } .fi .SH "Member Function Documentation" .PP .SS "\fBVersion\fP Module::GetVersion ()\fC [virtual]\fP" .PP -Returns the version number of a Module. The method should return a \fBVersion\fP object with its version information assigned via \fBVersion::Version\fPDefinition at line 383 of file modules.cpp. +Returns the version number of a Module. The method should return a \fBVersion\fP object with its version information assigned via \fBVersion::Version\fPDefinition at line 307 of file modules.cpp. .PP References VF_VENDOR. .PP .nf -383 { return Version(1,0,0,0,VF_VENDOR); } +307 { return Version(1,0,0,0,VF_VENDOR); } .fi .SS "void Module::On005Numeric (std::string & output)\fC [virtual]\fP" .PP -Called when a 005 numeric is about to be output. The module should modify the 005 numeric if needed to indicate its features.Definition at line 395 of file modules.cpp. +Called when a 005 numeric is about to be output. The module should modify the 005 numeric if needed to indicate its features.Definition at line 319 of file modules.cpp. .PP .nf -395 { }; +319 { }; .fi .SS "int Module::OnAccessCheck (\fBuserrec\fP * source, \fBuserrec\fP * dest, \fBchanrec\fP * channel, int access_type)\fC [virtual]\fP" .PP @@ -307,312 +307,312 @@ Called before an action which requires a channel privilage check. This function .br .br - Upon returning from your function you must return either ACR_DEFAULT, to indicate the module wishes to do nothing, or ACR_DENY where approprate to deny the action, and ACR_ALLOW where appropriate to allow the action. Please note that in the case of some access checks (such as AC_GENERAL_MODE) access may be denied 'upstream' causing other checks such as AC_DEOP to not be reached. Be very careful with use of the AC_GENERAL_MODE type, as it may inadvertently override the behaviour of other modules. When the access_type is AC_GENERAL_MODE, the destination of the mode will be NULL (as it has not yet been determined).Definition at line 392 of file modules.cpp. + Upon returning from your function you must return either ACR_DEFAULT, to indicate the module wishes to do nothing, or ACR_DENY where approprate to deny the action, and ACR_ALLOW where appropriate to allow the action. Please note that in the case of some access checks (such as AC_GENERAL_MODE) access may be denied 'upstream' causing other checks such as AC_DEOP to not be reached. Be very careful with use of the AC_GENERAL_MODE type, as it may inadvertently override the behaviour of other modules. When the access_type is AC_GENERAL_MODE, the destination of the mode will be NULL (as it has not yet been determined).Definition at line 316 of file modules.cpp. .PP References ACR_DEFAULT. .PP .nf -392 { return ACR_DEFAULT; }; +316 { return ACR_DEFAULT; }; .fi .SS "int Module::OnAddBan (\fBuserrec\fP * source, \fBchanrec\fP * channel, std::string banmask)\fC [virtual]\fP" .PP -Called whenever a ban is added to a channel's list. Return a non-zero value to 'eat' the mode change and prevent the ban from being added.Definition at line 420 of file modules.cpp. +Called whenever a ban is added to a channel's list. Return a non-zero value to 'eat' the mode change and prevent the ban from being added.Definition at line 344 of file modules.cpp. .PP .nf -420 { return 0; }; +344 { return 0; }; .fi .SS "void Module::OnBackgroundTimer (time_t curtime)\fC [virtual]\fP" .PP -Called once every five seconds for background processing. This timer can be used to control timed features. Its period is not accurate enough to be used as a clock, but it is gauranteed to be called at least once in any five second period, directly from the main loop of the server.Definition at line 398 of file modules.cpp. +Called once every five seconds for background processing. This timer can be used to control timed features. Its period is not accurate enough to be used as a clock, but it is gauranteed to be called at least once in any five second period, directly from the main loop of the server.Definition at line 322 of file modules.cpp. .PP .nf -398 { }; +322 { }; .fi .SS "int Module::OnChangeLocalUserGECOS (\fBuserrec\fP * user, std::string newhost)\fC [virtual]\fP" .PP -Called whenever a change of a local users GECOS (fullname field) is attempted. return 1 to deny the name change, or 0 to allow it.Definition at line 412 of file modules.cpp. +Called whenever a change of a local users GECOS (fullname field) is attempted. return 1 to deny the name change, or 0 to allow it.Definition at line 336 of file modules.cpp. .PP .nf -412 { return 0; }; +336 { return 0; }; .fi .SS "int Module::OnChangeLocalUserHost (\fBuserrec\fP * user, std::string newhost)\fC [virtual]\fP" .PP -Called whenever a change of a local users displayed host is attempted. Return 1 to deny the host change, or 0 to allow it.Definition at line 411 of file modules.cpp. +Called whenever a change of a local users displayed host is attempted. Return 1 to deny the host change, or 0 to allow it.Definition at line 335 of file modules.cpp. .PP .nf -411 { return 0; }; +335 { return 0; }; .fi .SS "\fBstring_list\fP Module::OnChannelSync (\fBchanrec\fP * chan)\fC [virtual]\fP" .PP -Called during a netburst to sync channel data. This is called during the netburst on a per-channel basis. You should use this call to up any special channel-related things which are implemented by your module, e.g. sending listmodes. You may return multiple commands in the string_list.Definition at line 394 of file modules.cpp. +Called during a netburst to sync channel data. This is called during the netburst on a per-channel basis. You should use this call to up any special channel-related things which are implemented by your module, e.g. sending listmodes. You may return multiple commands in the string_list.Definition at line 318 of file modules.cpp. .PP References string_list. .PP .nf -394 { string_list empty; return empty; } +318 { string_list empty; return empty; } .fi .SS "int Module::OnCheckBan (\fBuserrec\fP * user, \fBchanrec\fP * chan)\fC [virtual]\fP" .PP -Called whenever a user joins a channel, to determine if banlist checks should go ahead or not. This method will always be called for each join, wether or not the user actually matches a channel ban, and determines the outcome of an if statement around the whole section of ban checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event. Definition at line 409 of file modules.cpp. +Called whenever a user joins a channel, to determine if banlist checks should go ahead or not. This method will always be called for each join, wether or not the user actually matches a channel ban, and determines the outcome of an if statement around the whole section of ban checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event. Definition at line 333 of file modules.cpp. .PP .nf -409 { return 0; }; +333 { return 0; }; .fi .SS "int Module::OnCheckInvite (\fBuserrec\fP * user, \fBchanrec\fP * chan)\fC [virtual]\fP" .PP -Called whenever a user joins a channel, to determine if invite checks should go ahead or not. This method will always be called for each join, wether or not the channel is actually +i, and determines the outcome of an if statement around the whole section of invite checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event.Definition at line 406 of file modules.cpp. +Called whenever a user joins a channel, to determine if invite checks should go ahead or not. This method will always be called for each join, wether or not the channel is actually +i, and determines the outcome of an if statement around the whole section of invite checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event.Definition at line 330 of file modules.cpp. .PP .nf -406 { return 0; }; +330 { return 0; }; .fi .SS "int Module::OnCheckKey (\fBuserrec\fP * user, \fBchanrec\fP * chan, std::string keygiven)\fC [virtual]\fP" .PP -Called whenever a user joins a channel, to determine if key checks should go ahead or not. This method will always be called for each join, wether or not the channel is actually +k, and determines the outcome of an if statement around the whole section of key checking code. if the user specified no key, the keygiven string will be a valid but empty value. return 1 to explicitly allow the join to go ahead or 0 to ignore the event. Definition at line 407 of file modules.cpp. +Called whenever a user joins a channel, to determine if key checks should go ahead or not. This method will always be called for each join, wether or not the channel is actually +k, and determines the outcome of an if statement around the whole section of key checking code. if the user specified no key, the keygiven string will be a valid but empty value. return 1 to explicitly allow the join to go ahead or 0 to ignore the event. Definition at line 331 of file modules.cpp. .PP .nf -407 { return 0; }; +331 { return 0; }; .fi .SS "int Module::OnCheckLimit (\fBuserrec\fP * user, \fBchanrec\fP * chan)\fC [virtual]\fP" .PP -Called whenever a user joins a channel, to determine if channel limit checks should go ahead or not. This method will always be called for each join, wether or not the channel is actually +l, and determines the outcome of an if statement around the whole section of channel limit checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event. Definition at line 408 of file modules.cpp. +Called whenever a user joins a channel, to determine if channel limit checks should go ahead or not. This method will always be called for each join, wether or not the channel is actually +l, and determines the outcome of an if statement around the whole section of channel limit checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event. Definition at line 332 of file modules.cpp. .PP .nf -408 { return 0; }; +332 { return 0; }; .fi .SS "bool Module::OnCheckReady (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called to check if a user who is connecting can now be allowed to register If any modules return false for this function, the user is held in the waiting state until all modules return true. For example a module which implements ident lookups will continue to return false for a user until their ident lookup is completed. Note that the registration timeout for a user overrides these checks, if the registration timeout is reached, the user is disconnected even if modules report that the user is not ready to connect.Definition at line 401 of file modules.cpp. +Called to check if a user who is connecting can now be allowed to register If any modules return false for this function, the user is held in the waiting state until all modules return true. For example a module which implements ident lookups will continue to return false for a user until their ident lookup is completed. Note that the registration timeout for a user overrides these checks, if the registration timeout is reached, the user is disconnected even if modules report that the user is not ready to connect.Definition at line 325 of file modules.cpp. .PP .nf -401 { return true; }; +325 { return true; }; .fi .SS "int Module::OnDelBan (\fBuserrec\fP * source, \fBchanrec\fP * channel, std::string banmask)\fC [virtual]\fP" .PP -Called whenever a ban is removed from a channel's list. Return a non-zero value to 'eat' the mode change and prevent the ban from being removed.Definition at line 421 of file modules.cpp. +Called whenever a ban is removed from a channel's list. Return a non-zero value to 'eat' the mode change and prevent the ban from being removed.Definition at line 345 of file modules.cpp. .PP .nf -421 { return 0; }; +345 { return 0; }; .fi .SS "void Module::OnEvent (\fBEvent\fP * event)\fC [virtual]\fP" .PP -Called whenever an \fBEvent\fP class is sent to all module by another module. Please see the documentation of \fBEvent::Send()\fP for further information. The \fBEvent\fP sent can always be assumed to be non-NULL, you should *always* check the value of \fBEvent::GetEventID()\fP before doing anything to the event data, and you should *not* change the event data in any way!Definition at line 415 of file modules.cpp. +Called whenever an \fBEvent\fP class is sent to all module by another module. Please see the documentation of \fBEvent::Send()\fP for further information. The \fBEvent\fP sent can always be assumed to be non-NULL, you should *always* check the value of \fBEvent::GetEventID()\fP before doing anything to the event data, and you should *not* change the event data in any way!Definition at line 339 of file modules.cpp. .PP .nf -415 { return; }; +339 { return; }; .fi .SS "int Module::OnExtendedMode (\fBuserrec\fP * user, void * target, char modechar, int type, bool mode_on, \fBstring_list\fP & params)\fC [virtual]\fP" .PP -Called whenever an extended mode is to be processed. The type parameter is MT_SERVER, MT_CLIENT or MT_CHANNEL, dependent on where the mode is being changed. mode_on is set when the mode is being set, in which case params contains a list of parameters for the mode as strings. If mode_on is false, the mode is being removed, and parameters may contain the parameters for the mode, dependent on wether they were defined when a mode handler was set up with \fBServer::AddExtendedMode\fP If the mode is a channel mode, target is a chanrec*, and if it is a user mode, target is a userrec*. You must cast this value yourself to make use of it.Definition at line 382 of file modules.cpp. +Called whenever an extended mode is to be processed. The type parameter is MT_SERVER, MT_CLIENT or MT_CHANNEL, dependent on where the mode is being changed. mode_on is set when the mode is being set, in which case params contains a list of parameters for the mode as strings. If mode_on is false, the mode is being removed, and parameters may contain the parameters for the mode, dependent on wether they were defined when a mode handler was set up with \fBServer::AddExtendedMode\fP If the mode is a channel mode, target is a chanrec*, and if it is a user mode, target is a userrec*. You must cast this value yourself to make use of it.Definition at line 306 of file modules.cpp. .PP .nf -382 { return false; } +306 { return false; } .fi .SS "void Module::OnGlobalConnect (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called whenever a user connects, anywhere on the network. This event is informational only. You should not change any user information in this event. To do so, use the OnUserConnect method to change the state of local users.Definition at line 419 of file modules.cpp. +Called whenever a user connects, anywhere on the network. This event is informational only. You should not change any user information in this event. To do so, use the OnUserConnect method to change the state of local users.Definition at line 343 of file modules.cpp. .PP .nf -419 { }; +343 { }; .fi .SS "void Module::OnGlobalOper (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called whenever a user is given usermode +o, anywhere on the network. You cannot override this and prevent it from happening as it is already happened and such a task must be performed by another server. You can however bounce modes by sending servermodes out to reverse mode changes.Definition at line 418 of file modules.cpp. +Called whenever a user is given usermode +o, anywhere on the network. You cannot override this and prevent it from happening as it is already happened and such a task must be performed by another server. You can however bounce modes by sending servermodes out to reverse mode changes.Definition at line 342 of file modules.cpp. .PP .nf -418 { }; +342 { }; .fi .SS "void Module::OnInfo (\fBuserrec\fP * user)\fC [virtual]\fP" .PP Called whenever a user types /INFO. The userrec will contain the information of the user who typed the command. Modules may use this method to output their own credits in /INFO (which is the ircd's version of an about box). It is purposefully not possible to modify any info that has already been output, or halt the list. You must write a 371 numeric to the user, containing your info in the following format: .PP - :information hereDefinition at line 385 of file modules.cpp. + :information hereDefinition at line 309 of file modules.cpp. .PP .nf -385 { }; +309 { }; .fi .SS "int Module::OnKill (\fBuserrec\fP * source, \fBuserrec\fP * dest, std::string reason)\fC [virtual]\fP" .PP -Called when a client is disconnected by KILL. If a client is killed by a server, e.g. a nickname collision or protocol error, source is NULL. Return 1 from this function to prevent the kill, and 0 from this function to allow it as normal. If you prevent the kill no output will be sent to the client, it is down to your module to generate this information. NOTE: It is NOT advisable to stop kills which originate from servers. If you do so youre risking race conditions, desyncs and worse!Definition at line 396 of file modules.cpp. +Called when a client is disconnected by KILL. If a client is killed by a server, e.g. a nickname collision or protocol error, source is NULL. Return 1 from this function to prevent the kill, and 0 from this function to allow it as normal. If you prevent the kill no output will be sent to the client, it is down to your module to generate this information. NOTE: It is NOT advisable to stop kills which originate from servers. If you do so youre risking race conditions, desyncs and worse!Definition at line 320 of file modules.cpp. .PP .nf -396 { return 0; }; +320 { return 0; }; .fi .SS "void Module::OnLoadModule (\fBModule\fP * mod, std::string name)\fC [virtual]\fP" .PP -Called whenever a module is loaded. mod will contain a pointer to the module, and string will contain its name, for example m_widgets.so. This function is primary for dependency checking, your module may decide to enable some extra features if it sees that you have for example loaded 'm_killwidgets.so' with 'm_makewidgets.so'. It is highly recommended that modules do *NOT* bail if they cannot satisfy dependencies, but instead operate under reduced functionality, unless the dependency is absolutely neccessary (e.g. a module that extends the features of another module).Definition at line 397 of file modules.cpp. +Called whenever a module is loaded. mod will contain a pointer to the module, and string will contain its name, for example m_widgets.so. This function is primary for dependency checking, your module may decide to enable some extra features if it sees that you have for example loaded 'm_killwidgets.so' with 'm_makewidgets.so'. It is highly recommended that modules do *NOT* bail if they cannot satisfy dependencies, but instead operate under reduced functionality, unless the dependency is absolutely neccessary (e.g. a module that extends the features of another module).Definition at line 321 of file modules.cpp. .PP .nf -397 { }; +321 { }; .fi .SS "int Module::OnLocalTopicChange (\fBuserrec\fP * user, \fBchanrec\fP * chan, std::string topic)\fC [virtual]\fP" .PP -Called whenever a topic is changed by a local user. Return 1 to deny the topic change, or 0 to allow it.Definition at line 413 of file modules.cpp. +Called whenever a topic is changed by a local user. Return 1 to deny the topic change, or 0 to allow it.Definition at line 337 of file modules.cpp. .PP .nf -413 { return 0; }; +337 { return 0; }; .fi .SS "int Module::OnMeshToken (char token, \fBstring_list\fP params, \fBserverrec\fP * source, \fBserverrec\fP * reply, std::string tcp_host, std::string ipaddr, int port)\fC [virtual]\fP" .PP -Called whenever an unknown token is received in a server to server link. The token value is the unknown token -- please check that no other modules are using the token that you use. Returning 1 supresses the 'unknown token type' error which is usually sent to all opers with +s. The params list is a list of parameters, and if any parameters start with a colon (:) it is treated as the whole of the last parameter, identical to how RFC messages are handled. source is the sender of the message, and reply is what should be replied to for a unicast message. Note that there are not many messages in the mesh protocol which require unicast messaging. tcp_host is the server name as a string, ipaddr is its ip address in dotted decimal notation and port is the port number it is using.Definition at line 414 of file modules.cpp. +Called whenever an unknown token is received in a server to server link. The token value is the unknown token -- please check that no other modules are using the token that you use. Returning 1 supresses the 'unknown token type' error which is usually sent to all opers with +s. The params list is a list of parameters, and if any parameters start with a colon (:) it is treated as the whole of the last parameter, identical to how RFC messages are handled. source is the sender of the message, and reply is what should be replied to for a unicast message. Note that there are not many messages in the mesh protocol which require unicast messaging. tcp_host is the server name as a string, ipaddr is its ip address in dotted decimal notation and port is the port number it is using.Definition at line 338 of file modules.cpp. .PP .nf -414 { return 0; }; +338 { return 0; }; .fi .SS "void Module::OnOper (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called whenever a user opers locally. The userrec will contain the oper mode 'o' as this function is called after any modifications are made to the user's structure by the core.Definition at line 384 of file modules.cpp. +Called whenever a user opers locally. The userrec will contain the oper mode 'o' as this function is called after any modifications are made to the user's structure by the core.Definition at line 308 of file modules.cpp. .PP .nf -384 { }; +308 { }; .fi .SS "int Module::OnOperCompare (std::string password, std::string input)\fC [virtual]\fP" .PP -Called whenever an oper password is to be compared to what a user has input. The password field (from the config file) is in 'password' and is to be compared against 'input'. This method allows for encryption of oper passwords and much more besides. You should return a nonzero value if you want to allow the comparison or zero if you wish to do nothing.Definition at line 417 of file modules.cpp. +Called whenever an oper password is to be compared to what a user has input. The password field (from the config file) is in 'password' and is to be compared against 'input'. This method allows for encryption of oper passwords and much more besides. You should return a nonzero value if you want to allow the comparison or zero if you wish to do nothing.Definition at line 341 of file modules.cpp. .PP .nf -417 { return 0; }; +341 { return 0; }; .fi .SS "void Module::OnPacketReceive (std::string & data, std::string serv)\fC [virtual]\fP" .PP -Called after a packet is received from another irc server. This allows you to easily represent it in the correct ways to implement encryption, compression, digital signatures and anything else you may want to add. This should be regarded as a pre-processor and will be called immediately after the packet is received but before any other operations with the core of the ircd.Definition at line 378 of file modules.cpp. +Called after a packet is received from another irc server. This allows you to easily represent it in the correct ways to implement encryption, compression, digital signatures and anything else you may want to add. This should be regarded as a pre-processor and will be called immediately after the packet is received but before any other operations with the core of the ircd.Definition at line 302 of file modules.cpp. .PP .nf -378 { } +302 { } .fi .SS "void Module::OnPacketTransmit (std::string & data, std::string serv)\fC [virtual]\fP" .PP -Called before a packet is transmitted across the irc network between two irc servers. This allows you to easily represent it in the correct ways to implement encryption, compression, digital signatures and anything else you may want to add. This should be regarded as a pre-processor and will be called before ANY other operations within the ircd core program.Definition at line 377 of file modules.cpp. +Called before a packet is transmitted across the irc network between two irc servers. This allows you to easily represent it in the correct ways to implement encryption, compression, digital signatures and anything else you may want to add. This should be regarded as a pre-processor and will be called before ANY other operations within the ircd core program.Definition at line 301 of file modules.cpp. .PP .nf -377 { } +301 { } .fi .SS "int Module::OnPreCommand (std::string command, char ** parameters, int pcnt, \fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called whenever any command is about to be executed. This event occurs for all registered commands, wether they are registered in the core, or another module, but it will not occur for invalid commands (e.g. ones which do not exist within the command table). By returning 1 from this method you may prevent the command being executed. If you do this, no output is created by the core, and it is down to your module to produce any output neccessary. Note that unless you return 1, you should not destroy any structures (e.g. by using \fBServer::QuitUser\fP) otherwise when the command's handler function executes after your method returns, it will be passed an invalid pointer to the user object and crash!)Definition at line 400 of file modules.cpp. +Called whenever any command is about to be executed. This event occurs for all registered commands, wether they are registered in the core, or another module, but it will not occur for invalid commands (e.g. ones which do not exist within the command table). By returning 1 from this method you may prevent the command being executed. If you do this, no output is created by the core, and it is down to your module to produce any output neccessary. Note that unless you return 1, you should not destroy any structures (e.g. by using \fBServer::QuitUser\fP) otherwise when the command's handler function executes after your method returns, it will be passed an invalid pointer to the user object and crash!)Definition at line 324 of file modules.cpp. .PP .nf -400 { return 0; }; +324 { return 0; }; .fi .SS "int Module::OnRawMode (\fBuserrec\fP * user, \fBchanrec\fP * chan, char mode, std::string param, bool adding, int pcnt)\fC [virtual]\fP" .PP -Called whenever a mode character is processed. Return 1 from this function to block the mode character from being processed entirely, so that you may perform your own code instead. Note that this method allows you to override modes defined by other modes, but this is NOT RECOMMENDED!Definition at line 405 of file modules.cpp. +Called whenever a mode character is processed. Return 1 from this function to block the mode character from being processed entirely, so that you may perform your own code instead. Note that this method allows you to override modes defined by other modes, but this is NOT RECOMMENDED!Definition at line 329 of file modules.cpp. .PP .nf -405 { return 0; }; +329 { return 0; }; .fi .SS "void Module::OnRawSocketAccept (int fd, std::string ip, int localport)\fC [virtual]\fP" .PP -Called immediately after any connection is accepted. This is intended for raw socket processing (e.g. modules which wrap the tcp connection within another library) and provides no information relating to a user record as the connection has not been assigned yet. There are no return values from this call as all modules get an opportunity if required to process the connection.Definition at line 422 of file modules.cpp. +Called immediately after any connection is accepted. This is intended for raw socket processing (e.g. modules which wrap the tcp connection within another library) and provides no information relating to a user record as the connection has not been assigned yet. There are no return values from this call as all modules get an opportunity if required to process the connection.Definition at line 346 of file modules.cpp. .PP .nf -422 { }; +346 { }; .fi .SS "void Module::OnRawSocketClose (int fd)\fC [virtual]\fP" .PP -Called immediately before any socket is closed. When this event is called, shutdown() has not yet been called on the socket.Definition at line 424 of file modules.cpp. +Called immediately before any socket is closed. When this event is called, shutdown() has not yet been called on the socket.Definition at line 348 of file modules.cpp. .PP .nf -424 { }; +348 { }; .fi .SS "int Module::OnRawSocketRead (int fd, char * buffer, unsigned int count, int & readresult)\fC [virtual]\fP" .PP -Called immediately before any read() operation on a client socket in the core. This occurs AFTER the select() or poll() so there is always data waiting to be read when this event occurs. Your event should return 1 if it has handled the reading itself, which prevents the core just using read(). You should place any data read into buffer, up to but NOT GREATER THAN the value of count. The value of readresult must be identical to an actual result that might be returned from the read() system call, for example, number of bytes read upon success, 0 upon EOF or closed socket, and -1 for error. If your function returns a nonzero value, you MUST set readresult.Definition at line 425 of file modules.cpp. +Called immediately before any read() operation on a client socket in the core. This occurs AFTER the select() or poll() so there is always data waiting to be read when this event occurs. Your event should return 1 if it has handled the reading itself, which prevents the core just using read(). You should place any data read into buffer, up to but NOT GREATER THAN the value of count. The value of readresult must be identical to an actual result that might be returned from the read() system call, for example, number of bytes read upon success, 0 upon EOF or closed socket, and -1 for error. If your function returns a nonzero value, you MUST set readresult.Definition at line 349 of file modules.cpp. .PP .nf -425 { return 0; }; +349 { return 0; }; .fi .SS "int Module::OnRawSocketWrite (int fd, char * buffer, int count)\fC [virtual]\fP" .PP -Called immediately before any write() operation on a user's socket in the core. Because this event is a low level event no user information is associated with it. It is intended for use by modules which may wrap connections within another API such as SSL for example. return a non-zero result if you have handled the write operation, in which case the core will not call write().Definition at line 423 of file modules.cpp. +Called immediately before any write() operation on a user's socket in the core. Because this event is a low level event no user information is associated with it. It is intended for use by modules which may wrap connections within another API such as SSL for example. return a non-zero result if you have handled the write operation, in which case the core will not call write().Definition at line 347 of file modules.cpp. .PP .nf -423 { return 0; }; +347 { return 0; }; .fi .SS "void Module::OnRehash ()\fC [virtual]\fP" .PP -Called on rehash. This method is called prior to a /REHASH or when a SIGHUP is received from the operating system. You should use it to reload any files so that your module keeps in step with the rest of the application.Definition at line 379 of file modules.cpp. +Called on rehash. This method is called prior to a /REHASH or when a SIGHUP is received from the operating system. You should use it to reload any files so that your module keeps in step with the rest of the application.Definition at line 303 of file modules.cpp. .PP .nf -379 { } +303 { } .fi .SS "char * Module::OnRequest (\fBRequest\fP * request)\fC [virtual]\fP" .PP -Called whenever a \fBRequest\fP class is sent to your module by another module. Please see the documentation of \fBRequest::Send()\fP for further information. The \fBRequest\fP sent can always be assumed to be non-NULL, you should not change the request object or its data. Your method may return arbitary data in the char* result which the requesting module may be able to use for pre-determined purposes (e.g. the results of an SQL query, etc).Definition at line 416 of file modules.cpp. +Called whenever a \fBRequest\fP class is sent to your module by another module. Please see the documentation of \fBRequest::Send()\fP for further information. The \fBRequest\fP sent can always be assumed to be non-NULL, you should not change the request object or its data. Your method may return arbitary data in the char* result which the requesting module may be able to use for pre-determined purposes (e.g. the results of an SQL query, etc).Definition at line 340 of file modules.cpp. .PP Referenced by Request::Send(). .PP .nf -416 { return NULL; }; +340 { return NULL; }; .fi .SS "void Module::OnSendList (\fBuserrec\fP * user, \fBchanrec\fP * channel, char mode)\fC [virtual]\fP" .PP -Called whenever a list is needed for a listmode. For example, when a /MODE #channel +b (without any other parameters) is called, if a module was handling +b this function would be called. The function can then output any lists it wishes to. Please note that all modules will see all mode characters to provide the ability to extend each other, so please only output a list if the mode character given matches the one(s) you want to handle.Definition at line 399 of file modules.cpp. +Called whenever a list is needed for a listmode. For example, when a /MODE #channel +b (without any other parameters) is called, if a module was handling +b this function would be called. The function can then output any lists it wishes to. Please note that all modules will see all mode characters to provide the ability to extend each other, so please only output a list if the mode character given matches the one(s) you want to handle.Definition at line 323 of file modules.cpp. .PP .nf -399 { }; +323 { }; .fi .SS "void Module::OnServerRaw (std::string & raw, bool inbound, \fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called when a raw command is transmitted or received. This method is the lowest level of handler available to a module. It will be called with raw data which is passing through a connected socket. If you wish, you may munge this data by changing the string parameter 'raw'. If you do this, after your function exits it will immediately be cut down to 510 characters plus a carriage return and linefeed. For INBOUND messages only (where inbound is set to true) the value of user will be the userrec of the connection sending the data. This is not possible for outbound data because the data may be being routed to multiple targets.Definition at line 380 of file modules.cpp. +Called when a raw command is transmitted or received. This method is the lowest level of handler available to a module. It will be called with raw data which is passing through a connected socket. If you wish, you may munge this data by changing the string parameter 'raw'. If you do this, after your function exits it will immediately be cut down to 510 characters plus a carriage return and linefeed. For INBOUND messages only (where inbound is set to true) the value of user will be the userrec of the connection sending the data. This is not possible for outbound data because the data may be being routed to multiple targets.Definition at line 304 of file modules.cpp. .PP .nf -380 { } +304 { } .fi .SS "void Module::OnStats (char symbol)\fC [virtual]\fP" .PP -Called on all /STATS commands This method is triggered for all /STATS use, including stats symbols handled by the core. Definition at line 410 of file modules.cpp. +Called on all /STATS commands This method is triggered for all /STATS use, including stats symbols handled by the core. Definition at line 334 of file modules.cpp. .PP .nf -410 { }; +334 { }; .fi .SS "void Module::OnUserConnect (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called when a user connects. The details of the connecting user are available to you in the parameter userrec *userDefinition at line 372 of file modules.cpp. +Called when a user connects. The details of the connecting user are available to you in the parameter userrec *userDefinition at line 296 of file modules.cpp. .PP .nf -372 { } +296 { } .fi .SS "void Module::OnUserDisconnect (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called whenever a user's socket is closed. The details of the exiting user are available to you in the parameter userrec *user This event is called for all users, registered or not, as a cleanup method for modules which might assign resources to user, such as dns lookups, objects and sockets.Definition at line 374 of file modules.cpp. +Called whenever a user's socket is closed. The details of the exiting user are available to you in the parameter userrec *user This event is called for all users, registered or not, as a cleanup method for modules which might assign resources to user, such as dns lookups, objects and sockets.Definition at line 298 of file modules.cpp. .PP .nf -374 { } +298 { } .fi .SS "void Module::OnUserJoin (\fBuserrec\fP * user, \fBchanrec\fP * channel)\fC [virtual]\fP" .PP -Called when a user joins a channel. The details of the joining user are available to you in the parameter userrec *user, and the details of the channel they have joined is available in the variable chanrec *channelDefinition at line 375 of file modules.cpp. +Called when a user joins a channel. The details of the joining user are available to you in the parameter userrec *user, and the details of the channel they have joined is available in the variable chanrec *channelDefinition at line 299 of file modules.cpp. .PP .nf -375 { } +299 { } .fi .SS "void Module::OnUserKick (\fBuserrec\fP * source, \fBuserrec\fP * user, \fBchanrec\fP * chan, std::string reason)\fC [virtual]\fP" .PP -Called whenever a user is kicked. If this method is called, the kick is already underway and cannot be prevented, so to prevent a kick, please use \fBModule::OnUserPreKick\fP instead of this method.Definition at line 404 of file modules.cpp. +Called whenever a user is kicked. If this method is called, the kick is already underway and cannot be prevented, so to prevent a kick, please use \fBModule::OnUserPreKick\fP instead of this method.Definition at line 328 of file modules.cpp. .PP .nf -404 { }; +328 { }; .fi .SS "void Module::OnUserPart (\fBuserrec\fP * user, \fBchanrec\fP * channel)\fC [virtual]\fP" .PP -Called when a user parts a channel. The details of the leaving user are available to you in the parameter userrec *user, and the details of the channel they have left is available in the variable chanrec *channelDefinition at line 376 of file modules.cpp. +Called when a user parts a channel. The details of the leaving user are available to you in the parameter userrec *user, and the details of the channel they have left is available in the variable chanrec *channelDefinition at line 300 of file modules.cpp. .PP .nf -376 { } +300 { } .fi .SS "void Module::OnUserPostNick (\fBuserrec\fP * user, std::string oldnick)\fC [virtual]\fP" .PP -Called after any nickchange, local or remote. This can be used to track users after nickchanges have been applied. Please note that although you can see remote nickchanges through this function, you should NOT make any changes to the userrec if the user is a remote user as this may cause a desnyc. check user->server before taking any action (including returning nonzero from the method). Because this method is called after the nickchange is taken place, no return values are possible to indicate forbidding of the nick change. Use OnUserPreNick for this. Definition at line 391 of file modules.cpp. +Called after any nickchange, local or remote. This can be used to track users after nickchanges have been applied. Please note that although you can see remote nickchanges through this function, you should NOT make any changes to the userrec if the user is a remote user as this may cause a desnyc. check user->server before taking any action (including returning nonzero from the method). Because this method is called after the nickchange is taken place, no return values are possible to indicate forbidding of the nick change. Use OnUserPreNick for this. Definition at line 315 of file modules.cpp. .PP .nf -391 { }; +315 { }; .fi .SS "int Module::OnUserPreInvite (\fBuserrec\fP * source, \fBuserrec\fP * dest, \fBchanrec\fP * channel)\fC [virtual]\fP" .PP -Called whenever a user is about to invite another user into a channel, before any processing is done. Returning 1 from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter invites to channels.Definition at line 387 of file modules.cpp. +Called whenever a user is about to invite another user into a channel, before any processing is done. Returning 1 from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter invites to channels.Definition at line 311 of file modules.cpp. .PP .nf -387 { return 0; }; +311 { return 0; }; .fi .SS "int Module::OnUserPreJoin (\fBuserrec\fP * user, \fBchanrec\fP * chan, const char * cname)\fC [virtual]\fP" .PP @@ -620,68 +620,68 @@ Called whenever a user is about to join a channel, before any processing is done .PP IMPORTANT NOTE! .PP -If the user joins a NEW channel which does not exist yet, OnUserPreJoin will be called BEFORE the channel record is created. This will cause chanrec* chan to be NULL. There is very little you can do in form of processing on the actual channel record at this point, however the channel NAME will still be passed in char* cname, so that you could for example implement a channel blacklist or whitelist, etc.Definition at line 381 of file modules.cpp. +If the user joins a NEW channel which does not exist yet, OnUserPreJoin will be called BEFORE the channel record is created. This will cause chanrec* chan to be NULL. There is very little you can do in form of processing on the actual channel record at this point, however the channel NAME will still be passed in char* cname, so that you could for example implement a channel blacklist or whitelist, etc.Definition at line 305 of file modules.cpp. .PP .nf -381 { return 0; } +305 { return 0; } .fi .SS "int Module::OnUserPreKick (\fBuserrec\fP * source, \fBuserrec\fP * user, \fBchanrec\fP * chan, std::string reason)\fC [virtual]\fP" .PP -Called whenever a user is about to be kicked. Returning a value of 1 from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. Definition at line 403 of file modules.cpp. +Called whenever a user is about to be kicked. Returning a value of 1 from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. Definition at line 327 of file modules.cpp. .PP .nf -403 { return 0; }; +327 { return 0; }; .fi .SS "int Module::OnUserPreMessage (\fBuserrec\fP * user, void * dest, int target_type, std::string & text)\fC [virtual]\fP" .PP -Called whenever a user is about to PRIVMSG A user or a channel, before any processing is done. Returning any nonzero value from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter or redirect messages. target_type can be one of TYPE_USER or TYPE_CHANNEL. If the target_type value is a user, you must cast dest to a userrec* otherwise you must cast it to a chanrec*, this is the details of where the message is destined to be sent.Definition at line 388 of file modules.cpp. +Called whenever a user is about to PRIVMSG A user or a channel, before any processing is done. Returning any nonzero value from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter or redirect messages. target_type can be one of TYPE_USER or TYPE_CHANNEL. If the target_type value is a user, you must cast dest to a userrec* otherwise you must cast it to a chanrec*, this is the details of where the message is destined to be sent.Definition at line 312 of file modules.cpp. .PP .nf -388 { return 0; }; +312 { return 0; }; .fi .SS "int Module::OnUserPreNick (\fBuserrec\fP * user, std::string newnick)\fC [virtual]\fP" .PP -Called before any nickchange, local or remote. This can be used to implement Q-lines etc. Please note that although you can see remote nickchanges through this function, you should NOT make any changes to the userrec if the user is a remote user as this may cause a desnyc. check user->server before taking any action (including returning nonzero from the method). If your method returns nonzero, the nickchange is silently forbidden, and it is down to your module to generate some meaninful output.Definition at line 390 of file modules.cpp. +Called before any nickchange, local or remote. This can be used to implement Q-lines etc. Please note that although you can see remote nickchanges through this function, you should NOT make any changes to the userrec if the user is a remote user as this may cause a desnyc. check user->server before taking any action (including returning nonzero from the method). If your method returns nonzero, the nickchange is silently forbidden, and it is down to your module to generate some meaninful output.Definition at line 314 of file modules.cpp. .PP .nf -390 { return 0; }; +314 { return 0; }; .fi .SS "int Module::OnUserPreNotice (\fBuserrec\fP * user, void * dest, int target_type, std::string & text)\fC [virtual]\fP" .PP -Called whenever a user is about to NOTICE A user or a channel, before any processing is done. Returning any nonzero value from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter or redirect messages. target_type can be one of TYPE_USER or TYPE_CHANNEL. If the target_type value is a user, you must cast dest to a userrec* otherwise you must cast it to a chanrec*, this is the details of where the message is destined to be sent. You may alter the message text as you wish before relinquishing control to the next module in the chain, and if no other modules block the text this altered form of the text will be sent out to the user and possibly to other servers.Definition at line 389 of file modules.cpp. +Called whenever a user is about to NOTICE A user or a channel, before any processing is done. Returning any nonzero value from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter or redirect messages. target_type can be one of TYPE_USER or TYPE_CHANNEL. If the target_type value is a user, you must cast dest to a userrec* otherwise you must cast it to a chanrec*, this is the details of where the message is destined to be sent. You may alter the message text as you wish before relinquishing control to the next module in the chain, and if no other modules block the text this altered form of the text will be sent out to the user and possibly to other servers.Definition at line 313 of file modules.cpp. .PP .nf -389 { return 0; }; +313 { return 0; }; .fi .SS "void Module::OnUserQuit (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called when a user quits. The details of the exiting user are available to you in the parameter userrec *user This event is only called when the user is fully registered when they quit. To catch raw disconnections, use the OnUserDisconnect method.Definition at line 373 of file modules.cpp. +Called when a user quits. The details of the exiting user are available to you in the parameter userrec *user This event is only called when the user is fully registered when they quit. To catch raw disconnections, use the OnUserDisconnect method.Definition at line 297 of file modules.cpp. .PP .nf -373 { } +297 { } .fi .SS "void Module::OnUserRegister (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called whenever a user is about to register their connection (e.g. before the user is sent the MOTD etc). Modules can use this method if they are performing a function which must be done before the actual connection is completed (e.g. ident lookups, dnsbl lookups, etc). Note that you should NOT delete the user record here by causing a disconnection! Use OnUserConnect for that instead.Definition at line 402 of file modules.cpp. +Called whenever a user is about to register their connection (e.g. before the user is sent the MOTD etc). Modules can use this method if they are performing a function which must be done before the actual connection is completed (e.g. ident lookups, dnsbl lookups, etc). Note that you should NOT delete the user record here by causing a disconnection! Use OnUserConnect for that instead.Definition at line 326 of file modules.cpp. .PP .nf -402 { }; +326 { }; .fi .SS "\fBstring_list\fP Module::OnUserSync (\fBuserrec\fP * user)\fC [virtual]\fP" .PP -Called during a netburst to sync user data. This is called during the netburst on a per-user basis. You should use this call to up any special user-related things which are implemented by your module, e.g. sending listmodes. You may return multiple commands in the string_list.Definition at line 393 of file modules.cpp. +Called during a netburst to sync user data. This is called during the netburst on a per-user basis. You should use this call to up any special user-related things which are implemented by your module, e.g. sending listmodes. You may return multiple commands in the string_list.Definition at line 317 of file modules.cpp. .PP References string_list. .PP .nf -393 { string_list empty; return empty; } +317 { string_list empty; return empty; } .fi .SS "void Module::OnWhois (\fBuserrec\fP * source, \fBuserrec\fP * dest)\fC [virtual]\fP" .PP -Called whenever a /WHOIS is performed on a local user. The source parameter contains the details of the user who issued the WHOIS command, and the dest parameter contains the information of the user they are whoising.Definition at line 386 of file modules.cpp. +Called whenever a /WHOIS is performed on a local user. The source parameter contains the details of the user who issued the WHOIS command, and the dest parameter contains the information of the user they are whoising.Definition at line 310 of file modules.cpp. .PP .nf -386 { }; +310 { }; .fi diff --git a/docs/man/man3/ModuleFactory.3 b/docs/man/man3/ModuleFactory.3 index 2abcbcd97..be57b64c8 100644 --- a/docs/man/man3/ModuleFactory.3 +++ b/docs/man/man3/ModuleFactory.3 @@ -1,4 +1,4 @@ -.TH "ModuleFactory" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ModuleFactory" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -32,22 +32,22 @@ Instantiates classes inherited from \fBModule\fP This class creates a class inhe This is to allow for modules to create many different variants of \fBModule\fP, dependent on architecture, configuration, etc. In most cases, the simple class shown in the example module m_foobar.so will suffice for most modules. .PP -Definition at line 1291 of file modules.h. +Definition at line 1294 of file modules.h. .SH "Constructor & Destructor Documentation" .PP .SS "ModuleFactory::ModuleFactory ()\fC [inline]\fP" .PP -Definition at line 1294 of file modules.h. +Definition at line 1297 of file modules.h. .PP .nf -1294 { } +1297 { } .fi .SS "virtual ModuleFactory::~\fBModuleFactory\fP ()\fC [inline, virtual]\fP" .PP -Definition at line 1295 of file modules.h. +Definition at line 1298 of file modules.h. .PP .nf -1295 { } +1298 { } .fi .SH "Member Function Documentation" .PP diff --git a/docs/man/man3/ModuleMessage.3 b/docs/man/man3/ModuleMessage.3 index 8f1484c69..63b7dba85 100644 --- a/docs/man/man3/ModuleMessage.3 +++ b/docs/man/man3/ModuleMessage.3 @@ -1,4 +1,4 @@ -.TH "ModuleMessage" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ModuleMessage" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/QLine.3 b/docs/man/man3/QLine.3 index a57fa6e9d..3d9dbdc20 100644 --- a/docs/man/man3/QLine.3 +++ b/docs/man/man3/QLine.3 @@ -1,4 +1,4 @@ -.TH "QLine" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "QLine" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/Request.3 b/docs/man/man3/Request.3 index 61644568d..2f7487d15 100644 --- a/docs/man/man3/Request.3 +++ b/docs/man/man3/Request.3 @@ -1,4 +1,4 @@ -.TH "Request" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Request" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -63,65 +63,65 @@ Definition at line 154 of file modules.h. .PP .SS "Request::Request (char * anydata, \fBModule\fP * src, \fBModule\fP * dst)" .PP -Create a new Request. Definition at line 316 of file modules.cpp. +Create a new Request. Definition at line 240 of file modules.cpp. .PP .nf -316 : data(anydata), source(src), dest(dst) { }; +240 : data(anydata), source(src), dest(dst) { }; .fi .SH "Member Function Documentation" .PP .SS "char * Request::GetData ()" .PP -Fetch the Request data. Definition at line 318 of file modules.cpp. +Fetch the Request data. Definition at line 242 of file modules.cpp. .PP References data. .PP .nf -319 { -320 return this->data; -321 } +243 { +244 return this->data; +245 } .fi .SS "\fBModule\fP * Request::GetDest ()" .PP -Fetch the request destination (should be 'this' in the receiving module). Definition at line 328 of file modules.cpp. +Fetch the request destination (should be 'this' in the receiving module). Definition at line 252 of file modules.cpp. .PP References dest. .PP .nf -329 { -330 return this->dest; -331 } +253 { +254 return this->dest; +255 } .fi .SS "\fBModule\fP * Request::GetSource ()" .PP -Fetch the request source. Definition at line 323 of file modules.cpp. +Fetch the request source. Definition at line 247 of file modules.cpp. .PP References source. .PP .nf -324 { -325 return this->source; -326 } +248 { +249 return this->source; +250 } .fi .SS "char * Request::Send ()\fC [virtual]\fP" .PP Send the Request. Upon returning the result will be arbitary data returned by the module you sent the request to. It is up to your module to know what this data is and how to deal with it. Implements \fBModuleMessage\fP. .PP -Definition at line 333 of file modules.cpp. +Definition at line 257 of file modules.cpp. .PP References dest, and Module::OnRequest(). .PP .nf -334 { -335 if (this->dest) -336 { -337 return dest->OnRequest(this); -338 } -339 else -340 { -341 return NULL; -342 } -343 } +258 { +259 if (this->dest) +260 { +261 return dest->OnRequest(this); +262 } +263 else +264 { +265 return NULL; +266 } +267 } .fi .SH "Member Data Documentation" .PP diff --git a/docs/man/man3/Server.3 b/docs/man/man3/Server.3 index d9c89aa98..93daa2cc9 100644 --- a/docs/man/man3/Server.3 +++ b/docs/man/man3/Server.3 @@ -1,4 +1,4 @@ -.TH "Server" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Server" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -104,6 +104,10 @@ Inherits \fBclassbase\fP. .br .RI "\fIReturns the network name, global to all linked servers. \fP" .ti -1c +.RI "virtual std::string \fBGetServerDescription\fP ()" +.br +.RI "\fIReturns the server description string of the local server. \fP" +.ti -1c .RI "virtual \fBAdmin\fP \fBGetAdmin\fP ()" .br .RI "\fIReturns the information of the server as returned by the /ADMIN command. \fP" @@ -267,19 +271,19 @@ Definition at line 694 of file modules.h. .PP .SS "Server::Server ()" .PP -Default constructor. Creates a Server object.Definition at line 431 of file modules.cpp. +Default constructor. Creates a Server object.Definition at line 355 of file modules.cpp. .PP .nf -432 { -433 } +356 { +357 } .fi .SS "Server::~\fBServer\fP ()\fC [virtual]\fP" .PP -Default destructor. Destroys a Server object.Definition at line 435 of file modules.cpp. +Default destructor. Destroys a Server object.Definition at line 359 of file modules.cpp. .PP .nf -436 { -437 } +360 { +361 } .fi .SH "Member Function Documentation" .PP @@ -289,25 +293,25 @@ Adds a command to the command table. This allows modules to add extra commands i .PP typedef void (handlerfunc) (char**, int, userrec*); ... void \fBhandle_kill(char **parameters, int pcnt, userrec *user)\fP .PP -When the command is typed, the parameters will be placed into the parameters array (similar to argv) and the parameter count will be placed into pcnt (similar to argv). There will never be any less parameters than the 'minparams' value you specified when creating the command. The *user parameter is the class of the user which caused the command to trigger, who will always have the flag you specified in 'flags' when creating the initial command. For example to create an oper only command create the commands with flags='o'. The source parameter is used for resource tracking, and should contain the name of your module (with file extension) e.g. 'm_blarp.so'. If you place the wrong identifier here, you can cause crashes if your module is unloaded.Definition at line 504 of file modules.cpp. +When the command is typed, the parameters will be placed into the parameters array (similar to argv) and the parameter count will be placed into pcnt (similar to argv). There will never be any less parameters than the 'minparams' value you specified when creating the command. The *user parameter is the class of the user which caused the command to trigger, who will always have the flag you specified in 'flags' when creating the initial command. For example to create an oper only command create the commands with flags='o'. The source parameter is used for resource tracking, and should contain the name of your module (with file extension) e.g. 'm_blarp.so'. If you place the wrong identifier here, you can cause crashes if your module is unloaded.Definition at line 428 of file modules.cpp. .PP References createcommand(). .PP .nf -505 { -506 createcommand(cmd,f,flags,minparams,source); -507 } +429 { +430 createcommand(cmd,f,flags,minparams,source); +431 } .fi .SS "void Server::AddELine (long duration, std::string source, std::string reason, std::string hostmask)\fC [virtual]\fP" .PP -Adds a E-line The E-line is enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 750 of file modules.cpp. +Adds a E-line The E-line is enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 679 of file modules.cpp. .PP References add_eline(), and duration(). .PP .nf -751 { -752 add_eline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); -753 } +680 { +681 add_eline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); +682 } .fi .SS "bool Server::AddExtendedListMode (char modechar)\fC [virtual]\fP" .PP @@ -321,540 +325,549 @@ Adds an extended mode letter which is parsed by a module and handled in a list f .PP (4) The mode and its parameter are NOT stored in the channels modes structure .PP -It is down to the module handling the mode to maintain state and determine what 'items' (e.g. users, or a banlist) have the mode set on them, and process the modes at the correct times, e.g. during access checks on channels, etc. When the extended mode is triggered the OnExtendedMode method will be triggered as above. Note that the target you are given will be a channel, if for example your mode is set 'on a user' (in for example +a) you must use Server::Find to locate the user the mode is operating on. Your mode handler may return 1 to handle the mode AND tell the core to display the mode change, e.g. '+aaa one two three' in the case of the mode for 'two', or it may return -1 to 'eat' the mode change, so the above example would become '+aa one three' after processing.Definition at line 667 of file modules.cpp. +It is down to the module handling the mode to maintain state and determine what 'items' (e.g. users, or a banlist) have the mode set on them, and process the modes at the correct times, e.g. during access checks on channels, etc. When the extended mode is triggered the OnExtendedMode method will be triggered as above. Note that the target you are given will be a channel, if for example your mode is set 'on a user' (in for example +a) you must use Server::Find to locate the user the mode is operating on. Your mode handler may return 1 to handle the mode AND tell the core to display the mode change, e.g. '+aaa one two three' in the case of the mode for 'two', or it may return -1 to 'eat' the mode change, so the above example would become '+aa one three' after processing.Definition at line 596 of file modules.cpp. .PP References DoAddExtendedMode(), ModeMakeList(), and MT_CHANNEL. .PP .nf -668 { -669 bool res = DoAddExtendedMode(modechar,MT_CHANNEL,false,1,1); -670 if (res) -671 ModeMakeList(modechar); -672 return res; -673 } +597 { +598 bool res = DoAddExtendedMode(modechar,MT_CHANNEL,false,1,1); +599 if (res) +600 ModeMakeList(modechar); +601 return res; +602 } .fi .SS "bool Server::AddExtendedMode (char modechar, int type, bool requires_oper, int params_when_on, int params_when_off)\fC [virtual]\fP" .PP -Adds an extended mode letter which is parsed by a module. This allows modules to add extra mode letters, e.g. +x for hostcloak. the 'type' parameter is either MT_CHANNEL, MT_CLIENT, or MT_SERVER, to indicate wether the mode is a channel mode, a client mode, or a server mode. requires_oper is used with MT_CLIENT type modes only to indicate the mode can only be set or unset by an oper. If this is used for MT_CHANNEL type modes it is ignored. params_when_on is the number of modes to expect when the mode is turned on (for type MT_CHANNEL only), e.g. with mode +k, this would have a value of 1. the params_when_off value has a similar value to params_when_on, except it indicates the number of parameters to expect when the mode is disabled. Modes which act in a similar way to channel mode +l (e.g. require a parameter to enable, but not to disable) should use this parameter. The function returns false if the mode is unavailable, and will not attempt to allocate another character, as this will confuse users. This also means that as only one module can claim a specific mode character, the core does not need to keep track of which modules own which modes, which speeds up operation of the server. In this version, a mode can have at most one parameter, attempting to use more parameters will have undefined effects.Definition at line 639 of file modules.cpp. +Adds an extended mode letter which is parsed by a module. This allows modules to add extra mode letters, e.g. +x for hostcloak. the 'type' parameter is either MT_CHANNEL, MT_CLIENT, or MT_SERVER, to indicate wether the mode is a channel mode, a client mode, or a server mode. requires_oper is used with MT_CLIENT type modes only to indicate the mode can only be set or unset by an oper. If this is used for MT_CHANNEL type modes it is ignored. params_when_on is the number of modes to expect when the mode is turned on (for type MT_CHANNEL only), e.g. with mode +k, this would have a value of 1. the params_when_off value has a similar value to params_when_on, except it indicates the number of parameters to expect when the mode is disabled. Modes which act in a similar way to channel mode +l (e.g. require a parameter to enable, but not to disable) should use this parameter. The function returns false if the mode is unavailable, and will not attempt to allocate another character, as this will confuse users. This also means that as only one module can claim a specific mode character, the core does not need to keep track of which modules own which modes, which speeds up operation of the server. In this version, a mode can have at most one parameter, attempting to use more parameters will have undefined effects.Definition at line 568 of file modules.cpp. .PP References DEBUG, DoAddExtendedMode(), MT_CLIENT, and MT_SERVER. .PP .nf -640 { -641 if (((modechar >= 'A') && (modechar <= 'Z')) || ((modechar >= 'a') && (modechar <= 'z'))) -642 { -643 if (type == MT_SERVER) -644 { -645 log(DEBUG,'*** API ERROR *** Modes of type MT_SERVER are reserved for future expansion'); -646 return false; -647 } -648 if (((params_when_on>0) || (params_when_off>0)) && (type == MT_CLIENT)) -649 { -650 log(DEBUG,'*** API ERROR *** Parameters on MT_CLIENT modes are not supported'); -651 return false; -652 } -653 if ((params_when_on>1) || (params_when_off>1)) -654 { -655 log(DEBUG,'*** API ERROR *** More than one parameter for an MT_CHANNEL mode is not yet supported'); -656 return false; -657 } -658 return DoAddExtendedMode(modechar,type,requires_oper,params_when_on,params_when_off); -659 } -660 else -661 { -662 log(DEBUG,'*** API ERROR *** Muppet modechar detected.'); -663 } -664 return false; -665 } +569 { +570 if (((modechar >= 'A') && (modechar <= 'Z')) || ((modechar >= 'a') && (modechar <= 'z'))) +571 { +572 if (type == MT_SERVER) +573 { +574 log(DEBUG,'*** API ERROR *** Modes of type MT_SERVER are reserved for future expansion'); +575 return false; +576 } +577 if (((params_when_on>0) || (params_when_off>0)) && (type == MT_CLIENT)) +578 { +579 log(DEBUG,'*** API ERROR *** Parameters on MT_CLIENT modes are not supported'); +580 return false; +581 } +582 if ((params_when_on>1) || (params_when_off>1)) +583 { +584 log(DEBUG,'*** API ERROR *** More than one parameter for an MT_CHANNEL mode is not yet supported'); +585 return false; +586 } +587 return DoAddExtendedMode(modechar,type,requires_oper,params_when_on,params_when_off); +588 } +589 else +590 { +591 log(DEBUG,'*** API ERROR *** Muppet modechar detected.'); +592 } +593 return false; +594 } .fi .SS "void Server::AddGLine (long duration, std::string source, std::string reason, std::string hostmask)\fC [virtual]\fP" .PP -Adds a G-line The G-line is propogated to all of the servers in the mesh and enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name.Definition at line 730 of file modules.cpp. +Adds a G-line The G-line is propogated to all of the servers in the mesh and enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name.Definition at line 659 of file modules.cpp. .PP References add_gline(), and duration(). .PP .nf -731 { -732 add_gline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); -733 } +660 { +661 add_gline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); +662 } .fi .SS "void Server::AddKLine (long duration, std::string source, std::string reason, std::string hostmask)\fC [virtual]\fP" .PP -Adds a K-line The K-line is enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 745 of file modules.cpp. +Adds a K-line The K-line is enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 674 of file modules.cpp. .PP References add_kline(), and duration(). .PP .nf -746 { -747 add_kline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); -748 } +675 { +676 add_kline(duration, source.c_str(), reason.c_str(), hostmask.c_str()); +677 } .fi .SS "void Server::AddQLine (long duration, std::string source, std::string reason, std::string nickname)\fC [virtual]\fP" .PP -Adds a Q-line The Q-line is propogated to all of the servers in the mesh and enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 735 of file modules.cpp. +Adds a Q-line The Q-line is propogated to all of the servers in the mesh and enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 664 of file modules.cpp. .PP References add_qline(), and duration(). .PP .nf -736 { -737 add_qline(duration, source.c_str(), reason.c_str(), nickname.c_str()); -738 } +665 { +666 add_qline(duration, source.c_str(), reason.c_str(), nickname.c_str()); +667 } .fi .SS "void Server::AddZLine (long duration, std::string source, std::string reason, std::string ipaddr)\fC [virtual]\fP" .PP -Adds a Z-line The Z-line is propogated to all of the servers in the mesh and enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 740 of file modules.cpp. +Adds a Z-line The Z-line is propogated to all of the servers in the mesh and enforced as soon as it is added. The duration must be in seconds, however you can use the \fBServer::CalcDuration\fP method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. Definition at line 669 of file modules.cpp. .PP References add_zline(), and duration(). .PP .nf -741 { -742 add_zline(duration, source.c_str(), reason.c_str(), ipaddr.c_str()); -743 } +670 { +671 add_zline(duration, source.c_str(), reason.c_str(), ipaddr.c_str()); +672 } .fi .SS "long Server::CalcDuration (std::string duration)\fC [virtual]\fP" .PP -Calculates a duration This method will take a string containing a formatted duration (e.g. '1w2d') and return its value as a total number of seconds. This is the same function used internally by /GLINE etc to set the ban times.Definition at line 780 of file modules.cpp. +Calculates a duration This method will take a string containing a formatted duration (e.g. '1w2d') and return its value as a total number of seconds. This is the same function used internally by /GLINE etc to set the ban times.Definition at line 709 of file modules.cpp. .PP References duration(). .PP .nf -781 { -782 return duration(delta.c_str()); -783 } +710 { +711 return duration(delta.c_str()); +712 } .fi .SS "void Server::CallCommandHandler (std::string commandname, char ** parameters, int pcnt, \fBuserrec\fP * user)\fC [virtual]\fP" .PP Calls the handler for a command, either implemented by the core or by another module. You can use this function to trigger other commands in the ircd, such as PRIVMSG, JOIN, KICK etc, or even as a method of callback. By defining command names that are untypeable for users on irc (e.g. those which contain a or .br -) you may use them as callback identifiers. The first parameter to this method is the name of the command handler you wish to call, e.g. PRIVMSG. This will be a command handler previously registered by the core or wih \fBAddCommand()\fP. The second parameter is an array of parameters, and the third parameter is a count of parameters in the array. If you do not pass enough parameters to meet the minimum needed by the handler, the functiom will silently ignore it. The final parameter is the user executing the command handler, used for privilage checks, etc.Definition at line 494 of file modules.cpp. +) you may use them as callback identifiers. The first parameter to this method is the name of the command handler you wish to call, e.g. PRIVMSG. This will be a command handler previously registered by the core or wih \fBAddCommand()\fP. The second parameter is an array of parameters, and the third parameter is a count of parameters in the array. If you do not pass enough parameters to meet the minimum needed by the handler, the functiom will silently ignore it. The final parameter is the user executing the command handler, used for privilage checks, etc.Definition at line 418 of file modules.cpp. .PP .nf -495 { -496 call_handler(commandname.c_str(),parameters,pcnt,user); -497 } +419 { +420 call_handler(commandname.c_str(),parameters,pcnt,user); +421 } .fi .SS "void Server::ChangeGECOS (\fBuserrec\fP * user, std::string gecos)\fC [virtual]\fP" .PP -Change GECOS (fullname) of a user. You should always call this method to change a user's GECOS rather than writing directly to the fullname member of userrec, as any change applied via this method will be propogated to any linked servers.Definition at line 587 of file modules.cpp. +Change GECOS (fullname) of a user. You should always call this method to change a user's GECOS rather than writing directly to the fullname member of userrec, as any change applied via this method will be propogated to any linked servers.Definition at line 511 of file modules.cpp. .PP References ChangeName(). .PP .nf -588 { -589 ChangeName(user,gecos.c_str()); -590 } +512 { +513 ChangeName(user,gecos.c_str()); +514 } .fi .SS "void Server::ChangeHost (\fBuserrec\fP * user, std::string host)\fC [virtual]\fP" .PP -Change displayed hostname of a user. You should always call this method to change a user's host rather than writing directly to the dhost member of userrec, as any change applied via this method will be propogated to any linked servers.Definition at line 582 of file modules.cpp. +Change displayed hostname of a user. You should always call this method to change a user's host rather than writing directly to the dhost member of userrec, as any change applied via this method will be propogated to any linked servers.Definition at line 506 of file modules.cpp. .PP References ChangeDisplayedHost(). .PP .nf -583 { -584 ChangeDisplayedHost(user,host.c_str()); -585 } +507 { +508 ChangeDisplayedHost(user,host.c_str()); +509 } .fi .SS "void Server::ChangeUserNick (\fBuserrec\fP * user, std::string nickname)\fC [virtual]\fP" .PP -Forces a user nickchange. This command works similarly to SVSNICK, and can be used to implement Q-lines etc. If you specify an invalid nickname, the nick change will be dropped and the target user will receive the error numeric for it.Definition at line 479 of file modules.cpp. +Forces a user nickchange. This command works similarly to SVSNICK, and can be used to implement Q-lines etc. If you specify an invalid nickname, the nick change will be dropped and the target user will receive the error numeric for it.Definition at line 403 of file modules.cpp. .PP .nf -480 { -481 force_nickchange(user,nickname.c_str()); -482 } +404 { +405 force_nickchange(user,nickname.c_str()); +406 } .fi .SS "std::string Server::ChanMode (\fBuserrec\fP * User, \fBchanrec\fP * Chan)\fC [virtual]\fP" .PP -Attempts to look up a user's privilages on a channel. This function will return a string containing either @, , +, or an empty string, representing the user's privilages upon the channel you specify.Definition at line 612 of file modules.cpp. +Attempts to look up a user's privilages on a channel. This function will return a string containing either @, , +, or an empty string, representing the user's privilages upon the channel you specify.Definition at line 536 of file modules.cpp. .PP References cmode(). .PP .nf -613 { -614 return cmode(User,Chan); -615 } +537 { +538 return cmode(User,Chan); +539 } .fi .SS "bool Server::CommonChannels (\fBuserrec\fP * u1, \fBuserrec\fP * u2)\fC [virtual]\fP" .PP -Returns true if two users share a common channel. This method is used internally by the NICK and QUIT commands, and the \fBServer::SendCommon\fP method.Definition at line 560 of file modules.cpp. +Returns true if two users share a common channel. This method is used internally by the NICK and QUIT commands, and the \fBServer::SendCommon\fP method.Definition at line 484 of file modules.cpp. .PP References common_channels(). .PP .nf -561 { -562 return (common_channels(u1,u2) != 0); -563 } +485 { +486 return (common_channels(u1,u2) != 0); +487 } .fi .SS "int Server::CountUsers (\fBchanrec\fP * c)\fC [virtual]\fP" .PP -Returns a count of the number of users on a channel. This will NEVER be 0, as if the chanrec exists, it will have at least one user in the channel.Definition at line 675 of file modules.cpp. +Returns a count of the number of users on a channel. This will NEVER be 0, as if the chanrec exists, it will have at least one user in the channel.Definition at line 604 of file modules.cpp. .PP .nf -676 { -677 return usercount(c); -678 } +605 { +606 return usercount(c); +607 } .fi .SS "bool Server::DelELine (std::string hostmask)\fC [virtual]\fP" .PP -Deletes a local E-Line. Definition at line 775 of file modules.cpp. +Deletes a local E-Line. Definition at line 704 of file modules.cpp. .PP References del_eline(). .PP .nf -776 { -777 del_eline(hostmask.c_str()); -778 } +705 { +706 del_eline(hostmask.c_str()); +707 } .fi .SS "bool Server::DelGLine (std::string hostmask)\fC [virtual]\fP" .PP -Deletes a G-Line from all servers on the mesh. Definition at line 755 of file modules.cpp. +Deletes a G-Line from all servers on the mesh. Definition at line 684 of file modules.cpp. .PP References del_gline(). .PP .nf -756 { -757 del_gline(hostmask.c_str()); -758 } +685 { +686 del_gline(hostmask.c_str()); +687 } .fi .SS "bool Server::DelKLine (std::string hostmask)\fC [virtual]\fP" .PP -Deletes a local K-Line. Definition at line 770 of file modules.cpp. +Deletes a local K-Line. Definition at line 699 of file modules.cpp. .PP References del_kline(). .PP .nf -771 { -772 del_kline(hostmask.c_str()); -773 } +700 { +701 del_kline(hostmask.c_str()); +702 } .fi .SS "bool Server::DelQLine (std::string nickname)\fC [virtual]\fP" .PP -Deletes a Q-Line from all servers on the mesh. Definition at line 760 of file modules.cpp. +Deletes a Q-Line from all servers on the mesh. Definition at line 689 of file modules.cpp. .PP References del_qline(). .PP .nf -761 { -762 del_qline(nickname.c_str()); -763 } +690 { +691 del_qline(nickname.c_str()); +692 } .fi .SS "bool Server::DelZLine (std::string ipaddr)\fC [virtual]\fP" .PP -Deletes a Z-Line from all servers on the mesh. Definition at line 765 of file modules.cpp. +Deletes a Z-Line from all servers on the mesh. Definition at line 694 of file modules.cpp. .PP References del_zline(). .PP .nf -766 { -767 del_zline(ipaddr.c_str()); -768 } +695 { +696 del_zline(ipaddr.c_str()); +697 } .fi .SS "\fBchanrec\fP * Server::FindChannel (std::string channel)\fC [virtual]\fP" .PP -Attempts to look up a channel and return a pointer to it. This function will return NULL if the channel does not exist.Definition at line 607 of file modules.cpp. +Attempts to look up a channel and return a pointer to it. This function will return NULL if the channel does not exist.Definition at line 531 of file modules.cpp. .PP .nf -608 { -609 return FindChan(channel.c_str()); -610 } +532 { +533 return FindChan(channel.c_str()); +534 } .fi .SS "\fBuserrec\fP * Server::FindDescriptor (int socket)\fC [virtual]\fP" .PP -Attempts to look up a nick using the file descriptor associated with that nick. This function will return NULL if the file descriptor is not associated with a valid user.Definition at line 602 of file modules.cpp. +Attempts to look up a nick using the file descriptor associated with that nick. This function will return NULL if the file descriptor is not associated with a valid user.Definition at line 526 of file modules.cpp. .PP References fd_ref_table. .PP .nf -603 { -604 return (socket < 65536 ? fd_ref_table[socket] : NULL); -605 } +527 { +528 return (socket < 65536 ? fd_ref_table[socket] : NULL); +529 } .fi .SS "\fBModule\fP * Server::FindModule (std::string name)\fC [virtual]\fP" .PP -This function finds a module by name. You must provide the filename of the module. If the module cannot be found (is not loaded) the function will return NULL.Definition at line 858 of file modules.cpp. +This function finds a module by name. You must provide the filename of the module. If the module cannot be found (is not loaded) the function will return NULL.Definition at line 787 of file modules.cpp. .PP References MODCOUNT, module_names, and modules. .PP .nf -859 { -860 for (int i = 0; i <= MODCOUNT; i++) -861 { -862 if (module_names[i] == name) -863 { -864 return modules[i]; -865 } -866 } -867 return NULL; -868 } +788 { +789 for (int i = 0; i <= MODCOUNT; i++) +790 { +791 if (module_names[i] == name) +792 { +793 return modules[i]; +794 } +795 } +796 return NULL; +797 } .fi .SS "\fBuserrec\fP * Server::FindNick (std::string nick)\fC [virtual]\fP" .PP -Attempts to look up a nick and return a pointer to it. This function will return NULL if the nick does not exist.Definition at line 597 of file modules.cpp. +Attempts to look up a nick and return a pointer to it. This function will return NULL if the nick does not exist.Definition at line 521 of file modules.cpp. .PP .nf -598 { -599 return Find(nick); -600 } +522 { +523 return Find(nick); +524 } .fi .SS "\fBAdmin\fP Server::GetAdmin ()\fC [virtual]\fP" .PP -Returns the information of the server as returned by the /ADMIN command. See the \fBAdmin\fP class for further information of the return value. The members \fBAdmin::Nick\fP, \fBAdmin::Email\fP and \fBAdmin::Name\fP contain the information for the server where the module is loaded.Definition at line 632 of file modules.cpp. +Returns the information of the server as returned by the /ADMIN command. See the \fBAdmin\fP class for further information of the return value. The members \fBAdmin::Nick\fP, \fBAdmin::Email\fP and \fBAdmin::Name\fP contain the information for the server where the module is loaded.Definition at line 561 of file modules.cpp. .PP .nf -633 { -634 return Admin(getadminname(),getadminemail(),getadminnick()); -635 } +562 { +563 return Admin(getadminname(),getadminemail(),getadminnick()); +564 } .fi .SS "std::string Server::GetNetworkName ()\fC [virtual]\fP" .PP -Returns the network name, global to all linked servers. Definition at line 627 of file modules.cpp. +Returns the network name, global to all linked servers. Definition at line 551 of file modules.cpp. +.PP +.nf +552 { +553 return getnetworkname(); +554 } +.fi +.SS "std::string Server::GetServerDescription ()\fC [virtual]\fP" +.PP +Returns the server description string of the local server. Definition at line 556 of file modules.cpp. .PP .nf -628 { -629 return getnetworkname(); -630 } +557 { +558 return getserverdesc(); +559 } .fi .SS "std::string Server::GetServerName ()\fC [virtual]\fP" .PP -Returns the server name of the server where the module is loaded. Definition at line 622 of file modules.cpp. +Returns the server name of the server where the module is loaded. Definition at line 546 of file modules.cpp. .PP .nf -623 { -624 return getservername(); -625 } +547 { +548 return getservername(); +549 } .fi .SS "\fBchanuserlist\fP Server::GetUsers (\fBchanrec\fP * chan)\fC [virtual]\fP" .PP -Fetches the userlist of a channel. This function must be here and not a member of userrec or chanrec due to include constraints.Definition at line 467 of file modules.cpp. +Fetches the userlist of a channel. This function must be here and not a member of userrec or chanrec due to include constraints.Definition at line 391 of file modules.cpp. .PP References chanuserlist, chanrec::GetUsers(), and list. .PP .nf -468 { -469 chanuserlist userl; -470 userl.clear(); -471 std::vector *list = chan->GetUsers(); -472 for (std::vector::iterator i = list->begin(); i != list->end(); i++) -473 { -474 char* o = *i; -475 userl.push_back((userrec*)o); -476 } -477 return userl; -478 } +392 { +393 chanuserlist userl; +394 userl.clear(); +395 std::vector *list = chan->GetUsers(); +396 for (std::vector::iterator i = list->begin(); i != list->end(); i++) +397 { +398 char* o = *i; +399 userl.push_back((userrec*)o); +400 } +401 return userl; +402 } .fi .SS "bool Server::IsNick (std::string nick)\fC [virtual]\fP" .PP -Returns true if a nick is valid. Nicks for unregistered connections will return false.Definition at line 592 of file modules.cpp. +Returns true if a nick is valid. Nicks for unregistered connections will return false.Definition at line 516 of file modules.cpp. .PP References isnick(). .PP .nf -593 { -594 return (isnick(nick.c_str()) != 0); -595 } +517 { +518 return (isnick(nick.c_str()) != 0); +519 } .fi .SS "bool Server::IsOnChannel (\fBuserrec\fP * User, \fBchanrec\fP * Chan)\fC [virtual]\fP" .PP -Checks if a user is on a channel. This function will return true or false to indicate if user 'User' is on channel 'Chan'.Definition at line 617 of file modules.cpp. +Checks if a user is on a channel. This function will return true or false to indicate if user 'User' is on channel 'Chan'.Definition at line 541 of file modules.cpp. .PP References has_channel(). .PP .nf -618 { -619 return has_channel(User,Chan); -620 } +542 { +543 return has_channel(User,Chan); +544 } .fi .SS "bool Server::IsUlined (std::string server)\fC [virtual]\fP" .PP -Returns true if the servername you give is ulined. ULined servers have extra privilages. They are allowed to change nicknames on remote servers, change modes of clients which are on remote servers and set modes of channels where there are no channel operators for that channel on the ulined server, amongst other things. Ulined server data is also broadcast across the mesh at all times as opposed to selectively messaged in the case of normal servers, as many ulined server types (such as services) do not support meshed links and must operate in this manner.Definition at line 489 of file modules.cpp. +Returns true if the servername you give is ulined. ULined servers have extra privilages. They are allowed to change nicknames on remote servers, change modes of clients which are on remote servers and set modes of channels where there are no channel operators for that channel on the ulined server, amongst other things. Ulined server data is also broadcast across the mesh at all times as opposed to selectively messaged in the case of normal servers, as many ulined server types (such as services) do not support meshed links and must operate in this manner.Definition at line 413 of file modules.cpp. .PP References is_uline(). .PP .nf -490 { -491 return is_uline(server.c_str()); -492 } +414 { +415 return is_uline(server.c_str()); +416 } .fi .SS "bool Server::IsValidMask (std::string mask)\fC [virtual]\fP" .PP -Returns true if a nick!ident string is correctly formatted, false if otherwise. Definition at line 785 of file modules.cpp. +Returns true if a nick!ident string is correctly formatted, false if otherwise. Definition at line 714 of file modules.cpp. .PP .nf -786 { -787 const char* dest = mask.c_str(); -788 if (strchr(dest,'!')==0) -789 return false; -790 if (strchr(dest,'@')==0) -791 return false; -792 for (int i = 0; i < strlen(dest); i++) -793 if (dest[i] < 32) -794 return false; -795 for (int i = 0; i < strlen(dest); i++) -796 if (dest[i] > 126) -797 return false; -798 int c = 0; -799 for (int i = 0; i < strlen(dest); i++) -800 if (dest[i] == '!') -801 c++; -802 if (c>1) -803 return false; -804 c = 0; -805 for (int i = 0; i < strlen(dest); i++) -806 if (dest[i] == '@') -807 c++; -808 if (c>1) -809 return false; -810 -811 return true; -812 } +715 { +716 const char* dest = mask.c_str(); +717 if (strchr(dest,'!')==0) +718 return false; +719 if (strchr(dest,'@')==0) +720 return false; +721 for (int i = 0; i < strlen(dest); i++) +722 if (dest[i] < 32) +723 return false; +724 for (int i = 0; i < strlen(dest); i++) +725 if (dest[i] > 126) +726 return false; +727 int c = 0; +728 for (int i = 0; i < strlen(dest); i++) +729 if (dest[i] == '!') +730 c++; +731 if (c>1) +732 return false; +733 c = 0; +734 for (int i = 0; i < strlen(dest); i++) +735 if (dest[i] == '@') +736 c++; +737 if (c>1) +738 return false; +739 +740 return true; +741 } .fi .SS "\fBchanrec\fP * Server::JoinUserToChannel (\fBuserrec\fP * user, std::string cname, std::string key)\fC [virtual]\fP" .PP -Forces a user to join a channel. This is similar to svsjoin and can be used to implement redirection, etc. On success, the return value is a valid pointer to a chanrec* of the channel the user was joined to. On failure, the result is NULL.Definition at line 457 of file modules.cpp. +Forces a user to join a channel. This is similar to svsjoin and can be used to implement redirection, etc. On success, the return value is a valid pointer to a chanrec* of the channel the user was joined to. On failure, the result is NULL.Definition at line 381 of file modules.cpp. .PP .nf -458 { -459 return add_channel(user,cname.c_str(),key.c_str(),false); -460 } +382 { +383 return add_channel(user,cname.c_str(),key.c_str(),false); +384 } .fi .SS "void Server::Log (int level, std::string s)\fC [virtual]\fP" .PP -Writes a log string. This method writes a line of text to the log. If the level given is lower than the level given in the configuration, this command has no effect.Definition at line 499 of file modules.cpp. +Writes a log string. This method writes a line of text to the log. If the level given is lower than the level given in the configuration, this command has no effect.Definition at line 423 of file modules.cpp. .PP .nf -500 { -501 log(level,'%s',s.c_str()); -502 } +424 { +425 log(level,'%s',s.c_str()); +426 } .fi .SS "bool Server::MatchText (std::string sliteral, std::string spattern)\fC [virtual]\fP" .PP -Matches text against a glob pattern. Uses the ircd's internal matching function to match string against a globbing pattern, e.g. *!*@*.com Returns true if the literal successfully matches the pattern, false if otherwise.Definition at line 444 of file modules.cpp. +Matches text against a glob pattern. Uses the ircd's internal matching function to match string against a globbing pattern, e.g. *!*@*.com Returns true if the literal successfully matches the pattern, false if otherwise.Definition at line 368 of file modules.cpp. .PP .nf -445 { -446 char literal[MAXBUF],pattern[MAXBUF]; -447 strlcpy(literal,sliteral.c_str(),MAXBUF); -448 strlcpy(pattern,spattern.c_str(),MAXBUF); -449 return match(literal,pattern); -450 } +369 { +370 char literal[MAXBUF],pattern[MAXBUF]; +371 strlcpy(literal,sliteral.c_str(),MAXBUF); +372 strlcpy(pattern,spattern.c_str(),MAXBUF); +373 return match(literal,pattern); +374 } .fi .SS "bool Server::MeshCheckChan (\fBchanrec\fP * c, std::string servername)\fC [virtual]\fP" .PP -This function is used to check if any users on channel c are on server servername. This is used internally by PRIVMSG etc. You should not need to use it.Definition at line 840 of file modules.cpp. +This function is used to check if any users on channel c are on server servername. This is used internally by PRIVMSG etc. You should not need to use it.Definition at line 769 of file modules.cpp. .PP .nf -841 { -842 if (c) -843 { -844 return ChanAnyOnThisServer(c,(char*)servername.c_str()); -845 } -846 else return false; -847 } +770 { +771 if (c) +772 { +773 return ChanAnyOnThisServer(c,(char*)servername.c_str()); +774 } +775 else return false; +776 } .fi .SS "bool Server::MeshCheckCommon (\fBuserrec\fP * u, std::string servername)\fC [virtual]\fP" .PP -This function is used to check if user u has any channels in common with users on servername. This is used internally by \fBServer::MeshSendCommon\fP. You should very rarely need to use it.Definition at line 849 of file modules.cpp. +This function is used to check if user u has any channels in common with users on servername. This is used internally by \fBServer::MeshSendCommon\fP. You should very rarely need to use it.Definition at line 778 of file modules.cpp. .PP .nf -850 { -851 if (u) -852 { -853 return CommonOnThisServer(u,(char*)servername.c_str()); -854 } -855 else return false; -856 } +779 { +780 if (u) +781 { +782 return CommonOnThisServer(u,(char*)servername.c_str()); +783 } +784 else return false; +785 } .fi .SS "void Server::MeshSendAll (std::string text)\fC [virtual]\fP" .PP -Sends a line of text to all connected servers. If a server is not directly reachable, the core deals with routing the message, and will also deal with failures transparently.Definition at line 814 of file modules.cpp. +Sends a line of text to all connected servers. If a server is not directly reachable, the core deals with routing the message, and will also deal with failures transparently.Definition at line 743 of file modules.cpp. .PP .nf -815 { -816 NetSendToAll((char*)text.c_str()); -817 } +744 { +745 NetSendToAll((char*)text.c_str()); +746 } .fi .SS "void Server::MeshSendAllAlive (std::string text)\fC [virtual]\fP" .PP -This function is equivalent to Server::MeshSendToAll except it will only route to servers which are directly routable. Definition at line 825 of file modules.cpp. +This function is equivalent to Server::MeshSendToAll except it will only route to servers which are directly routable. Definition at line 754 of file modules.cpp. .PP .nf -826 { -827 NetSendToAllAlive((char*)text.c_str()); -828 } +755 { +756 NetSendToAllAlive((char*)text.c_str()); +757 } .fi .SS "void Server::MeshSendAllExcept (std::string target, std::string text)\fC [virtual]\fP" .PP -This function sends to all servers EXCEPT the one you specify. You should usually use this function to send messages, specifying the SENDER of your message as 'target'. This will prevent message loops.Definition at line 835 of file modules.cpp. +This function sends to all servers EXCEPT the one you specify. You should usually use this function to send messages, specifying the SENDER of your message as 'target'. This will prevent message loops.Definition at line 764 of file modules.cpp. .PP .nf -836 { -837 NetSendToAllExcept(target.c_str(),(char*)text.c_str()); -838 } +765 { +766 NetSendToAllExcept(target.c_str(),(char*)text.c_str()); +767 } .fi .SS "void Server::MeshSendCommon (\fBuserrec\fP * user, std::string text)\fC [virtual]\fP" .PP -This method sends a line of text to all servers who have users which share common channels with the user you provide. For example, if user A is on server A, and they are on channels #one and #two, and user B is on server B, and also on channel #one, but user C is on server C and on neither #one or #two, this function will cause the text to only be sent to server B. However, if server B is only reachable via C, it will route it to C (you do not have to worry about this routing, it is done transparently, but its good to know how things work!)Definition at line 819 of file modules.cpp. +This method sends a line of text to all servers who have users which share common channels with the user you provide. For example, if user A is on server A, and they are on channels #one and #two, and user B is on server B, and also on channel #one, but user C is on server C and on neither #one or #two, this function will cause the text to only be sent to server B. However, if server B is only reachable via C, it will route it to C (you do not have to worry about this routing, it is done transparently, but its good to know how things work!)Definition at line 748 of file modules.cpp. .PP .nf -820 { -821 if (user) -822 NetSendToCommon(user,(char*)text.c_str()); -823 } +749 { +750 if (user) +751 NetSendToCommon(user,(char*)text.c_str()); +752 } .fi .SS "void Server::MeshSendUnicast (std::string destination, std::string text)\fC [virtual]\fP" .PP -This function sends a line of text directly to a server. If the server is not directly routable at this time, the server attempts to route text through the mesh.Definition at line 830 of file modules.cpp. +This function sends a line of text directly to a server. If the server is not directly routable at this time, the server attempts to route text through the mesh.Definition at line 759 of file modules.cpp. .PP .nf -831 { -832 NetSendToOne((char*)destination.c_str(),(char*)text.c_str()); -833 } +760 { +761 NetSendToOne((char*)destination.c_str(),(char*)text.c_str()); +762 } .fi .SS "\fBchanrec\fP * Server::PartUserFromChannel (\fBuserrec\fP * user, std::string cname, std::string reason)\fC [virtual]\fP" .PP -Forces a user to part a channel. This is similar to svspart and can be used to implement redirection, etc. Although the return value of this function is a pointer to a channel record, the returned data is undefined and should not be read or written to. This behaviour may be changed in a future version.Definition at line 462 of file modules.cpp. +Forces a user to part a channel. This is similar to svspart and can be used to implement redirection, etc. Although the return value of this function is a pointer to a channel record, the returned data is undefined and should not be read or written to. This behaviour may be changed in a future version.Definition at line 386 of file modules.cpp. .PP .nf -463 { -464 return del_channel(user,cname.c_str(),reason.c_str(),false); -465 } +387 { +388 return del_channel(user,cname.c_str(),reason.c_str(),false); +389 } .fi .SS "bool Server::PseudoToUser (\fBuserrec\fP * alive, \fBuserrec\fP * zombie, std::string message)\fC [virtual]\fP" .PP -This user takes one user, and switches their file descriptor with another user, so that one user 'becomes' the other. The user in 'alive' is booted off the server with the given message. The user referred to by 'zombie' should have previously been locked with Server::ZombifyUser, otherwise stale sockets and file descriptor leaks can occur. After this call, the pointer to alive will be invalid, and the pointer to zombie will be equivalent in effect to the old pointer to alive.Definition at line 700 of file modules.cpp. +This user takes one user, and switches their file descriptor with another user, so that one user 'becomes' the other. The user in 'alive' is booted off the server with the given message. The user referred to by 'zombie' should have previously been locked with Server::ZombifyUser, otherwise stale sockets and file descriptor leaks can occur. After this call, the pointer to alive will be invalid, and the pointer to zombie will be equivalent in effect to the old pointer to alive.Definition at line 629 of file modules.cpp. .PP References ucrec::channel, userrec::chans, userrec::ClearBuffer(), connection::fd, FD_MAGIC_NUMBER, fd_ref_table, connection::host, userrec::ident, chanrec::name, userrec::nick, chanrec::setby, chanrec::topic, and chanrec::topicset. .PP .nf -701 { -702 zombie->fd = alive->fd; -703 alive->fd = FD_MAGIC_NUMBER; -704 alive->ClearBuffer(); -705 Write(zombie->fd,':%s!%s@%s NICK %s',alive->nick,alive->ident,alive->host,zombie->nick); -706 kill_link(alive,message.c_str()); -707 fd_ref_table[zombie->fd] = zombie; -708 for (int i = 0; i != MAXCHANS; i++) -709 { -710 if (zombie->chans[i].channel != NULL) -711 { -712 if (zombie->chans[i].channel->name) -713 { -714 chanrec* Ptr = zombie->chans[i].channel; -715 WriteFrom(zombie->fd,zombie,'JOIN %s',Ptr->name); -716 if (Ptr->topicset) -717 { -718 WriteServ(zombie->fd,'332 %s %s :%s', zombie->nick, Ptr->name, Ptr->topic); -719 WriteServ(zombie->fd,'333 %s %s %s %d', zombie->nick, Ptr->name, Ptr->setby, Ptr->topicset); -720 } -721 userlist(zombie,Ptr); -722 WriteServ(zombie->fd,'366 %s %s :End of /NAMES list.', zombie->nick, Ptr->name); -723 -724 } -725 } -726 } -727 -728 } +630 { +631 zombie->fd = alive->fd; +632 alive->fd = FD_MAGIC_NUMBER; +633 alive->ClearBuffer(); +634 Write(zombie->fd,':%s!%s@%s NICK %s',alive->nick,alive->ident,alive->host,zombie->nick); +635 kill_link(alive,message.c_str()); +636 fd_ref_table[zombie->fd] = zombie; +637 for (int i = 0; i != MAXCHANS; i++) +638 { +639 if (zombie->chans[i].channel != NULL) +640 { +641 if (zombie->chans[i].channel->name) +642 { +643 chanrec* Ptr = zombie->chans[i].channel; +644 WriteFrom(zombie->fd,zombie,'JOIN %s',Ptr->name); +645 if (Ptr->topicset) +646 { +647 WriteServ(zombie->fd,'332 %s %s :%s', zombie->nick, Ptr->name, Ptr->topic); +648 WriteServ(zombie->fd,'333 %s %s %s %d', zombie->nick, Ptr->name, Ptr->setby, Ptr->topicset); +649 } +650 userlist(zombie,Ptr); +651 WriteServ(zombie->fd,'366 %s %s :End of /NAMES list.', zombie->nick, Ptr->name); +652 +653 } +654 } +655 } +656 +657 } .fi .SS "void Server::QuitUser (\fBuserrec\fP * user, std::string reason)\fC [virtual]\fP" .PP @@ -862,71 +875,71 @@ Forces a user to quit with the specified reason. To the user, it will appear as .PP WARNING! .PP -Once you call this function, userrec* user will immediately become INVALID. You MUST NOT write to, or read from this pointer after calling the QuitUser method UNDER ANY CIRCUMSTANCES! The best course of action after calling this method is to immediately bail from your handler.Definition at line 484 of file modules.cpp. +Once you call this function, userrec* user will immediately become INVALID. You MUST NOT write to, or read from this pointer after calling the QuitUser method UNDER ANY CIRCUMSTANCES! The best course of action after calling this method is to immediately bail from your handler.Definition at line 408 of file modules.cpp. .PP .nf -485 { -486 kill_link(user,reason.c_str()); -487 } +409 { +410 kill_link(user,reason.c_str()); +411 } .fi .SS "void Server::Send (int Socket, std::string s)\fC [virtual]\fP" .PP -Sends a line of text down a TCP/IP socket. This method writes a line of text to an established socket, cutting it to 510 characters plus a carriage return and linefeed if required.Definition at line 514 of file modules.cpp. +Sends a line of text down a TCP/IP socket. This method writes a line of text to an established socket, cutting it to 510 characters plus a carriage return and linefeed if required.Definition at line 438 of file modules.cpp. .PP .nf -515 { -516 Write(Socket,'%s',s.c_str()); -517 } +439 { +440 Write(Socket,'%s',s.c_str()); +441 } .fi .SS "void Server::SendChannel (\fBuserrec\fP * User, \fBchanrec\fP * Channel, std::string s, bool IncludeSender)\fC [virtual]\fP" .PP -Sends text from a user to a channel (mulicast). This method writes a line of text to a channel, with the given user's nick/ident /host combination prepended, as used in PRIVMSG etc commands (see RFC 1459). If the IncludeSender flag is set, then the text is also sent back to the user from which it originated, as seen in MODE (see RFC 1459).Definition at line 548 of file modules.cpp. +Sends text from a user to a channel (mulicast). This method writes a line of text to a channel, with the given user's nick/ident /host combination prepended, as used in PRIVMSG etc commands (see RFC 1459). If the IncludeSender flag is set, then the text is also sent back to the user from which it originated, as seen in MODE (see RFC 1459).Definition at line 472 of file modules.cpp. .PP .nf -549 { -550 if (IncludeSender) -551 { -552 WriteChannel(Channel,User,'%s',s.c_str()); -553 } -554 else -555 { -556 ChanExceptSender(Channel,User,'%s',s.c_str()); -557 } -558 } +473 { +474 if (IncludeSender) +475 { +476 WriteChannel(Channel,User,'%s',s.c_str()); +477 } +478 else +479 { +480 ChanExceptSender(Channel,User,'%s',s.c_str()); +481 } +482 } .fi .SS "void Server::SendChannelServerNotice (std::string ServName, \fBchanrec\fP * Channel, std::string text)\fC [virtual]\fP" .PP -Writes text to a channel, but from a server, including all. This can be used to send server notices to a group of users.Definition at line 543 of file modules.cpp. +Writes text to a channel, but from a server, including all. This can be used to send server notices to a group of users.Definition at line 467 of file modules.cpp. .PP .nf -544 { -545 WriteChannelWithServ((char*)ServName.c_str(), Channel, '%s', text.c_str()); -546 } +468 { +469 WriteChannelWithServ((char*)ServName.c_str(), Channel, '%s', text.c_str()); +470 } .fi .SS "void Server::SendCommon (\fBuserrec\fP * User, std::string text, bool IncludeSender)\fC [virtual]\fP" .PP -Sends text from a user to one or more channels (mulicast). This method writes a line of text to all users which share a common channel with a given user, with the user's nick/ident/host combination prepended, as used in PRIVMSG etc commands (see RFC 1459). If the IncludeSender flag is set, then the text is also sent back to the user from which it originated, as seen in NICK (see RFC 1459). Otherwise, it is only sent to the other recipients, as seen in QUIT.Definition at line 565 of file modules.cpp. +Sends text from a user to one or more channels (mulicast). This method writes a line of text to all users which share a common channel with a given user, with the user's nick/ident/host combination prepended, as used in PRIVMSG etc commands (see RFC 1459). If the IncludeSender flag is set, then the text is also sent back to the user from which it originated, as seen in NICK (see RFC 1459). Otherwise, it is only sent to the other recipients, as seen in QUIT.Definition at line 489 of file modules.cpp. .PP .nf -566 { -567 if (IncludeSender) -568 { -569 WriteCommon(User,'%s',text.c_str()); -570 } -571 else -572 { -573 WriteCommonExcept(User,'%s',text.c_str()); -574 } -575 } +490 { +491 if (IncludeSender) +492 { +493 WriteCommon(User,'%s',text.c_str()); +494 } +495 else +496 { +497 WriteCommonExcept(User,'%s',text.c_str()); +498 } +499 } .fi .SS "void Server::SendFrom (int Socket, \fBuserrec\fP * User, std::string s)\fC [virtual]\fP" .PP -Sends text from a user to a socket. This method writes a line of text to an established socket, with the given user's nick/ident /host combination prepended, as used in PRIVSG etc commands (see RFC 1459)Definition at line 524 of file modules.cpp. +Sends text from a user to a socket. This method writes a line of text to an established socket, with the given user's nick/ident /host combination prepended, as used in PRIVSG etc commands (see RFC 1459)Definition at line 448 of file modules.cpp. .PP .nf -525 { -526 WriteFrom(Socket,User,'%s',s.c_str()); -527 } +449 { +450 WriteFrom(Socket,User,'%s',s.c_str()); +451 } .fi .SS "void Server::SendMode (char ** parameters, int pcnt, \fBuserrec\fP * user)\fC [virtual]\fP" .PP @@ -944,32 +957,32 @@ modes[2] = user->nick; .PP Srv->SendMode(modes,3,user); .PP -The modes will originate from the server where the command was issued, however responses (e.g. numerics) will be sent to the user you provide as the third parameter. You must be sure to get the number of parameters correct in the pcnt parameter otherwise you could leave your server in an unstable state!Definition at line 509 of file modules.cpp. +The modes will originate from the server where the command was issued, however responses (e.g. numerics) will be sent to the user you provide as the third parameter. You must be sure to get the number of parameters correct in the pcnt parameter otherwise you could leave your server in an unstable state!Definition at line 433 of file modules.cpp. .PP References server_mode(). .PP .nf -510 { -511 server_mode(parameters,pcnt,user); -512 } +434 { +435 server_mode(parameters,pcnt,user); +436 } .fi .SS "void Server::SendOpers (std::string s)\fC [virtual]\fP" .PP -Sends text to all opers. This method sends a server notice to all opers with the usermode +s.Definition at line 439 of file modules.cpp. +Sends text to all opers. This method sends a server notice to all opers with the usermode +s.Definition at line 363 of file modules.cpp. .PP .nf -440 { -441 WriteOpers('%s',s.c_str()); -442 } +364 { +365 WriteOpers('%s',s.c_str()); +366 } .fi .SS "void Server::SendServ (int Socket, std::string s)\fC [virtual]\fP" .PP -Sends text from the server to a socket. This method writes a line of text to an established socket, with the servername prepended as used by numerics (see RFC 1459)Definition at line 519 of file modules.cpp. +Sends text from the server to a socket. This method writes a line of text to an established socket, with the servername prepended as used by numerics (see RFC 1459)Definition at line 443 of file modules.cpp. .PP .nf -520 { -521 WriteServ(Socket,'%s',s.c_str()); -522 } +444 { +445 WriteServ(Socket,'%s',s.c_str()); +446 } .fi .SS "void Server::SendTo (\fBuserrec\fP * Source, \fBuserrec\fP * Dest, std::string s)\fC [virtual]\fP" .PP @@ -981,23 +994,23 @@ The format will become: .PP :localserver TEXT .PP -Which is useful for numerics and server notices to single users, etc.Definition at line 529 of file modules.cpp. +Which is useful for numerics and server notices to single users, etc.Definition at line 453 of file modules.cpp. .PP References connection::fd. .PP .nf -530 { -531 if (!Source) -532 { -533 // if source is NULL, then the message originates from the local server -534 Write(Dest->fd,':%s %s',this->GetServerName().c_str(),s.c_str()); -535 } -536 else -537 { -538 // otherwise it comes from the user specified -539 WriteTo(Source,Dest,'%s',s.c_str()); -540 } -541 } +454 { +455 if (!Source) +456 { +457 // if source is NULL, then the message originates from the local server +458 Write(Dest->fd,':%s %s',this->GetServerName().c_str(),s.c_str()); +459 } +460 else +461 { +462 // otherwise it comes from the user specified +463 WriteTo(Source,Dest,'%s',s.c_str()); +464 } +465 } .fi .SS "void Server::SendToModeMask (std::string modes, int flags, std::string text)\fC [virtual]\fP" .PP @@ -1005,46 +1018,46 @@ Sends to all users matching a mode mask You must specify one or more usermodes a .PP Serv->SendToModeMask('xi', WM_OR, 'm00'); .PP -Then the text 'm00' will be sent to all users with EITHER mode x or i. Conversely if you used WM_AND, the user must have both modes set to receive the message.Definition at line 452 of file modules.cpp. +Then the text 'm00' will be sent to all users with EITHER mode x or i. Conversely if you used WM_AND, the user must have both modes set to receive the message.Definition at line 376 of file modules.cpp. .PP .nf -453 { -454 WriteMode(modes.c_str(),flags,'%s',text.c_str()); -455 } +377 { +378 WriteMode(modes.c_str(),flags,'%s',text.c_str()); +379 } .fi .SS "void Server::SendWallops (\fBuserrec\fP * User, std::string text)\fC [virtual]\fP" .PP -Sends a WALLOPS message. This method writes a WALLOPS message to all users with the +w flag, originating from the specified user.Definition at line 577 of file modules.cpp. +Sends a WALLOPS message. This method writes a WALLOPS message to all users with the +w flag, originating from the specified user.Definition at line 501 of file modules.cpp. .PP .nf -578 { -579 WriteWallOps(User,false,'%s',text.c_str()); -580 } +502 { +503 WriteWallOps(User,false,'%s',text.c_str()); +504 } .fi .SS "bool Server::UserToPseudo (\fBuserrec\fP * user, std::string message)\fC [virtual]\fP" .PP -Remove a user's connection to the irc server, but leave their client in existence in the user hash. When you call this function, the user's file descriptor will be replaced with the value of FD_MAGIC_NUMBER and their old file descriptor will be closed. This idle client will remain until it is restored with a valid file descriptor, or is removed from IRC by an operator After this call, the pointer to user will be invalid.Definition at line 681 of file modules.cpp. +Remove a user's connection to the irc server, but leave their client in existence in the user hash. When you call this function, the user's file descriptor will be replaced with the value of FD_MAGIC_NUMBER and their old file descriptor will be closed. This idle client will remain until it is restored with a valid file descriptor, or is removed from IRC by an operator After this call, the pointer to user will be invalid.Definition at line 610 of file modules.cpp. .PP References userrec::ClearBuffer(), DEBUG, connection::fd, FD_MAGIC_NUMBER, connection::host, and userrec::ident. .PP .nf -682 { -683 unsigned int old_fd = user->fd; -684 user->fd = FD_MAGIC_NUMBER; -685 user->ClearBuffer(); -686 Write(old_fd,'ERROR :Closing link (%s@%s) [%s]',user->ident,user->host,message.c_str()); -687 #ifdef USE_KQUEUE -688 struct kevent ke; -689 EV_SET(&ke, old_fd, EVFILT_READ, EV_DELETE, 0, 0, NULL); -690 int i = kevent(kq, &ke, 1, 0, 0, NULL); -691 if (i == -1) -692 { -693 log(DEBUG,'kqueue: Failed to remove user from queue!'); -694 } -695 #endif -696 shutdown(old_fd,2); -697 close(old_fd); -698 } +611 { +612 unsigned int old_fd = user->fd; +613 user->fd = FD_MAGIC_NUMBER; +614 user->ClearBuffer(); +615 Write(old_fd,'ERROR :Closing link (%s@%s) [%s]',user->ident,user->host,message.c_str()); +616 #ifdef USE_KQUEUE +617 struct kevent ke; +618 EV_SET(&ke, old_fd, EVFILT_READ, EV_DELETE, 0, 0, NULL); +619 int i = kevent(kq, &ke, 1, 0, 0, NULL); +620 if (i == -1) +621 { +622 log(DEBUG,'kqueue: Failed to remove user from queue!'); +623 } +624 #endif +625 shutdown(old_fd,2); +626 close(old_fd); +627 } .fi diff --git a/docs/man/man3/StrHashComp.3 b/docs/man/man3/StrHashComp.3 index 24b2ebb81..bff4dec00 100644 --- a/docs/man/man3/StrHashComp.3 +++ b/docs/man/man3/StrHashComp.3 @@ -1,35 +1,35 @@ -.TH "StrHashComp" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "StrHashComp" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME -StrHashComp \- +StrHashComp \- This class returns true if two strings match. + +.PP .SH SYNOPSIS .br .PP +\fC#include \fP +.PP .SS "Public Member Functions" .in +1c .ti -1c .RI "bool \fBoperator()\fP (const string &s1, const string &s2) const" .br +.RI "\fIThe operator () does the actual comparison in hash_map. \fP" .in -1c -.SH "Member Function Documentation" +.SH "Detailed Description" .PP -.SS "bool StrHashComp::operator() (const string & s1, const string & s2) const\fC [inline]\fP" +This class returns true if two strings match. + +Case sensitivity is ignored, and the RFC 'character set' is adhered to .PP -Definition at line 156 of file modules.cpp. +Definition at line 60 of file hashcomp.h. +.SH "Member Function Documentation" +.PP +.SS "bool StrHashComp::operator() (const string & s1, const string & s2) const" .PP -.nf -157 { -158 char a[MAXBUF],b[MAXBUF]; -159 strlcpy(a,s1.c_str(),MAXBUF); -160 strlcpy(b,s2.c_str(),MAXBUF); -161 strlower(a); -162 strlower(b); -163 return (strcasecmp(a,b) == 0); -164 } -.fi - +The operator () does the actual comparison in hash_map. .SH "Author" .PP diff --git a/docs/man/man3/Version.3 b/docs/man/man3/Version.3 index f755c1cfb..b553e9e20 100644 --- a/docs/man/man3/Version.3 +++ b/docs/man/man3/Version.3 @@ -1,4 +1,4 @@ -.TH "Version" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "Version" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -49,10 +49,10 @@ Definition at line 111 of file modules.h. .PP .SS "Version::Version (int major, int minor, int revision, int build, int flags)" .PP -Definition at line 310 of file modules.cpp. +Definition at line 234 of file modules.cpp. .PP .nf -310 : Major(major), Minor(minor), Revision(revision), Build(build), Flags(flags) { }; +234 : Major(major), Minor(minor), Revision(revision), Build(build), Flags(flags) { }; .fi .SH "Member Data Documentation" .PP diff --git a/docs/man/man3/WhoWasUser.3 b/docs/man/man3/WhoWasUser.3 index 40ffbca4b..a6d45973f 100644 --- a/docs/man/man3/WhoWasUser.3 +++ b/docs/man/man3/WhoWasUser.3 @@ -1,4 +1,4 @@ -.TH "WhoWasUser" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "WhoWasUser" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -37,30 +37,30 @@ WhoWasUser \- A lightweight userrec used by WHOWAS. .in -1c .SH "Detailed Description" .PP -A lightweight userrec used by WHOWAS. Definition at line 315 of file users.h. +A lightweight userrec used by WHOWAS. Definition at line 318 of file users.h. .SH "Member Data Documentation" .PP .SS "char \fBWhoWasUser::dhost\fP[160]" .PP -Definition at line 320 of file users.h. +Definition at line 323 of file users.h. .SS "char \fBWhoWasUser::fullname\fP[128]" .PP -Definition at line 322 of file users.h. +Definition at line 325 of file users.h. .SS "char \fBWhoWasUser::host\fP[160]" .PP -Definition at line 321 of file users.h. +Definition at line 324 of file users.h. .SS "char \fBWhoWasUser::ident\fP[16]" .PP -Definition at line 319 of file users.h. +Definition at line 322 of file users.h. .SS "char \fBWhoWasUser::nick\fP[NICKMAX]" .PP -Definition at line 318 of file users.h. +Definition at line 321 of file users.h. .SS "char \fBWhoWasUser::server\fP[256]" .PP -Definition at line 323 of file users.h. +Definition at line 326 of file users.h. .SS "time_t \fBWhoWasUser::signon\fP" .PP -Definition at line 324 of file users.h. +Definition at line 327 of file users.h. .SH "Author" .PP diff --git a/docs/man/man3/XLine.3 b/docs/man/man3/XLine.3 index 2933362c4..8cd21fa0c 100644 --- a/docs/man/man3/XLine.3 +++ b/docs/man/man3/XLine.3 @@ -1,4 +1,4 @@ -.TH "XLine" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "XLine" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/ZLine.3 b/docs/man/man3/ZLine.3 index 72dbca6fc..916e3681f 100644 --- a/docs/man/man3/ZLine.3 +++ b/docs/man/man3/ZLine.3 @@ -1,4 +1,4 @@ -.TH "ZLine" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ZLine" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/base.h.3 b/docs/man/man3/base.h.3 index f3784d649..d3d7d4065 100644 --- a/docs/man/man3/base.h.3 +++ b/docs/man/man3/base.h.3 @@ -1,4 +1,4 @@ -.TH "base.h" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "base.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/channels.cpp.3 b/docs/man/man3/channels.cpp.3 index 9cf60156c..1b0bc51c5 100644 --- a/docs/man/man3/channels.cpp.3 +++ b/docs/man/man3/channels.cpp.3 @@ -1,4 +1,4 @@ -.TH "channels.cpp" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "channels.cpp" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -16,16 +16,12 @@ channels.cpp \- .br \fC#include \fP .br -\fC#include \fP -.br \fC#include \fP .br \fC#include \fP .br \fC#include \fP .br -\fC#include \fP -.br \fC#include \fP .br \fC#include \fP @@ -38,12 +34,8 @@ channels.cpp \- .br \fC#include \fP .br -\fC#include \fP -.br \fC#include \fP .br -\fC#include \fP -.br \fC#include 'connection.h'\fP .br \fC#include 'users.h'\fP @@ -68,6 +60,8 @@ channels.cpp \- .br \fC#include 'inspstring.h'\fP .br +\fC#include 'helperfuncs.h'\fP +.br .SS "Namespaces" @@ -205,137 +199,137 @@ channels.cpp \- .PP .SS "#define nspace std" .PP -Definition at line 58 of file channels.cpp. +Definition at line 53 of file channels.cpp. .SH "Variable Documentation" .PP .SS "char \fBAdminEmail\fP[MAXBUF]" .PP -Definition at line 72 of file channels.cpp. +Definition at line 67 of file channels.cpp. .SS "char \fBAdminName\fP[MAXBUF]" .PP -Definition at line 71 of file channels.cpp. +Definition at line 66 of file channels.cpp. .SS "char \fBAdminNick\fP[MAXBUF]" .PP -Definition at line 73 of file channels.cpp. +Definition at line 68 of file channels.cpp. .SS "std::vector \fBauth_cookies\fP" .PP -Definition at line 100 of file channels.cpp. +Definition at line 95 of file channels.cpp. .SS "int \fBboundPortCount\fP" .PP -Definition at line 94 of file channels.cpp. +Definition at line 89 of file channels.cpp. .SS "std::stringstream \fBconfig_f\fP" .PP -Definition at line 101 of file channels.cpp. +Definition at line 96 of file channels.cpp. .PP Referenced by userrec::HasPermission(). .SS "std::vector<\fBModeParameter\fP> \fBcustom_mode_params\fP" .PP -Definition at line 111 of file channels.cpp. +Definition at line 106 of file channels.cpp. .PP Referenced by chanrec::GetModeParameter(), and chanrec::SetCustomModeParam(). .SS "int \fBdebugging\fP" .PP -Definition at line 82 of file channels.cpp. +Definition at line 77 of file channels.cpp. .SS "int \fBdefaultRoute\fP" .PP -Definition at line 98 of file channels.cpp. +Definition at line 93 of file channels.cpp. .SS "int \fBDieDelay\fP" .PP -Definition at line 85 of file channels.cpp. +Definition at line 80 of file channels.cpp. .SS "char \fBdiepass\fP[MAXBUF]" .PP -Definition at line 74 of file channels.cpp. +Definition at line 69 of file channels.cpp. .SS "char \fBDieValue\fP[MAXBUF]" .PP -Definition at line 80 of file channels.cpp. +Definition at line 75 of file channels.cpp. .SS "std::vector<\fBircd_module\fP*> factory" .PP -Definition at line 65 of file channels.cpp. +Definition at line 60 of file channels.cpp. .SS "std::vector \fBfd_reap\fP" .PP -Definition at line 91 of file channels.cpp. +Definition at line 86 of file channels.cpp. .SS "char \fBlist\fP[MAXBUF]" .PP -Definition at line 78 of file channels.cpp. +Definition at line 73 of file channels.cpp. .PP Referenced by Server::GetUsers(). .SS "FILE* \fBlog_file\fP" .PP -Definition at line 105 of file channels.cpp. +Definition at line 100 of file channels.cpp. .SS "int \fBLogLevel\fP" .PP -Definition at line 67 of file channels.cpp. +Definition at line 62 of file channels.cpp. .SS "int \fBMaxWhoResults\fP" .PP -Definition at line 88 of file channels.cpp. +Definition at line 83 of file channels.cpp. .SS "\fBserverrec\fP* \fBme\fP[32]" .PP -Definition at line 103 of file channels.cpp. +Definition at line 98 of file channels.cpp. .SS "int \fBMODCOUNT\fP = -1" .PP -Definition at line 1067 of file modules.cpp. +Definition at line 996 of file modules.cpp. .PP Referenced by Server::FindModule(). .SS "std::vector \fBmodule_names\fP" .PP -Definition at line 92 of file channels.cpp. +Definition at line 87 of file channels.cpp. .PP Referenced by Server::FindModule(). .SS "std::vector<\fBModule\fP*> modules" .PP -Definition at line 64 of file channels.cpp. +Definition at line 59 of file channels.cpp. .PP Referenced by Server::FindModule(). .SS "char \fBmotd\fP[MAXBUF]" .PP -Definition at line 76 of file channels.cpp. +Definition at line 71 of file channels.cpp. .SS "time_t \fBnb_start\fP" .PP -Definition at line 89 of file channels.cpp. +Definition at line 84 of file channels.cpp. .SS "int \fBNetBufferSize\fP" .PP -Definition at line 87 of file channels.cpp. +Definition at line 82 of file channels.cpp. .SS "char \fBNetwork\fP[MAXBUF]" .PP -Definition at line 69 of file channels.cpp. +Definition at line 64 of file channels.cpp. .SS "int \fBportCount\fP" .PP -Definition at line 95 of file channels.cpp. +Definition at line 90 of file channels.cpp. .SS "int \fBports\fP[MAXSOCKS]" .PP -Definition at line 97 of file channels.cpp. +Definition at line 92 of file channels.cpp. .SS "char \fBPrefixQuit\fP[MAXBUF]" .PP -Definition at line 79 of file channels.cpp. +Definition at line 74 of file channels.cpp. .SS "char \fBrestartpass\fP[MAXBUF]" .PP -Definition at line 75 of file channels.cpp. +Definition at line 70 of file channels.cpp. .SS "char \fBrules\fP[MAXBUF]" .PP -Definition at line 77 of file channels.cpp. +Definition at line 72 of file channels.cpp. .SS "char \fBServerDesc\fP[MAXBUF]" .PP -Definition at line 70 of file channels.cpp. +Definition at line 65 of file channels.cpp. .SS "char \fBServerName\fP[MAXBUF]" .PP -Definition at line 68 of file channels.cpp. +Definition at line 63 of file channels.cpp. .SS "int \fBSERVERportCount\fP" .PP -Definition at line 96 of file channels.cpp. +Definition at line 91 of file channels.cpp. .SS "time_t \fBstartup_time\fP" .PP -Definition at line 86 of file channels.cpp. +Definition at line 81 of file channels.cpp. .SS "time_t \fBTIME\fP" .PP -Definition at line 107 of file channels.cpp. +Definition at line 102 of file channels.cpp. .PP Referenced by serverrec::serverrec(), and userrec::userrec(). .SS "int \fBWHOWAS_MAX\fP" .PP -Definition at line 84 of file channels.cpp. +Definition at line 79 of file channels.cpp. .SS "int \fBWHOWAS_STALE\fP" .PP -Definition at line 83 of file channels.cpp. +Definition at line 78 of file channels.cpp. .SH "Author" .PP Generated automatically by Doxygen for InspIRCd from the source code. diff --git a/docs/man/man3/channels.h.3 b/docs/man/man3/channels.h.3 index 97577d320..0609a03e6 100644 --- a/docs/man/man3/channels.h.3 +++ b/docs/man/man3/channels.h.3 @@ -1,4 +1,4 @@ -.TH "channels.h" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "channels.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/chanrec.3 b/docs/man/man3/chanrec.3 index 2e965d43a..0831e46b3 100644 --- a/docs/man/man3/chanrec.3 +++ b/docs/man/man3/chanrec.3 @@ -1,4 +1,4 @@ -.TH "chanrec" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "chanrec" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -114,21 +114,21 @@ Definition at line 101 of file channels.h. .PP .SS "chanrec::chanrec ()" .PP -Creates a channel record and initialises it with default values. Definition at line 113 of file channels.cpp. +Creates a channel record and initialises it with default values. Definition at line 108 of file channels.cpp. .PP References binarymodes, created, custom_modes, internal_userlist, key, limit, name, setby, topic, and topicset. .PP .nf -114 { -115 strcpy(name,''); -116 strcpy(custom_modes,''); -117 strcpy(topic,''); -118 strcpy(setby,''); -119 strcpy(key,''); -120 created = topicset = limit = 0; -121 binarymodes = 0; -122 internal_userlist.clear(); -123 } +109 { +110 strcpy(name,''); +111 strcpy(custom_modes,''); +112 strcpy(topic,''); +113 strcpy(setby,''); +114 strcpy(key,''); +115 created = topicset = limit = 0; +116 binarymodes = 0; +117 internal_userlist.clear(); +118 } .fi .SS "virtual chanrec::~\fBchanrec\fP ()\fC [inline, virtual]\fP" .PP @@ -141,161 +141,161 @@ Definition at line 205 of file channels.h. .PP .SS "void chanrec::AddUser (char * castuser)" .PP -Add a user pointer to the internal reference list The data inserted into the reference list is a table as it is an arbitary pointer compared to other users by its memory address, as this is a very fast 32 or 64 bit integer comparison. Definition at line 207 of file channels.cpp. +Add a user pointer to the internal reference list The data inserted into the reference list is a table as it is an arbitary pointer compared to other users by its memory address, as this is a very fast 32 or 64 bit integer comparison. Definition at line 202 of file channels.cpp. .PP References DEBUG, and internal_userlist. .PP .nf -208 { -209 internal_userlist.push_back(castuser); -210 log(DEBUG,'Added casted user to channel's internal list'); -211 } +203 { +204 internal_userlist.push_back(castuser); +205 log(DEBUG,'Added casted user to channel's internal list'); +206 } .fi .SS "void chanrec::DelUser (char * castuser)" .PP -Delete a user pointer to the internal reference list The data removed from the reference list is a table as it is an arbitary pointer compared to other users by its memory address, as this is a very fast 32 or 64 bit integer comparison. Definition at line 213 of file channels.cpp. +Delete a user pointer to the internal reference list The data removed from the reference list is a table as it is an arbitary pointer compared to other users by its memory address, as this is a very fast 32 or 64 bit integer comparison. Definition at line 208 of file channels.cpp. .PP References DEBUG, internal_userlist, and name. .PP .nf -214 { -215 for (std::vector::iterator a = internal_userlist.begin(); a < internal_userlist.end(); a++) -216 { -217 if (*a == castuser) -218 { -219 log(DEBUG,'Removed casted user from channel's internal list'); -220 internal_userlist.erase(a); -221 return; -222 } -223 } -224 log(DEBUG,'BUG BUG BUG! Attempt to remove an uncasted user from the internal list of %s!',name); -225 } +209 { +210 for (std::vector::iterator a = internal_userlist.begin(); a < internal_userlist.end(); a++) +211 { +212 if (*a == castuser) +213 { +214 log(DEBUG,'Removed casted user from channel's internal list'); +215 internal_userlist.erase(a); +216 return; +217 } +218 } +219 log(DEBUG,'BUG BUG BUG! Attempt to remove an uncasted user from the internal list of %s!',name); +220 } .fi .SS "std::string chanrec::GetModeParameter (char mode)" .PP -Returns the parameter for a custom mode on a channel. For example if '+L #foo' is set, and you pass this method 'L', it will return '#foo'. If the mode is not set on the channel, or the mode has no parameters associated with it, it will return an empty string.Definition at line 187 of file channels.cpp. +Returns the parameter for a custom mode on a channel. For example if '+L #foo' is set, and you pass this method 'L', it will return '#foo'. If the mode is not set on the channel, or the mode has no parameters associated with it, it will return an empty string.Definition at line 182 of file channels.cpp. .PP References custom_mode_params. .PP .nf -188 { -189 if (custom_mode_params.size()) -190 { -191 for (vector::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++) -192 { -193 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel))) -194 { -195 return i->parameter; -196 } -197 } -198 } -199 return ''; -200 } +183 { +184 if (custom_mode_params.size()) +185 { +186 for (vector::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++) +187 { +188 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel))) +189 { +190 return i->parameter; +191 } +192 } +193 } +194 return ''; +195 } .fi .SS "long chanrec::GetUserCounter ()" .PP -Obtain the channel 'user counter' This returns the channel reference counter, which is initialized to 0 when the channel is created and incremented/decremented upon joins, parts quits and kicks. Definition at line 202 of file channels.cpp. +Obtain the channel 'user counter' This returns the channel reference counter, which is initialized to 0 when the channel is created and incremented/decremented upon joins, parts quits and kicks. Definition at line 197 of file channels.cpp. .PP References internal_userlist. .PP .nf -203 { -204 return (this->internal_userlist.size()); -205 } +198 { +199 return (this->internal_userlist.size()); +200 } .fi .SS "std::vector< char * > * chanrec::GetUsers ()" .PP -Obrain the internal reference list The internal reference list contains a list of userrec* cast to char*. These are used for rapid comparison to determine channel membership for PRIVMSG, NOTICE, QUIT, PART etc. The resulting pointer to the vector should be considered readonly and only modified via AddUser and DelUser.Definition at line 227 of file channels.cpp. +Obrain the internal reference list The internal reference list contains a list of userrec* cast to char*. These are used for rapid comparison to determine channel membership for PRIVMSG, NOTICE, QUIT, PART etc. The resulting pointer to the vector should be considered readonly and only modified via AddUser and DelUser.Definition at line 222 of file channels.cpp. .PP References internal_userlist. .PP Referenced by Server::GetUsers(). .PP .nf -228 { -229 return &internal_userlist; -230 } +223 { +224 return &internal_userlist; +225 } .fi .SS "bool chanrec::IsCustomModeSet (char mode)" .PP -Returns true if a custom mode is set on a channel. Definition at line 181 of file channels.cpp. +Returns true if a custom mode is set on a channel. Definition at line 176 of file channels.cpp. .PP References DEBUG. .PP .nf -182 { -183 log(DEBUG,'Checking ISCustomModeSet: %c %s',mode,this->custom_modes); -184 return (strchr(this->custom_modes,mode) != 0); -185 } +177 { +178 log(DEBUG,'Checking ISCustomModeSet: %c %s',mode,this->custom_modes); +179 return (strchr(this->custom_modes,mode) != 0); +180 } .fi .SS "void chanrec::SetCustomMode (char mode, bool mode_on)" .PP -Sets or unsets a custom mode in the channels info. Definition at line 125 of file channels.cpp. +Sets or unsets a custom mode in the channels info. Definition at line 120 of file channels.cpp. .PP References custom_modes, DEBUG, and SetCustomModeParam(). .PP .nf -126 { -127 if (mode_on) { -128 static char m[3]; -129 m[0] = mode; -130 m[1] = '\0'; -131 if (!strchr(this->custom_modes,mode)) -132 { -133 strlcat(custom_modes,m,MAXMODES); -134 } -135 log(DEBUG,'Custom mode %c set',mode); -136 } -137 else { +121 { +122 if (mode_on) { +123 static char m[3]; +124 m[0] = mode; +125 m[1] = '\0'; +126 if (!strchr(this->custom_modes,mode)) +127 { +128 strlcat(custom_modes,m,MAXMODES); +129 } +130 log(DEBUG,'Custom mode %c set',mode); +131 } +132 else { +133 +134 std::string a = this->custom_modes; +135 int pos = a.find(mode); +136 a.erase(pos,1); +137 strncpy(this->custom_modes,a.c_str(),MAXMODES); 138 -139 std::string a = this->custom_modes; -140 int pos = a.find(mode); -141 a.erase(pos,1); -142 strncpy(this->custom_modes,a.c_str(),MAXMODES); -143 -144 log(DEBUG,'Custom mode %c removed: modelist='%s'',mode,this->custom_modes); -145 this->SetCustomModeParam(mode,'',false); -146 } -147 } +139 log(DEBUG,'Custom mode %c removed: modelist='%s'',mode,this->custom_modes); +140 this->SetCustomModeParam(mode,'',false); +141 } +142 } .fi .SS "void chanrec::SetCustomModeParam (char mode, char * parameter, bool mode_on)" .PP -Sets or unsets the parameters for a custom mode in a channels info. Definition at line 150 of file channels.cpp. +Sets or unsets the parameters for a custom mode in a channels info. Definition at line 145 of file channels.cpp. .PP References ModeParameter::channel, custom_mode_params, DEBUG, ModeParameter::mode, and ModeParameter::parameter. .PP Referenced by SetCustomMode(). .PP .nf -151 { -152 -153 log(DEBUG,'SetCustomModeParam called'); -154 ModeParameter M; -155 M.mode = mode; -156 strlcpy(M.channel,this->name,CHANMAX); -157 strlcpy(M.parameter,parameter,MAXBUF); -158 if (mode_on) +146 { +147 +148 log(DEBUG,'SetCustomModeParam called'); +149 ModeParameter M; +150 M.mode = mode; +151 strlcpy(M.channel,this->name,CHANMAX); +152 strlcpy(M.parameter,parameter,MAXBUF); +153 if (mode_on) +154 { +155 log(DEBUG,'Custom mode parameter %c %s added',mode,parameter); +156 custom_mode_params.push_back(M); +157 } +158 else 159 { -160 log(DEBUG,'Custom mode parameter %c %s added',mode,parameter); -161 custom_mode_params.push_back(M); -162 } -163 else -164 { -165 if (custom_mode_params.size()) -166 { -167 for (vector::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++) -168 { -169 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel))) -170 { -171 log(DEBUG,'Custom mode parameter %c %s removed',mode,parameter); -172 custom_mode_params.erase(i); -173 return; -174 } -175 } -176 } -177 log(DEBUG,'*** BUG *** Attempt to remove non-existent mode parameter!'); -178 } -179 } +160 if (custom_mode_params.size()) +161 { +162 for (vector::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++) +163 { +164 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel))) +165 { +166 log(DEBUG,'Custom mode parameter %c %s removed',mode,parameter); +167 custom_mode_params.erase(i); +168 return; +169 } +170 } +171 } +172 log(DEBUG,'*** BUG *** Attempt to remove non-existent mode parameter!'); +173 } +174 } .fi .SH "Member Data Documentation" .PP diff --git a/docs/man/man3/classbase.3 b/docs/man/man3/classbase.3 index d3c9b34b4..9530bb7c8 100644 --- a/docs/man/man3/classbase.3 +++ b/docs/man/man3/classbase.3 @@ -1,4 +1,4 @@ -.TH "classbase" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "classbase" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/command_t.3 b/docs/man/man3/command_t.3 index fe5b1b348..8309583b7 100644 --- a/docs/man/man3/command_t.3 +++ b/docs/man/man3/command_t.3 @@ -1,4 +1,4 @@ -.TH "command_t" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "command_t" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/commands.h.3 b/docs/man/man3/commands.h.3 index 3033594c2..c13b7bd21 100644 --- a/docs/man/man3/commands.h.3 +++ b/docs/man/man3/commands.h.3 @@ -1,4 +1,4 @@ -.TH "commands.h" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "commands.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -178,78 +178,78 @@ commands.h \- .RI "void \fBhandle_unloadmodule\fP (char **parameters, int pcnt, \fBuserrec\fP *user)" .br .ti -1c -.RI "void \fBhandle_link_packet\fP (char *tcp_msg, char *tcp_host, \fBserverrec\fP *serv)" +.RI "void \fBhandle_link_packet\fP (char *tcp_msg, char *tcp_host, \fBserverrec\fP *serv, char *tcp_sum)" .br .RI "\fISpecial functions for processing server to server traffic. \fP" .ti -1c -.RI "void \fBprocess_restricted_commands\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *ipaddr, int port)" +.RI "void \fBprocess_restricted_commands\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *ipaddr, int port, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_amp\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_amp\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .RI "\fIThese are the handlers for server commands (tokens). \fP" .ti -1c -.RI "void \fBhandle_dollar\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_dollar\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_J\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_J\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_R\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_R\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_plus\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_plus\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_b\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_b\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_a\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_a\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_F\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_F\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_N\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_N\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_AT\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_AT\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_k\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_k\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_n\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_n\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_Q\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_Q\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_K\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_K\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_L\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_L\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_m\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_m\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_M\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_M\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_T\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_T\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_t\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_t\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_i\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_i\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_P\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_P\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c -.RI "void \fBhandle_V\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host)" +.RI "void \fBhandle_V\fP (char token, char *params, \fBserverrec\fP *source, \fBserverrec\fP *reply, char *tcp_host, char *tcp_sum)" .br .ti -1c .RI "bool \fBis_uline\fP (const char *server)" @@ -265,32 +265,32 @@ commands.h \- .SS "long duration (const char * str)" .PP Other useful functions. Referenced by Server::AddELine(), Server::AddGLine(), Server::AddKLine(), Server::AddQLine(), Server::AddZLine(), and Server::CalcDuration(). -.SS "void handle_a (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_a (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_admin (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP -.SS "void handle_amp (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_amp (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP These are the handlers for server commands (tokens). -.SS "void handle_AT (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_AT (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_away (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP -.SS "void handle_b (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_b (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_connect (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP .SS "void handle_die (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP -.SS "void handle_dollar (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_dollar (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_eline (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP -.SS "void handle_F (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_F (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_gline (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP -.SS "void handle_i (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_i (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_info (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP @@ -298,14 +298,14 @@ These are the handlers for server commands (tokens). .PP .SS "void handle_ison (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP -.SS "void handle_J (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_J (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_join (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP These are the handlers for user commands. -.SS "void handle_K (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_K (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP -.SS "void handle_k (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_k (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_kick (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP @@ -313,9 +313,9 @@ These are the handlers for user commands. .PP .SS "void handle_kline (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP -.SS "void handle_L (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_L (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP -.SS "void handle_link_packet (char * tcp_msg, char * tcp_host, \fBserverrec\fP * serv)" +.SS "void handle_link_packet (char * tcp_msg, char * tcp_host, \fBserverrec\fP * serv, char * tcp_sum)" .PP Special functions for processing server to server traffic. .SS "void handle_links (char ** parameters, int pcnt, \fBuserrec\fP * user)" @@ -326,9 +326,9 @@ Special functions for processing server to server traffic. .PP .SS "void handle_lusers (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP -.SS "void handle_M (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_M (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP -.SS "void handle_m (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_m (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_map (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP @@ -336,9 +336,9 @@ Special functions for processing server to server traffic. .PP .SS "void handle_motd (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP -.SS "void handle_n (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_n (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP -.SS "void handle_N (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_N (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_names (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP @@ -348,7 +348,7 @@ Special functions for processing server to server traffic. .PP .SS "void handle_oper (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP -.SS "void handle_P (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_P (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_part (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP @@ -356,19 +356,19 @@ Special functions for processing server to server traffic. .PP .SS "void handle_ping (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP -.SS "void handle_plus (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_plus (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_pong (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP .SS "void handle_privmsg (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP -.SS "void handle_Q (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_Q (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_qline (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP .SS "void handle_quit (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP -.SS "void handle_R (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_R (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_rehash (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP @@ -384,9 +384,9 @@ Special functions for processing server to server traffic. .PP .SS "void handle_summon (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP -.SS "void handle_t (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_t (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP -.SS "void handle_T (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_T (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_time (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP @@ -402,7 +402,7 @@ Special functions for processing server to server traffic. .PP .SS "void handle_users (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP -.SS "void handle_V (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host)" +.SS "void handle_V (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * tcp_sum)" .PP .SS "void handle_wallops (char ** parameters, int pcnt, \fBuserrec\fP * user)" .PP @@ -417,7 +417,7 @@ Special functions for processing server to server traffic. .SS "bool is_uline (const char * server)" .PP Functions for u:lined servers. Referenced by Server::IsUlined(). -.SS "void process_restricted_commands (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * ipaddr, int port)" +.SS "void process_restricted_commands (char token, char * params, \fBserverrec\fP * source, \fBserverrec\fP * reply, char * tcp_host, char * ipaddr, int port, char * tcp_sum)" .PP .SH "Author" .PP diff --git a/docs/man/man3/connection.3 b/docs/man/man3/connection.3 index 089bd108e..e21a84b8d 100644 --- a/docs/man/man3/connection.3 +++ b/docs/man/man3/connection.3 @@ -1,4 +1,4 @@ -.TH "connection" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "connection" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -42,7 +42,7 @@ Inherited by \fBserverrec\fP, and \fBuserrec\fP. .br .RI "\fISend a message to a server by name, if the server is unavailable directly route the packet via another server If the server still cannot be reached after attempting to route the message remotely, returns false. \fP" .ti -1c -.RI "bool \fBRecvPacket\fP (std::deque< std::string > &messages, char *\fBhost\fP)" +.RI "bool \fBRecvPacket\fP (std::deque< std::string > &messages, char *\fBhost\fP, std::deque< std::string > &sums)" .br .RI "\fIReturns the next available packet and returns true if data is available. \fP" .ti -1c @@ -120,7 +120,7 @@ Inherited by \fBserverrec\fP, and \fBuserrec\fP. .in -1c .SH "Detailed Description" .PP -Please note: classes serverrec and userrec both inherit from class connection. Definition at line 210 of file connection.h. +Please note: classes serverrec and userrec both inherit from class connection. Definition at line 212 of file connection.h. .SH "Constructor & Destructor Documentation" .PP .SS "connection::connection ()" @@ -143,7 +143,7 @@ Find the \fBircd_connector\fP oject related to a certain servername given in 'ho .SS "bool connection::MeshCookie (char * targethost, int port, unsigned long cookie, char * servername)" .PP Begin an outbound mesh link to another ircd on a network you are already an authenticated member of. -.SS "bool connection::RecvPacket (std::deque< std::string > & messages, char * host)" +.SS "bool connection::RecvPacket (std::deque< std::string > & messages, char * host, std::deque< std::string > & sums)" .PP Returns the next available packet and returns true if data is available. Writes the servername the data came from to 'host'. If no data is available this function returns false. This function will automatically close broken links and reroute pathways, generating split messages on the network. .SS "bool connection::SendPacket (char * message, const char * host)" @@ -156,75 +156,75 @@ Terminate a link to 'targethost' by calling the \fBircd_connector::CloseConnecti .PP .SS "long \fBconnection::bytes_in\fP" .PP -Stats counter for bytes inbound. Definition at line 227 of file connection.h. +Stats counter for bytes inbound. Definition at line 229 of file connection.h. .PP Referenced by userrec::userrec(). .SS "long \fBconnection::bytes_out\fP" .PP -Stats counter for bytes outbound. Definition at line 231 of file connection.h. +Stats counter for bytes outbound. Definition at line 233 of file connection.h. .PP Referenced by userrec::FlushWriteBuf(), and userrec::userrec(). .SS "long \fBconnection::cmds_in\fP" .PP -Stats counter for commands inbound. Definition at line 235 of file connection.h. +Stats counter for commands inbound. Definition at line 237 of file connection.h. .PP Referenced by userrec::userrec(). .SS "long \fBconnection::cmds_out\fP" .PP -Stats counter for commands outbound. Definition at line 239 of file connection.h. +Stats counter for commands outbound. Definition at line 241 of file connection.h. .PP Referenced by userrec::FlushWriteBuf(), and userrec::userrec(). .SS "std::vector<\fBircd_connector\fP> \fBconnection::connectors\fP" .PP -With a serverrec, this is a list of all established server connections. With a userrec this is unused.Definition at line 274 of file connection.h. +With a serverrec, this is a list of all established server connections. With a userrec this is unused.Definition at line 276 of file connection.h. .SS "int \fBconnection::fd\fP" .PP -File descriptor of the connection. Definition at line 215 of file connection.h. +File descriptor of the connection. Definition at line 217 of file connection.h. .PP Referenced by ConfigReader::DumpErrors(), Server::PseudoToUser(), Server::SendTo(), serverrec::serverrec(), userrec::userrec(), and Server::UserToPseudo(). .SS "bool \fBconnection::haspassed\fP" .PP -True if server/user has authenticated, false if otherwise. Definition at line 243 of file connection.h. +True if server/user has authenticated, false if otherwise. Definition at line 245 of file connection.h. .PP Referenced by userrec::userrec(). .SS "char \fBconnection::host\fP[160]" .PP -Hostname of connection. Not used if this is a serverrecDefinition at line 219 of file connection.h. +Hostname of connection. Not used if this is a serverrecDefinition at line 221 of file connection.h. .PP Referenced by userrec::GetFullRealHost(), Server::PseudoToUser(), userrec::userrec(), and Server::UserToPseudo(). .SS "time_t \fBconnection::idle_lastmsg\fP" .PP -Time that the connection last sent data, used to calculate idle time. Definition at line 265 of file connection.h. +Time that the connection last sent data, used to calculate idle time. Definition at line 267 of file connection.h. .PP Referenced by userrec::userrec(). .SS "char \fBconnection::ip\fP[16]" .PP -IP of connection. Definition at line 223 of file connection.h. +IP of connection. Definition at line 225 of file connection.h. .PP Referenced by userrec::userrec(). .SS "time_t \fBconnection::lastping\fP" .PP -Time the connection was last pinged. Definition at line 257 of file connection.h. +Time the connection was last pinged. Definition at line 259 of file connection.h. .PP Referenced by serverrec::serverrec(), and userrec::userrec(). .SS "time_t \fBconnection::nping\fP" .PP -Used by PING checks with clients. Definition at line 269 of file connection.h. +Used by PING checks with clients. Definition at line 271 of file connection.h. .PP Referenced by userrec::userrec(). .SS "int \fBconnection::port\fP" .PP -Port number For a userrec, this is the port they connected to the network on. For a serverrec this is the current listening port of the serverrec object.Definition at line 249 of file connection.h. +Port number For a userrec, this is the port they connected to the network on. For a serverrec this is the current listening port of the serverrec object.Definition at line 251 of file connection.h. .PP Referenced by userrec::userrec(). .SS "char \fBconnection::registered\fP" .PP -Used by userrec to indicate the registration status of the connection. Definition at line 253 of file connection.h. +Used by userrec to indicate the registration status of the connection. Definition at line 255 of file connection.h. .PP Referenced by userrec::userrec(). .SS "time_t \fBconnection::signon\fP" .PP -Time the connection was created, set in the constructor. Definition at line 261 of file connection.h. +Time the connection was created, set in the constructor. Definition at line 263 of file connection.h. .PP Referenced by serverrec::serverrec(), and userrec::userrec(). diff --git a/docs/man/man3/connection.h.3 b/docs/man/man3/connection.h.3 index 20f716f16..2bd9c858a 100644 --- a/docs/man/man3/connection.h.3 +++ b/docs/man/man3/connection.h.3 @@ -1,4 +1,4 @@ -.TH "connection.h" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "connection.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -69,6 +69,13 @@ connection.h \- .RI "#define \fBSTATE_SERVICES\fP 5" .br .in -1c +.SS "Functions" + +.in +1c +.ti -1c +.RI "std::string \fBCreateSum\fP ()" +.br +.in -1c .SH "Define Documentation" .PP .SS "#define STATE_CONNECTED 1" @@ -89,6 +96,10 @@ Definition at line 40 of file connection.h. .SS "#define STATE_SYNC 2" .PP Definition at line 37 of file connection.h. +.SH "Function Documentation" +.PP +.SS "std::string CreateSum ()" +.PP .SH "Author" .PP Generated automatically by Doxygen for InspIRCd from the source code. diff --git a/docs/man/man3/ctables.h.3 b/docs/man/man3/ctables.h.3 index dbbfcd783..2d7eb05c9 100644 --- a/docs/man/man3/ctables.h.3 +++ b/docs/man/man3/ctables.h.3 @@ -1,4 +1,4 @@ -.TH "ctables.h" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ctables.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/dns.h.3 b/docs/man/man3/dns.h.3 index 2262c8192..aca6fe856 100644 --- a/docs/man/man3/dns.h.3 +++ b/docs/man/man3/dns.h.3 @@ -1,4 +1,4 @@ -.TH "dns.h" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "dns.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/dns_ip4list.3 b/docs/man/man3/dns_ip4list.3 index 72756c11c..a3835ec7f 100644 --- a/docs/man/man3/dns_ip4list.3 +++ b/docs/man/man3/dns_ip4list.3 @@ -1,4 +1,4 @@ -.TH "dns_ip4list" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "dns_ip4list" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/hashcomp.h.3 b/docs/man/man3/hashcomp.h.3 new file mode 100644 index 000000000..abd940138 --- /dev/null +++ b/docs/man/man3/hashcomp.h.3 @@ -0,0 +1,50 @@ +.TH "hashcomp.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.ad l +.nh +.SH NAME +hashcomp.h \- +.SH SYNOPSIS +.br +.PP +\fC#include 'inspircd_config.h'\fP +.br +\fC#include \fP +.br + +.SS "Namespaces" + +.in +1c +.ti -1c +.RI "namespace \fBirc\fP" +.br +.ti -1c +.RI "namespace \fBnspace\fP" +.br +.in -1c +.SS "Compounds" + +.in +1c +.ti -1c +.RI "struct \fBInAddr_HashComp\fP" +.br +.RI "\fIThis class returns true if two in_addr structs match. \fP" +.ti -1c +.RI "struct \fBStrHashComp\fP" +.br +.RI "\fIThis class returns true if two strings match. \fP" +.in -1c +.SS "Defines" + +.in +1c +.ti -1c +.RI "#define \fBnspace\fP __gnu_cxx" +.br +.in -1c +.SH "Define Documentation" +.PP +.SS "#define nspace __gnu_cxx" +.PP +Definition at line 29 of file hashcomp.h. +.SH "Author" +.PP +Generated automatically by Doxygen for InspIRCd from the source code. diff --git a/docs/man/man3/irc.3 b/docs/man/man3/irc.3 new file mode 100644 index 000000000..a825271ad --- /dev/null +++ b/docs/man/man3/irc.3 @@ -0,0 +1,36 @@ +.TH "irc" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.ad l +.nh +.SH NAME +irc \- The irc namespace contains a number of helper classes. + +.SH SYNOPSIS +.br +.PP +.SS "Compounds" + +.in +1c +.ti -1c +.RI "struct \fBirc_char_traits\fP" +.br +.RI "\fIThe \fBirc_char_traits\fP class is used for RFC-style comparison of strings. \fP" +.in -1c +.SS "Typedefs" + +.in +1c +.ti -1c +.RI "typedef basic_string< char, \fBirc_char_traits\fP, allocator< char > > \fBstring\fP" +.br +.RI "\fIThis typedef declares \fBirc::string\fP based upon \fBirc_char_traits\fP. \fP" +.in -1c +.SH "Detailed Description" +.PP +The irc namespace contains a number of helper classes. +.SH "Typedef Documentation" +.PP +.SS "typedef basic_string > \fBirc::string\fP" +.PP +This typedef declares \fBirc::string\fP based upon \fBirc_char_traits\fP. Definition at line 111 of file hashcomp.h. +.SH "Author" +.PP +Generated automatically by Doxygen for InspIRCd from the source code. diff --git a/docs/man/man3/irc_irc_char_traits.3 b/docs/man/man3/irc_irc_char_traits.3 new file mode 100644 index 000000000..1ee931ba6 --- /dev/null +++ b/docs/man/man3/irc_irc_char_traits.3 @@ -0,0 +1,66 @@ +.TH "irc::irc_char_traits" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.ad l +.nh +.SH NAME +irc::irc_char_traits \- The \fBirc_char_traits\fP class is used for RFC-style comparison of strings. + +.PP +.SH SYNOPSIS +.br +.PP +\fC#include \fP +.PP +Inherits \fBchar_traits< char >\fP. +.PP +.SS "Static Public Member Functions" + +.in +1c +.ti -1c +.RI "bool \fBeq\fP (char c1st, char c2nd)" +.br +.RI "\fICheck if two chars match. \fP" +.ti -1c +.RI "bool \fBne\fP (char c1st, char c2nd)" +.br +.RI "\fICheck if two chars do NOT match. \fP" +.ti -1c +.RI "bool \fBlt\fP (char c1st, char c2nd)" +.br +.RI "\fICheck if one char is less than another. \fP" +.ti -1c +.RI "int \fBcompare\fP (const char *str1, const char *str2, size_t n)" +.br +.RI "\fICompare two strings of size n. \fP" +.ti -1c +.RI "const char * \fBfind\fP (const char *s1, int n, char c)" +.br +.RI "\fIFind a char within a string up to position n. \fP" +.in -1c +.SH "Detailed Description" +.PP +The \fBirc_char_traits\fP class is used for RFC-style comparison of strings. + +This class is used to implement \fBirc::string\fP, a case-insensitive, RFC- comparing string class. +.PP +Definition at line 86 of file hashcomp.h. +.SH "Member Function Documentation" +.PP +.SS "int irc::irc_char_traits::compare (const char * str1, const char * str2, size_t n)\fC [static]\fP" +.PP +Compare two strings of size n. +.SS "bool irc::irc_char_traits::eq (char c1st, char c2nd)\fC [static]\fP" +.PP +Check if two chars match. +.SS "const char* irc::irc_char_traits::find (const char * s1, int n, char c)\fC [static]\fP" +.PP +Find a char within a string up to position n. +.SS "bool irc::irc_char_traits::lt (char c1st, char c2nd)\fC [static]\fP" +.PP +Check if one char is less than another. +.SS "bool irc::irc_char_traits::ne (char c1st, char c2nd)\fC [static]\fP" +.PP +Check if two chars do NOT match. + +.SH "Author" +.PP +Generated automatically by Doxygen for InspIRCd from the source code. diff --git a/docs/man/man3/ircd_connector.3 b/docs/man/man3/ircd_connector.3 index f45d65f95..226b6797e 100644 --- a/docs/man/man3/ircd_connector.3 +++ b/docs/man/man3/ircd_connector.3 @@ -1,4 +1,4 @@ -.TH "ircd_connector" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ircd_connector" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -160,7 +160,7 @@ Each connection has one or more of these each represents ONE outbound connection A listening socket that accepts server type connections is represented by one class serverrec. Class serverrec will instantiate several objects of type ircd_connector to represent each established connection, inbound or outbound. So, to determine all linked servers you must walk through all the serverrecs that the core defines, and in each one iterate through until you find connection(s) relating to the server you want information on. The core and module API provide functions for this. .PP -Definition at line 54 of file connection.h. +Definition at line 56 of file connection.h. .SH "Member Function Documentation" .PP .SS "void ircd_connector::AddBuffer (std::string a)" @@ -230,36 +230,36 @@ This method sets the version string of the remote server. .PP .SS "sockaddr_in \fBircd_connector::addr\fP\fC [private]\fP" .PP -Sockaddr of the outbound ip and port. Definition at line 59 of file connection.h. +Sockaddr of the outbound ip and port. Definition at line 61 of file connection.h. .SS "std::string \fBircd_connector::description\fP\fC [private]\fP" .PP -\fBServer\fP 'GECOS'. Definition at line 71 of file connection.h. +\fBServer\fP 'GECOS'. Definition at line 73 of file connection.h. .SS "int \fBircd_connector::fd\fP\fC [private]\fP" .PP -File descriptor of the connection. Definition at line 63 of file connection.h. +File descriptor of the connection. Definition at line 65 of file connection.h. .SS "char \fBircd_connector::host\fP[MAXBUF]" .PP -When MakeOutboundConnection is called, these public members are filled with the details passed to the function, for future reference. Definition at line 99 of file connection.h. +When MakeOutboundConnection is called, these public members are filled with the details passed to the function, for future reference. Definition at line 101 of file connection.h. .SS "std::string \fBircd_connector::ircdbuffer\fP" .PP IRCD Buffer for input characters, holds as many lines as are pending - Note that the final line may not be complete and should only be read when there is a .br - seperator. Definition at line 92 of file connection.h. + seperator. Definition at line 94 of file connection.h. .SS "int \fBircd_connector::port\fP" .PP -When MakeOutboundConnection is called, these public members are filled with the details passed to the function, for future reference. Definition at line 105 of file connection.h. +When MakeOutboundConnection is called, these public members are filled with the details passed to the function, for future reference. Definition at line 107 of file connection.h. .SS "std::vector \fBircd_connector::routes\fP" .PP -\fBServer\fP names of servers that this server is linked to So for A->B->C, if this was the record for B it would contain A and C whilever both servers are connected to B. Definition at line 111 of file connection.h. +\fBServer\fP names of servers that this server is linked to So for A->B->C, if this was the record for B it would contain A and C whilever both servers are connected to B. Definition at line 113 of file connection.h. .SS "std::string \fBircd_connector::servername\fP\fC [private]\fP" .PP -\fBServer\fP name. Definition at line 67 of file connection.h. +\fBServer\fP name. Definition at line 69 of file connection.h. .SS "char \fBircd_connector::state\fP\fC [private]\fP" .PP -State. STATE_NOAUTH_INBOUND, STATE_NOAUTH_OUTBOUND STATE_SYNC, STATE_DISCONNECTED, STATE_CONNECTEDDefinition at line 76 of file connection.h. +State. STATE_NOAUTH_INBOUND, STATE_NOAUTH_OUTBOUND STATE_SYNC, STATE_DISCONNECTED, STATE_CONNECTEDDefinition at line 78 of file connection.h. .SS "std::string \fBircd_connector::version\fP\fC [private]\fP" .PP -This string holds the ircd's version response. Definition at line 84 of file connection.h. +This string holds the ircd's version response. Definition at line 86 of file connection.h. .SH "Author" .PP diff --git a/docs/man/man3/message.h.3 b/docs/man/man3/message.h.3 index 3cbc9f2c8..5b7529f6c 100644 --- a/docs/man/man3/message.h.3 +++ b/docs/man/man3/message.h.3 @@ -1,4 +1,4 @@ -.TH "message.h" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "message.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/mode.h.3 b/docs/man/man3/mode.h.3 index 9d1833afe..51981f20d 100644 --- a/docs/man/man3/mode.h.3 +++ b/docs/man/man3/mode.h.3 @@ -1,4 +1,4 @@ -.TH "mode.h" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "mode.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/modules.cpp.3 b/docs/man/man3/modules.cpp.3 index 2c42d18cb..dfea1301b 100644 --- a/docs/man/man3/modules.cpp.3 +++ b/docs/man/man3/modules.cpp.3 @@ -1,4 +1,4 @@ -.TH "modules.cpp" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "modules.cpp" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -16,16 +16,8 @@ modules.cpp \- .br \fC#include \fP .br -\fC#include \fP -.br \fC#include \fP .br -\fC#include \fP -.br -\fC#include \fP -.br -\fC#include \fP -.br \fC#include \fP .br \fC#include \fP @@ -38,12 +30,8 @@ modules.cpp \- .br \fC#include \fP .br -\fC#include \fP -.br \fC#include \fP .br -\fC#include \fP -.br \fC#include 'connection.h'\fP .br \fC#include 'users.h'\fP @@ -70,33 +58,17 @@ modules.cpp \- .br \fC#include 'inspstring.h'\fP .br - -.SS "Namespaces" - -.in +1c -.ti -1c -.RI "namespace \fBnspace\fP" +\fC#include 'helperfuncs.h'\fP .br -.in -1c +\fC#include 'hashcomp.h'\fP +.br + .SS "Compounds" .in +1c .ti -1c .RI "class \fBExtMode\fP" .br -.ti -1c -.RI "struct \fBInAddr_HashComp\fP" -.br -.ti -1c -.RI "struct \fBStrHashComp\fP" -.br -.in -1c -.SS "Defines" - -.in +1c -.ti -1c -.RI "#define \fBnspace\fP std" -.br .in -1c .SS "Typedefs" @@ -296,169 +268,164 @@ modules.cpp \- .RI "\fBExtModeList\fP \fBEMode\fP" .br .in -1c -.SH "Define Documentation" -.PP -.SS "#define nspace std" -.PP -Definition at line 64 of file modules.cpp. .SH "Typedef Documentation" .PP .SS "typedef nspace::hash_map, \fBInAddr_HashComp\fP> \fBaddress_cache\fP" .PP -Definition at line 187 of file modules.cpp. +Definition at line 111 of file modules.cpp. .SS "typedef nspace::hash_map, \fBStrHashComp\fP> \fBchan_hash\fP" .PP -Definition at line 186 of file modules.cpp. +Definition at line 110 of file modules.cpp. .SS "typedef std::deque<\fBcommand_t\fP> \fBcommand_table\fP" .PP -Definition at line 189 of file modules.cpp. +Definition at line 113 of file modules.cpp. .SS "typedef std::vector<\fBExtMode\fP> \fBExtModeList\fP" .PP -Definition at line 215 of file modules.cpp. +Definition at line 139 of file modules.cpp. .SS "typedef ExtModeList::iterator \fBExtModeListIter\fP" .PP -Definition at line 216 of file modules.cpp. +Definition at line 140 of file modules.cpp. .PP Referenced by ModeDefined(), ModeDefinedOff(), ModeDefinedOn(), ModeDefinedOper(), ModeIsListMode(), and ModeMakeList(). .SS "typedef nspace::hash_map, \fBStrHashComp\fP> \fBuser_hash\fP" .PP -Definition at line 185 of file modules.cpp. +Definition at line 109 of file modules.cpp. .SS "typedef nspace::hash_map, \fBStrHashComp\fP> \fBwhowas_hash\fP" .PP -Definition at line 188 of file modules.cpp. +Definition at line 112 of file modules.cpp. .SH "Function Documentation" .PP .SS "bool DoAddExtendedMode (char modechar, int type, bool requires_oper, int params_on, int params_off)" .PP -Definition at line 285 of file modules.cpp. +Definition at line 209 of file modules.cpp. .PP References EMode, and ModeDefined(). .PP Referenced by Server::AddExtendedListMode(), and Server::AddExtendedMode(). .PP .nf -286 { -287 if (ModeDefined(modechar,type)) { -288 return false; -289 } -290 EMode.push_back(ExtMode(modechar,type,requires_oper,params_on,params_off)); -291 return true; -292 } +210 { +211 if (ModeDefined(modechar,type)) { +212 return false; +213 } +214 EMode.push_back(ExtMode(modechar,type,requires_oper,params_on,params_off)); +215 return true; +216 } .fi .SS "std::vector<\fBircd_module\fP*> factory (255)" .PP .SS "bool ModeDefined (char modechar, int type)" .PP -Definition at line 222 of file modules.cpp. +Definition at line 146 of file modules.cpp. .PP References EMode, and ExtModeListIter. .PP Referenced by DoAddExtendedMode(). .PP .nf -223 { -224 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -225 { -226 if ((i->modechar == modechar) && (i->type == type)) -227 { -228 return true; -229 } -230 } -231 return false; -232 } +147 { +148 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +149 { +150 if ((i->modechar == modechar) && (i->type == type)) +151 { +152 return true; +153 } +154 } +155 return false; +156 } .fi .SS "int ModeDefinedOff (char modechar, int type)" .PP -Definition at line 272 of file modules.cpp. +Definition at line 196 of file modules.cpp. .PP References EMode, and ExtModeListIter. .PP .nf -273 { -274 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -275 { -276 if ((i->modechar == modechar) && (i->type == type)) -277 { -278 return i->params_when_off; -279 } -280 } -281 return 0; -282 } +197 { +198 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +199 { +200 if ((i->modechar == modechar) && (i->type == type)) +201 { +202 return i->params_when_off; +203 } +204 } +205 return 0; +206 } .fi .SS "int ModeDefinedOn (char modechar, int type)" .PP -Definition at line 259 of file modules.cpp. +Definition at line 183 of file modules.cpp. .PP References EMode, and ExtModeListIter. .PP .nf -260 { -261 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -262 { -263 if ((i->modechar == modechar) && (i->type == type)) -264 { -265 return i->params_when_on; -266 } -267 } -268 return 0; -269 } +184 { +185 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +186 { +187 if ((i->modechar == modechar) && (i->type == type)) +188 { +189 return i->params_when_on; +190 } +191 } +192 return 0; +193 } .fi .SS "bool ModeDefinedOper (char modechar, int type)" .PP -Definition at line 246 of file modules.cpp. +Definition at line 170 of file modules.cpp. .PP References EMode, and ExtModeListIter. .PP .nf -247 { -248 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -249 { -250 if ((i->modechar == modechar) && (i->type == type) && (i->needsoper == true)) -251 { -252 return true; -253 } -254 } -255 return false; -256 } +171 { +172 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +173 { +174 if ((i->modechar == modechar) && (i->type == type) && (i->needsoper == true)) +175 { +176 return true; +177 } +178 } +179 return false; +180 } .fi .SS "bool ModeIsListMode (char modechar, int type)" .PP -Definition at line 234 of file modules.cpp. +Definition at line 158 of file modules.cpp. .PP References EMode, and ExtModeListIter. .PP .nf -235 { -236 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -237 { -238 if ((i->modechar == modechar) && (i->type == type) && (i->list == true)) -239 { -240 return true; -241 } -242 } -243 return false; -244 } +159 { +160 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +161 { +162 if ((i->modechar == modechar) && (i->type == type) && (i->list == true)) +163 { +164 return true; +165 } +166 } +167 return false; +168 } .fi .SS "void ModeMakeList (char modechar)" .PP -Definition at line 295 of file modules.cpp. +Definition at line 219 of file modules.cpp. .PP References EMode, ExtModeListIter, and MT_CHANNEL. .PP Referenced by Server::AddExtendedListMode(). .PP .nf -296 { -297 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) -298 { -299 if ((i->modechar == modechar) && (i->type == MT_CHANNEL)) -300 { -301 i->list = true; -302 return; -303 } -304 } -305 return; -306 } +220 { +221 for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++) +222 { +223 if ((i->modechar == modechar) && (i->type == MT_CHANNEL)) +224 { +225 i->list = true; +226 return; +227 } +228 } +229 return; +230 } .fi .SS "std::vector<\fBModule\fP*> modules (255)" .PP @@ -466,146 +433,146 @@ Referenced by Server::AddExtendedListMode(). .PP .SS "char \fBAdminEmail\fP[MAXBUF]" .PP -Definition at line 84 of file modules.cpp. +Definition at line 72 of file modules.cpp. .SS "char \fBAdminName\fP[MAXBUF]" .PP -Definition at line 83 of file modules.cpp. +Definition at line 71 of file modules.cpp. .SS "char \fBAdminNick\fP[MAXBUF]" .PP -Definition at line 85 of file modules.cpp. +Definition at line 73 of file modules.cpp. .SS "std::vector \fBauth_cookies\fP" .PP -Definition at line 112 of file modules.cpp. +Definition at line 100 of file modules.cpp. .SS "int \fBboundPortCount\fP" .PP -Definition at line 106 of file modules.cpp. +Definition at line 94 of file modules.cpp. .SS "\fBchan_hash\fP \fBchanlist\fP" .PP -Definition at line 193 of file modules.cpp. +Definition at line 117 of file modules.cpp. .SS "\fBuser_hash\fP \fBclientlist\fP" .PP -Definition at line 192 of file modules.cpp. +Definition at line 116 of file modules.cpp. .SS "\fBcommand_table\fP \fBcmdlist\fP" .PP -Definition at line 195 of file modules.cpp. +Definition at line 119 of file modules.cpp. .SS "std::stringstream \fBconfig_f\fP" .PP -Definition at line 113 of file modules.cpp. +Definition at line 101 of file modules.cpp. .SS "int \fBdebugging\fP" .PP -Definition at line 94 of file modules.cpp. +Definition at line 82 of file modules.cpp. .SS "int \fBdefaultRoute\fP" .PP -Definition at line 110 of file modules.cpp. +Definition at line 98 of file modules.cpp. .SS "int \fBDieDelay\fP" .PP -Definition at line 97 of file modules.cpp. +Definition at line 85 of file modules.cpp. .SS "char \fBdiepass\fP[MAXBUF]" .PP -Definition at line 86 of file modules.cpp. +Definition at line 74 of file modules.cpp. .SS "char \fBDieValue\fP[MAXBUF]" .PP -Definition at line 92 of file modules.cpp. +Definition at line 80 of file modules.cpp. .SS "\fBExtModeList\fP \fBEMode\fP" .PP -Definition at line 219 of file modules.cpp. +Definition at line 143 of file modules.cpp. .PP Referenced by DoAddExtendedMode(), ModeDefined(), ModeDefinedOff(), ModeDefinedOn(), ModeDefinedOper(), ModeIsListMode(), and ModeMakeList(). .SS "std::vector<\fBircd_module\fP*> factory" .PP -Definition at line 75 of file modules.cpp. +Definition at line 63 of file modules.cpp. .SS "std::vector \fBfd_reap\fP" .PP -Definition at line 103 of file modules.cpp. +Definition at line 91 of file modules.cpp. .SS "\fBuserrec\fP* \fBfd_ref_table\fP[65536]" .PP -Definition at line 119 of file modules.cpp. +Definition at line 107 of file modules.cpp. .PP Referenced by Server::FindDescriptor(), and Server::PseudoToUser(). .SS "\fBaddress_cache\fP \fBIP\fP" .PP -Definition at line 198 of file modules.cpp. +Definition at line 122 of file modules.cpp. .SS "char \fBlist\fP[MAXBUF]" .PP -Definition at line 90 of file modules.cpp. +Definition at line 78 of file modules.cpp. .SS "FILE* \fBlog_file\fP" .PP -Definition at line 117 of file modules.cpp. +Definition at line 105 of file modules.cpp. .SS "int \fBLogLevel\fP" .PP -Definition at line 79 of file modules.cpp. +Definition at line 67 of file modules.cpp. .SS "int \fBMaxWhoResults\fP" .PP -Definition at line 100 of file modules.cpp. +Definition at line 88 of file modules.cpp. .SS "\fBserverrec\fP* \fBme\fP[32]" .PP -Definition at line 115 of file modules.cpp. +Definition at line 103 of file modules.cpp. .SS "int \fBMODCOUNT\fP = -1" .PP -Definition at line 1067 of file modules.cpp. +Definition at line 996 of file modules.cpp. .SS "std::vector \fBmodule_names\fP" .PP -Definition at line 104 of file modules.cpp. +Definition at line 92 of file modules.cpp. .SS "std::vector<\fBModule\fP*> modules" .PP -Definition at line 74 of file modules.cpp. +Definition at line 62 of file modules.cpp. .SS "\fBfile_cache\fP \fBMOTD\fP" .PP -Definition at line 196 of file modules.cpp. +Definition at line 120 of file modules.cpp. .SS "char \fBmotd\fP[MAXBUF]" .PP -Definition at line 88 of file modules.cpp. +Definition at line 76 of file modules.cpp. .SS "time_t \fBnb_start\fP" .PP -Definition at line 101 of file modules.cpp. +Definition at line 89 of file modules.cpp. .SS "int \fBNetBufferSize\fP" .PP -Definition at line 99 of file modules.cpp. +Definition at line 87 of file modules.cpp. .SS "char \fBNetwork\fP[MAXBUF]" .PP -Definition at line 81 of file modules.cpp. +Definition at line 69 of file modules.cpp. .SS "int \fBportCount\fP" .PP -Definition at line 107 of file modules.cpp. +Definition at line 95 of file modules.cpp. .SS "int \fBports\fP[MAXSOCKS]" .PP -Definition at line 109 of file modules.cpp. +Definition at line 97 of file modules.cpp. .SS "char \fBPrefixQuit\fP[MAXBUF]" .PP -Definition at line 91 of file modules.cpp. +Definition at line 79 of file modules.cpp. .SS "char \fBrestartpass\fP[MAXBUF]" .PP -Definition at line 87 of file modules.cpp. +Definition at line 75 of file modules.cpp. .SS "\fBfile_cache\fP \fBRULES\fP" .PP -Definition at line 197 of file modules.cpp. +Definition at line 121 of file modules.cpp. .SS "char \fBrules\fP[MAXBUF]" .PP -Definition at line 89 of file modules.cpp. +Definition at line 77 of file modules.cpp. .SS "char \fBServerDesc\fP[MAXBUF]" .PP -Definition at line 82 of file modules.cpp. +Definition at line 70 of file modules.cpp. .SS "char \fBServerName\fP[MAXBUF]" .PP -Definition at line 80 of file modules.cpp. +Definition at line 68 of file modules.cpp. .SS "int \fBSERVERportCount\fP" .PP -Definition at line 108 of file modules.cpp. +Definition at line 96 of file modules.cpp. .SS "time_t \fBstartup_time\fP" .PP -Definition at line 98 of file modules.cpp. +Definition at line 86 of file modules.cpp. .SS "time_t \fBTIME\fP" .PP -Definition at line 77 of file modules.cpp. +Definition at line 65 of file modules.cpp. .SS "\fBwhowas_hash\fP \fBwhowas\fP" .PP -Definition at line 194 of file modules.cpp. +Definition at line 118 of file modules.cpp. .SS "int \fBWHOWAS_MAX\fP" .PP -Definition at line 96 of file modules.cpp. +Definition at line 84 of file modules.cpp. .SS "int \fBWHOWAS_STALE\fP" .PP -Definition at line 95 of file modules.cpp. +Definition at line 83 of file modules.cpp. .SH "Author" .PP Generated automatically by Doxygen for InspIRCd from the source code. diff --git a/docs/man/man3/modules.h.3 b/docs/man/man3/modules.h.3 index ac7e9ea35..38bf3733a 100644 --- a/docs/man/man3/modules.h.3 +++ b/docs/man/man3/modules.h.3 @@ -1,4 +1,4 @@ -.TH "modules.h" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "modules.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -230,22 +230,22 @@ Referenced by Module::OnAccessCheck(). Definition at line 38 of file modules.h. .SS "#define CONF_FILE_NOT_FOUND 0x000200" .PP -Definition at line 1138 of file modules.h. +Definition at line 1141 of file modules.h. .PP Referenced by ConfigReader::ConfigReader(). .SS "#define CONF_NOT_A_NUMBER 0x000010" .PP -Definition at line 1135 of file modules.h. +Definition at line 1138 of file modules.h. .PP Referenced by ConfigReader::ReadInteger(). .SS "#define CONF_NOT_UNSIGNED 0x000080" .PP -Definition at line 1136 of file modules.h. +Definition at line 1139 of file modules.h. .PP Referenced by ConfigReader::ReadInteger(). .SS "#define CONF_VALUE_NOT_FOUND 0x000100" .PP -Definition at line 1137 of file modules.h. +Definition at line 1140 of file modules.h. .PP Referenced by ConfigReader::ReadFlag(), ConfigReader::ReadInteger(), and ConfigReader::ReadValue(). .SS "#define DEBUG 10" @@ -333,7 +333,7 @@ Low level definition of a \fBFileReader\fP classes file cache area. Definition a Referenced by FileReader::FileReader(), and FileReader::LoadFile(). .SS "typedef DLLFactory<\fBModuleFactory\fP> \fBircd_module\fP" .PP -Definition at line 1304 of file modules.h. +Definition at line 1307 of file modules.h. .SS "typedef \fBfile_cache\fP \fBstring_list\fP" .PP Definition at line 68 of file modules.h. diff --git a/docs/man/man3/nspace.3 b/docs/man/man3/nspace.3 index 736e4cfb7..cbe375840 100644 --- a/docs/man/man3/nspace.3 +++ b/docs/man/man3/nspace.3 @@ -1,4 +1,4 @@ -.TH "nspace" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "nspace" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/nspace_nspace_hash_ in_addr _.3 b/docs/man/man3/nspace_nspace_hash_ in_addr _.3 index 43b548dd9..a21b8fa75 100644 --- a/docs/man/man3/nspace_nspace_hash_ in_addr _.3 +++ b/docs/man/man3/nspace_nspace_hash_ in_addr _.3 @@ -1,4 +1,4 @@ -.TH "nspace::nspace::hash< in_addr >" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "nspace::nspace::hash< in_addr >" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -6,6 +6,8 @@ nspace::nspace::hash< in_addr > \- .SH SYNOPSIS .br .PP +\fC#include \fP +.PP .SS "Public Member Functions" .in +1c @@ -18,17 +20,8 @@ nspace::nspace::hash< in_addr > \- .SH "Member Function Documentation" .PP -.SS "size_t nspace::hash< in_addr >::operator() (const struct in_addr & a) const\fC [inline]\fP" -.PP -Definition at line 129 of file modules.cpp. +.SS "size_t nspace::hash< in_addr >::operator() (const struct in_addr & a) const" .PP -.nf -130 { -131 size_t q; -132 memcpy(&q,&a,sizeof(size_t)); -133 return q; -134 } -.fi .SH "Author" diff --git a/docs/man/man3/nspace_nspace_hash_ string _.3 b/docs/man/man3/nspace_nspace_hash_ string _.3 index ba9c5a6f5..58c32c257 100644 --- a/docs/man/man3/nspace_nspace_hash_ string _.3 +++ b/docs/man/man3/nspace_nspace_hash_ string _.3 @@ -1,4 +1,4 @@ -.TH "nspace::nspace::hash< string >" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "nspace::nspace::hash< string >" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -6,6 +6,8 @@ nspace::nspace::hash< string > \- .SH SYNOPSIS .br .PP +\fC#include \fP +.PP .SS "Public Member Functions" .in +1c @@ -18,19 +20,8 @@ nspace::nspace::hash< string > \- .SH "Member Function Documentation" .PP -.SS "size_t nspace::hash< string >::operator() (const string & s) const\fC [inline]\fP" -.PP -Definition at line 142 of file modules.cpp. +.SS "size_t nspace::hash< string >::operator() (const string & s) const" .PP -.nf -143 { -144 char a[MAXBUF]; -145 static struct hash strhash; -146 strlcpy(a,s.c_str(),MAXBUF); -147 strlower(a); -148 return strhash(a); -149 } -.fi .SH "Author" diff --git a/docs/man/man3/serverrec.3 b/docs/man/man3/serverrec.3 index 8f2ed614c..6dd9d4387 100644 --- a/docs/man/man3/serverrec.3 +++ b/docs/man/man3/serverrec.3 @@ -1,4 +1,4 @@ -.TH "serverrec" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "serverrec" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -82,51 +82,51 @@ A class that defines the local server or a remote server. Definition at line 30 .PP .SS "serverrec::serverrec ()" .PP -Constructor. Definition at line 26 of file servers.cpp. +Constructor. Definition at line 27 of file servers.cpp. .PP References connection::fd, hops_away, jupiter, connection::lastping, name, nickserv, opercount, pingtime, connection::signon, sync_soon, TIME, usercount, usercount_i, and version. .PP .nf -27 { -28 strlcpy(name,'',256); -29 pingtime = 0; -30 lastping = TIME; -31 usercount_i = usercount = opercount = version = 0; -32 hops_away = 1; -33 signon = TIME; -34 jupiter = false; -35 fd = 0; -36 sync_soon = false; -37 strlcpy(nickserv,'',NICKMAX); -38 } +28 { +29 strlcpy(name,'',256); +30 pingtime = 0; +31 lastping = TIME; +32 usercount_i = usercount = opercount = version = 0; +33 hops_away = 1; +34 signon = TIME; +35 jupiter = false; +36 fd = 0; +37 sync_soon = false; +38 strlcpy(nickserv,'',NICKMAX); +39 } .fi .SS "serverrec::serverrec (char * n, long ver, bool jupe)" .PP -Constructor which initialises some of the main variables. Definition at line 45 of file servers.cpp. +Constructor which initialises some of the main variables. Definition at line 46 of file servers.cpp. .PP References connection::fd, hops_away, jupiter, connection::lastping, name, nickserv, opercount, connection::signon, sync_soon, TIME, usercount, usercount_i, and version. .PP .nf -46 { -47 strlcpy(name,n,256); -48 lastping = TIME; -49 usercount_i = usercount = opercount = 0; -50 version = ver; -51 hops_away = 1; -52 signon = TIME; -53 jupiter = jupe; -54 fd = 0; -55 sync_soon = false; -56 strlcpy(nickserv,'',NICKMAX); -57 } +47 { +48 strlcpy(name,n,256); +49 lastping = TIME; +50 usercount_i = usercount = opercount = 0; +51 version = ver; +52 hops_away = 1; +53 signon = TIME; +54 jupiter = jupe; +55 fd = 0; +56 sync_soon = false; +57 strlcpy(nickserv,'',NICKMAX); +58 } .fi .SS "serverrec::~\fBserverrec\fP ()" .PP -Destructor. Definition at line 41 of file servers.cpp. +Destructor. Definition at line 42 of file servers.cpp. .PP .nf -42 { -43 } +43 { +44 } .fi .SH "Member Data Documentation" .PP diff --git a/docs/man/man3/servers.cpp.3 b/docs/man/man3/servers.cpp.3 index e02fb0eb2..af036f7c6 100644 --- a/docs/man/man3/servers.cpp.3 +++ b/docs/man/man3/servers.cpp.3 @@ -1,4 +1,4 @@ -.TH "servers.cpp" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "servers.cpp" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -18,6 +18,8 @@ servers.cpp \- .br \fC#include 'inspstring.h'\fP .br +\fC#include 'helperfuncs.h'\fP +.br .SS "Variables" @@ -30,7 +32,7 @@ servers.cpp \- .PP .SS "time_t \fBTIME\fP" .PP -Definition at line 24 of file servers.cpp. +Definition at line 25 of file servers.cpp. .SH "Author" .PP Generated automatically by Doxygen for InspIRCd from the source code. diff --git a/docs/man/man3/servers.h.3 b/docs/man/man3/servers.h.3 index cb3f26dd6..a048d2a6e 100644 --- a/docs/man/man3/servers.h.3 +++ b/docs/man/man3/servers.h.3 @@ -1,4 +1,4 @@ -.TH "servers.h" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "servers.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/std.3 b/docs/man/man3/std.3 index 77d52825a..6d1a2ae72 100644 --- a/docs/man/man3/std.3 +++ b/docs/man/man3/std.3 @@ -1,4 +1,4 @@ -.TH "std" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "std" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/std_char_traits.3 b/docs/man/man3/std_char_traits.3 new file mode 100644 index 000000000..64a98bafc --- /dev/null +++ b/docs/man/man3/std_char_traits.3 @@ -0,0 +1,15 @@ +.TH "std::char_traits" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- +.ad l +.nh +.SH NAME +std::char_traits \- +.SH SYNOPSIS +.br +.PP +Inherited by \fBirc::irc_char_traits\fP. +.PP + + +.SH "Author" +.PP +Generated automatically by Doxygen for InspIRCd from the source code. diff --git a/docs/man/man3/ucrec.3 b/docs/man/man3/ucrec.3 index 986d2ba8f..efe396234 100644 --- a/docs/man/man3/ucrec.3 +++ b/docs/man/man3/ucrec.3 @@ -1,4 +1,4 @@ -.TH "ucrec" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "ucrec" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/man/man3/userrec.3 b/docs/man/man3/userrec.3 index 3afc6d02c..61e70f590 100644 --- a/docs/man/man3/userrec.3 +++ b/docs/man/man3/userrec.3 @@ -1,4 +1,4 @@ -.TH "userrec" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "userrec" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -77,6 +77,10 @@ Inherits \fBconnection\fP. .RI "void \fBFlushWriteBuf\fP ()" .br .RI "\fIFlushes as much of the user's buffer to the file descriptor as possible. \fP" +.ti -1c +.RI "\fBInvitedList\fP * \fBGetInviteList\fP ()" +.br +.RI "\fIReturns the list of channels this user has been invited to but has not yet joined. \fP" .in -1c .SS "Public Attributes" @@ -189,40 +193,40 @@ Definition at line 108 of file users.h. .PP .SS "userrec::userrec ()" .PP -Definition at line 28 of file users.cpp. +Definition at line 29 of file users.cpp. .PP References awaymsg, connection::bytes_in, connection::bytes_out, ucrec::channel, chans, connection::cmds_in, connection::cmds_out, dhost, dns_done, connection::fd, flood, fullname, connection::haspassed, connection::host, ident, connection::idle_lastmsg, invites, connection::ip, connection::lastping, lines_in, modes, nick, connection::nping, oper, connection::port, recvq, connection::registered, reset_due, result, sendq, server, connection::signon, TIME, timeout, and ucrec::uc_modes. .PP .nf -29 { -30 // the PROPER way to do it, AVOID bzero at *ALL* costs -31 strcpy(nick,''); -32 strcpy(ip,'127.0.0.1'); -33 timeout = 0; -34 strcpy(ident,''); -35 strcpy(host,''); -36 strcpy(dhost,''); -37 strcpy(fullname,''); -38 strcpy(modes,''); -39 strcpy(server,''); -40 strcpy(awaymsg,''); -41 strcpy(oper,''); -42 reset_due = TIME; -43 lines_in = 0; -44 fd = lastping = signon = idle_lastmsg = nping = registered = 0; -45 flood = port = bytes_in = bytes_out = cmds_in = cmds_out = 0; -46 haspassed = false; -47 dns_done = false; -48 recvq = ''; -49 sendq = ''; -50 strcpy(result,''); -51 for (int i = 0; i < MAXCHANS; i++) -52 { -53 this->chans[i].channel = NULL; -54 this->chans[i].uc_modes = 0; -55 } -56 invites.clear(); -57 } +30 { +31 // the PROPER way to do it, AVOID bzero at *ALL* costs +32 strcpy(nick,''); +33 strcpy(ip,'127.0.0.1'); +34 timeout = 0; +35 strcpy(ident,''); +36 strcpy(host,''); +37 strcpy(dhost,''); +38 strcpy(fullname,''); +39 strcpy(modes,''); +40 strcpy(server,''); +41 strcpy(awaymsg,''); +42 strcpy(oper,''); +43 reset_due = TIME; +44 lines_in = 0; +45 fd = lastping = signon = idle_lastmsg = nping = registered = 0; +46 flood = port = bytes_in = bytes_out = cmds_in = cmds_out = 0; +47 haspassed = false; +48 dns_done = false; +49 recvq = ''; +50 sendq = ''; +51 strcpy(result,''); +52 for (int i = 0; i < MAXCHANS; i++) +53 { +54 this->chans[i].channel = NULL; +55 this->chans[i].uc_modes = 0; +56 } +57 invites.clear(); +58 } .fi .SS "virtual userrec::~\fBuserrec\fP ()\fC [inline, virtual]\fP" .PP @@ -235,305 +239,316 @@ Definition at line 222 of file users.h. .PP .SS "bool userrec::AddBuffer (std::string a)" .PP -This method adds data to the buffer of the user. The buffer can grow to any size within limits of the available memory, managed by the size of a std::string, however if any individual line in the buffer grows over 600 bytes in length (which is 88 chars over the RFC-specified limit per line) then the method will return false and the text will not be inserted.Definition at line 169 of file users.cpp. +This method adds data to the buffer of the user. The buffer can grow to any size within limits of the available memory, managed by the size of a std::string, however if any individual line in the buffer grows over 600 bytes in length (which is 88 chars over the RFC-specified limit per line) then the method will return false and the text will not be inserted.Definition at line 175 of file users.cpp. .PP References recvq, recvqmax, and SetWriteError(). .PP .nf -170 { -171 std::string b = ''; -172 for (int i = 0; i < a.length(); i++) -173 if ((a[i] != '\r') && (a[i] != '\0') && (a[i] != 7)) -174 b = b + a[i]; -175 std::stringstream stream(recvq); -176 stream << b; -177 recvq = stream.str(); -178 int i = 0; -179 // count the size of the first line in the buffer. -180 while (i < recvq.length()) -181 { -182 if (recvq[i++] == '\n') -183 break; -184 } -185 if (recvq.length() > this->recvqmax) -186 { -187 this->SetWriteError('RecvQ exceeded'); -188 WriteOpers('*** User %s RecvQ of %d exceeds connect class maximum of %d',this->nick,recvq.length(),this->recvqmax); -189 } -190 // return false if we've had more than 600 characters WITHOUT -191 // a carriage return (this is BAD, drop the socket) -192 return (i < 600); -193 } +176 { +177 std::string b = ''; +178 for (int i = 0; i < a.length(); i++) +179 if ((a[i] != '\r') && (a[i] != '\0') && (a[i] != 7)) +180 b = b + a[i]; +181 std::stringstream stream(recvq); +182 stream << b; +183 recvq = stream.str(); +184 int i = 0; +185 // count the size of the first line in the buffer. +186 while (i < recvq.length()) +187 { +188 if (recvq[i++] == '\n') +189 break; +190 } +191 if (recvq.length() > this->recvqmax) +192 { +193 this->SetWriteError('RecvQ exceeded'); +194 WriteOpers('*** User %s RecvQ of %d exceeds connect class maximum of %d',this->nick,recvq.length(),this->recvqmax); +195 } +196 // return false if we've had more than 600 characters WITHOUT +197 // a carriage return (this is BAD, drop the socket) +198 return (i < 600); +199 } .fi .SS "void userrec::AddWriteBuf (std::string data)" .PP -Adds to the user's write buffer. You may add any amount of text up to this users sendq value, if you exceed the sendq value, \fBSetWriteError()\fP will be called to set the users error string to 'SendQ exceeded', and further buffer adds will be dropped.Definition at line 225 of file users.cpp. +Adds to the user's write buffer. You may add any amount of text up to this users sendq value, if you exceed the sendq value, \fBSetWriteError()\fP will be called to set the users error string to 'SendQ exceeded', and further buffer adds will be dropped.Definition at line 231 of file users.cpp. .PP References GetWriteError(), sendq, sendqmax, and SetWriteError(). .PP .nf -226 { -227 if (this->GetWriteError() != '') -228 return; -229 if (sendq.length() + data.length() > this->sendqmax) -230 { -231 WriteOpers('*** User %s SendQ of %d exceeds connect class maximum of %d',this->nick,sendq.length() + data.length(),this->sendqmax); -232 this->SetWriteError('SendQ exceeded'); -233 return; -234 } -235 std::stringstream stream; -236 stream << sendq << data; -237 sendq = stream.str(); -238 } +232 { +233 if (this->GetWriteError() != '') +234 return; +235 if (sendq.length() + data.length() > this->sendqmax) +236 { +237 WriteOpers('*** User %s SendQ of %d exceeds connect class maximum of %d',this->nick,sendq.length() + data.length(),this->sendqmax); +238 this->SetWriteError('SendQ exceeded'); +239 return; +240 } +241 std::stringstream stream; +242 stream << sendq << data; +243 sendq = stream.str(); +244 } .fi .SS "bool userrec::BufferIsReady ()" .PP -This method returns true if the buffer contains at least one carriage return character (e.g. one complete line may be read)Definition at line 195 of file users.cpp. +This method returns true if the buffer contains at least one carriage return character (e.g. one complete line may be read)Definition at line 201 of file users.cpp. .PP References recvq. .PP .nf -196 { -197 for (int i = 0; i < recvq.length(); i++) -198 if (recvq[i] == '\n') -199 return true; -200 return false; -201 } +202 { +203 for (int i = 0; i < recvq.length(); i++) +204 if (recvq[i] == '\n') +205 return true; +206 return false; +207 } .fi .SS "void userrec::ClearBuffer ()" .PP -This function clears the entire buffer by setting it to an empty string. Definition at line 203 of file users.cpp. +This function clears the entire buffer by setting it to an empty string. Definition at line 209 of file users.cpp. .PP References recvq. .PP Referenced by Server::PseudoToUser(), and Server::UserToPseudo(). .PP .nf -204 { -205 recvq = ''; -206 } +210 { +211 recvq = ''; +212 } .fi .SS "void userrec::FlushWriteBuf ()" .PP -Flushes as much of the user's buffer to the file descriptor as possible. This function may not always flush the entire buffer, rather instead as much of it as it possibly can. If the send() call fails to send the entire buffer, the buffer position is advanced forwards and the rest of the data sent at the next call to this method.Definition at line 241 of file users.cpp. +Flushes as much of the user's buffer to the file descriptor as possible. This function may not always flush the entire buffer, rather instead as much of it as it possibly can. If the send() call fails to send the entire buffer, the buffer position is advanced forwards and the rest of the data sent at the next call to this method.Definition at line 247 of file users.cpp. .PP References connection::bytes_out, connection::cmds_out, sendq, and SetWriteError(). .PP .nf -242 { -243 if (sendq.length()) -244 { -245 char* tb = (char*)this->sendq.c_str(); -246 int n_sent = write(this->fd,tb,this->sendq.length()); -247 if (n_sent == -1) -248 { -249 this->SetWriteError(strerror(errno)); -250 } -251 else -252 { -253 // advance the queue -254 tb += n_sent; -255 this->sendq = tb; -256 // update the user's stats counters -257 this->bytes_out += n_sent; -258 this->cmds_out++; -259 } -260 } -261 } +248 { +249 if (sendq.length()) +250 { +251 char* tb = (char*)this->sendq.c_str(); +252 int n_sent = write(this->fd,tb,this->sendq.length()); +253 if (n_sent == -1) +254 { +255 this->SetWriteError(strerror(errno)); +256 } +257 else +258 { +259 // advance the queue +260 tb += n_sent; +261 this->sendq = tb; +262 // update the user's stats counters +263 this->bytes_out += n_sent; +264 this->cmds_out++; +265 } +266 } +267 } .fi .SS "std::string userrec::GetBuffer ()" .PP -This method returns the first available string at the tail end of the buffer and advances the tail end of the buffer past the string. This means it is a one way operation in a similar way to strtok(), and multiple calls return multiple lines if they are available. The results of this function if there are no lines to be read are unknown, always use \fBBufferIsReady()\fP to check if it is ok to read the buffer before calling \fBGetBuffer()\fP.Definition at line 208 of file users.cpp. +This method returns the first available string at the tail end of the buffer and advances the tail end of the buffer past the string. This means it is a one way operation in a similar way to strtok(), and multiple calls return multiple lines if they are available. The results of this function if there are no lines to be read are unknown, always use \fBBufferIsReady()\fP to check if it is ok to read the buffer before calling \fBGetBuffer()\fP.Definition at line 214 of file users.cpp. .PP References recvq. .PP .nf -209 { -210 if (recvq == '') -211 return ''; -212 char* line = (char*)recvq.c_str(); -213 std::string ret = ''; -214 while ((*line != '\n') && (strlen(line))) -215 { -216 ret = ret + *line; -217 line++; -218 } -219 if ((*line == '\n') || (*line == '\r')) -220 line++; -221 recvq = line; -222 return ret; -223 } +215 { +216 if (recvq == '') +217 return ''; +218 char* line = (char*)recvq.c_str(); +219 std::string ret = ''; +220 while ((*line != '\n') && (strlen(line))) +221 { +222 ret = ret + *line; +223 line++; +224 } +225 if ((*line == '\n') || (*line == '\r')) +226 line++; +227 recvq = line; +228 return ret; +229 } .fi .SS "char * userrec::GetFullHost ()\fC [virtual]\fP" .PP -Returns the full displayed host of the user This member function returns the hostname of the user as seen by other users on the server, in nick!identhost form. Definition at line 61 of file users.cpp. +Returns the full displayed host of the user This member function returns the hostname of the user as seen by other users on the server, in nick!identhost form. Definition at line 62 of file users.cpp. .PP References dhost, ident, nick, and result. .PP .nf -62 { -63 snprintf(result,MAXBUF,'%s!%s@%s',nick,ident,dhost); -64 return result; -65 } +63 { +64 snprintf(result,MAXBUF,'%s!%s@%s',nick,ident,dhost); +65 return result; +66 } .fi .SS "char * userrec::GetFullRealHost ()\fC [virtual]\fP" .PP -Returns the full real host of the user This member function returns the hostname of the user as seen by other users on the server, in nick!identhost form. If any form of hostname cloaking is in operation, e.g. through a module, then this method will ignore it and return the true hostname.Definition at line 68 of file users.cpp. +Returns the full real host of the user This member function returns the hostname of the user as seen by other users on the server, in nick!identhost form. If any form of hostname cloaking is in operation, e.g. through a module, then this method will ignore it and return the true hostname.Definition at line 69 of file users.cpp. .PP References connection::host, ident, nick, and result. .PP .nf -69 { -70 snprintf(result,MAXBUF,'%s!%s@%s',nick,ident,host); -71 return result; -72 } +70 { +71 snprintf(result,MAXBUF,'%s!%s@%s',nick,ident,host); +72 return result; +73 } +.fi +.SS "\fBInvitedList\fP * userrec::GetInviteList ()" +.PP +Returns the list of channels this user has been invited to but has not yet joined. Definition at line 89 of file users.cpp. +.PP +References InvitedList, and invites. +.PP +.nf +90 { +91 return &invites; +92 } .fi .SS "std::string userrec::GetWriteError ()" .PP -Returns the write error which last occured on this connection or an empty string if none occured. Definition at line 271 of file users.cpp. +Returns the write error which last occured on this connection or an empty string if none occured. Definition at line 277 of file users.cpp. .PP References WriteError. .PP Referenced by AddWriteBuf(). .PP .nf -272 { -273 return this->WriteError; -274 } +278 { +279 return this->WriteError; +280 } .fi .SS "bool userrec::HasPermission (char * command)" .PP -Returns true or false for if a user can execute a privilaged oper command. This is done by looking up their oper type from \fBuserrec::oper\fP, then referencing this to their oper classes and checking the commands they can execute.Definition at line 117 of file users.cpp. +Returns true or false for if a user can execute a privilaged oper command. This is done by looking up their oper type from \fBuserrec::oper\fP, then referencing this to their oper classes and checking the commands they can execute.Definition at line 123 of file users.cpp. .PP References config_f, and DEBUG. .PP .nf -118 { -119 char TypeName[MAXBUF],Classes[MAXBUF],ClassName[MAXBUF],CommandList[MAXBUF]; -120 char* mycmd; -121 char* savept; -122 char* savept2; -123 -124 // are they even an oper at all? -125 if (strchr(this->modes,'o')) -126 { -127 log(DEBUG,'*** HasPermission: %s is an oper',this->nick); -128 for (int j =0; j < ConfValueEnum('type',&config_f); j++) -129 { -130 ConfValue('type','name',j,TypeName,&config_f); -131 if (!strcmp(TypeName,this->oper)) -132 { -133 log(DEBUG,'*** HasPermission: %s is an oper of type '%s'',this->nick,this->oper); -134 ConfValue('type','classes',j,Classes,&config_f); -135 char* myclass = strtok_r(Classes,' ',&savept); -136 while (myclass) -137 { -138 log(DEBUG,'*** HasPermission: checking classtype '%s'',myclass); -139 for (int k =0; k < ConfValueEnum('class',&config_f); k++) -140 { -141 ConfValue('class','name',k,ClassName,&config_f); -142 if (!strcmp(ClassName,myclass)) -143 { -144 ConfValue('class','commands',k,CommandList,&config_f); -145 log(DEBUG,'*** HasPermission: found class named %s with commands: '%s'',ClassName,CommandList); -146 -147 -148 mycmd = strtok_r(CommandList,' ',&savept2); -149 while (mycmd) -150 { -151 if (!strcasecmp(mycmd,command)) -152 { -153 log(DEBUG,'*** Command %s found, returning true',command); -154 return true; -155 } -156 mycmd = strtok_r(NULL,' ',&savept2); -157 } -158 } -159 } -160 myclass = strtok_r(NULL,' ',&savept); -161 } -162 } -163 } -164 } -165 return false; -166 } +124 { +125 char TypeName[MAXBUF],Classes[MAXBUF],ClassName[MAXBUF],CommandList[MAXBUF]; +126 char* mycmd; +127 char* savept; +128 char* savept2; +129 +130 // are they even an oper at all? +131 if (strchr(this->modes,'o')) +132 { +133 log(DEBUG,'*** HasPermission: %s is an oper',this->nick); +134 for (int j =0; j < ConfValueEnum('type',&config_f); j++) +135 { +136 ConfValue('type','name',j,TypeName,&config_f); +137 if (!strcmp(TypeName,this->oper)) +138 { +139 log(DEBUG,'*** HasPermission: %s is an oper of type '%s'',this->nick,this->oper); +140 ConfValue('type','classes',j,Classes,&config_f); +141 char* myclass = strtok_r(Classes,' ',&savept); +142 while (myclass) +143 { +144 log(DEBUG,'*** HasPermission: checking classtype '%s'',myclass); +145 for (int k =0; k < ConfValueEnum('class',&config_f); k++) +146 { +147 ConfValue('class','name',k,ClassName,&config_f); +148 if (!strcmp(ClassName,myclass)) +149 { +150 ConfValue('class','commands',k,CommandList,&config_f); +151 log(DEBUG,'*** HasPermission: found class named %s with commands: '%s'',ClassName,CommandList); +152 +153 +154 mycmd = strtok_r(CommandList,' ',&savept2); +155 while (mycmd) +156 { +157 if (!strcasecmp(mycmd,command)) +158 { +159 log(DEBUG,'*** Command %s found, returning true',command); +160 return true; +161 } +162 mycmd = strtok_r(NULL,' ',&savept2); +163 } +164 } +165 } +166 myclass = strtok_r(NULL,' ',&savept); +167 } +168 } +169 } +170 } +171 return false; +172 } .fi .SS "void userrec::InviteTo (char * channel)\fC [virtual]\fP" .PP -Adds a channel to a users invite list (invites them to a channel). Definition at line 88 of file users.cpp. +Adds a channel to a users invite list (invites them to a channel). Definition at line 94 of file users.cpp. .PP References Invited::channel, and invites. .PP .nf -89 { -90 Invited i; -91 strlcpy(i.channel,channel,CHANMAX); -92 invites.push_back(i); -93 } +95 { +96 Invited i; +97 strlcpy(i.channel,channel,CHANMAX); +98 invites.push_back(i); +99 } .fi .SS "bool userrec::IsInvited (char * channel)\fC [virtual]\fP" .PP -Returns true if a user is invited to a channel. Definition at line 74 of file users.cpp. +Returns true if a user is invited to a channel. Definition at line 75 of file users.cpp. .PP References invites. .PP .nf -75 { -76 for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) -77 { -78 if (i->channel) { -79 if (!strcasecmp(i->channel,channel)) -80 { -81 return true; -82 } -83 } -84 } -85 return false; -86 } +76 { +77 for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) +78 { +79 if (i->channel) { +80 if (!strcasecmp(i->channel,channel)) +81 { +82 return true; +83 } +84 } +85 } +86 return false; +87 } .fi .SS "void userrec::RemoveInvite (char * channel)\fC [virtual]\fP" .PP -Removes a channel from a users invite list. This member function is called on successfully joining an invite only channel to which the user has previously been invited, to clear the invitation.Definition at line 95 of file users.cpp. +Removes a channel from a users invite list. This member function is called on successfully joining an invite only channel to which the user has previously been invited, to clear the invitation.Definition at line 101 of file users.cpp. .PP References DEBUG, and invites. .PP .nf -96 { -97 log(DEBUG,'Removing invites'); -98 if (channel) -99 { -100 if (invites.size()) -101 { -102 for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) -103 { -104 if (i->channel) -105 { -106 if (!strcasecmp(i->channel,channel)) -107 { -108 invites.erase(i); -109 return; -110 } -111 } -112 } -113 } -114 } -115 } +102 { +103 log(DEBUG,'Removing invites'); +104 if (channel) +105 { +106 if (invites.size()) +107 { +108 for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) +109 { +110 if (i->channel) +111 { +112 if (!strcasecmp(i->channel,channel)) +113 { +114 invites.erase(i); +115 return; +116 } +117 } +118 } +119 } +120 } +121 } .fi .SS "void userrec::SetWriteError (std::string error)" .PP -Sets the write error for a connection. This is done because the actual disconnect of a client may occur at an inopportune time such as half way through /LIST output. The WriteErrors of clients are checked at a more ideal time (in the mainloop) and errored clients purged.Definition at line 263 of file users.cpp. +Sets the write error for a connection. This is done because the actual disconnect of a client may occur at an inopportune time such as half way through /LIST output. The WriteErrors of clients are checked at a more ideal time (in the mainloop) and errored clients purged.Definition at line 269 of file users.cpp. .PP References DEBUG, and WriteError. .PP Referenced by AddBuffer(), AddWriteBuf(), and FlushWriteBuf(). .PP .nf -264 { -265 log(DEBUG,'Setting error string for %s to '%s'',this->nick,error.c_str()); -266 // don't try to set the error twice, its already set take the first string. -267 if (this->WriteError == '') -268 this->WriteError = error; -269 } +270 { +271 log(DEBUG,'Setting error string for %s to '%s'',this->nick,error.c_str()); +272 // don't try to set the error twice, its already set take the first string. +273 if (this->WriteError == '') +274 this->WriteError = error; +275 } .fi .SH "Member Data Documentation" .PP @@ -576,7 +591,7 @@ Referenced by GetFullHost(), GetFullRealHost(), Server::PseudoToUser(), userrec( .PP A list of channels the user has a pending invite to. Definition at line 114 of file users.h. .PP -Referenced by InviteTo(), IsInvited(), RemoveInvite(), and userrec(). +Referenced by GetInviteList(), InviteTo(), IsInvited(), RemoveInvite(), and userrec(). .SS "int \fBuserrec::lines_in\fP" .PP Flood counters. Definition at line 204 of file users.h. diff --git a/docs/man/man3/users.cpp.3 b/docs/man/man3/users.cpp.3 index 72cf2e6fb..e8d74655d 100644 --- a/docs/man/man3/users.cpp.3 +++ b/docs/man/man3/users.cpp.3 @@ -1,4 +1,4 @@ -.TH "users.cpp" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "users.cpp" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -18,6 +18,8 @@ users.cpp \- .br \fC#include 'inspstring.h'\fP .br +\fC#include 'helperfuncs.h'\fP +.br .SS "Variables" @@ -33,10 +35,10 @@ users.cpp \- .PP .SS "std::stringstream \fBconfig_f\fP" .PP -Definition at line 24 of file users.cpp. +Definition at line 25 of file users.cpp. .SS "time_t \fBTIME\fP" .PP -Definition at line 26 of file users.cpp. +Definition at line 27 of file users.cpp. .SH "Author" .PP Generated automatically by Doxygen for InspIRCd from the source code. diff --git a/docs/man/man3/users.h.3 b/docs/man/man3/users.h.3 index ea393b917..234320343 100644 --- a/docs/man/man3/users.h.3 +++ b/docs/man/man3/users.h.3 @@ -1,4 +1,4 @@ -.TH "users.h" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "users.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME @@ -99,6 +99,8 @@ Holds a complete list of all allow and deny tags from the configuration file (co .SS "typedef std::vector<\fBInvited\fP> \fBInvitedList\fP" .PP Holds a complete list of all channels to which a user has been invited and has not yet joined. Definition at line 94 of file users.h. +.PP +Referenced by userrec::GetInviteList(). .SH "Author" .PP Generated automatically by Doxygen for InspIRCd from the source code. diff --git a/docs/man/man3/xline.h.3 b/docs/man/man3/xline.h.3 index 49c111470..65e55d871 100644 --- a/docs/man/man3/xline.h.3 +++ b/docs/man/man3/xline.h.3 @@ -1,4 +1,4 @@ -.TH "xline.h" 3 "13 May 2005" "InspIRCd" \" -*- nroff -*- +.TH "xline.h" 3 "15 May 2005" "InspIRCd" \" -*- nroff -*- .ad l .nh .SH NAME diff --git a/docs/module-doc/annotated.html b/docs/module-doc/annotated.html index ebb8d5dd2..c72a198b1 100644 --- a/docs/module-doc/annotated.html +++ b/docs/module-doc/annotated.html @@ -4,11 +4,12 @@ - +

InspIRCd Compound List

Here are the classes, structs, unions and interfaces with brief descriptions: + @@ -24,9 +25,10 @@ - + + @@ -39,7 +41,7 @@ - + @@ -47,7 +49,7 @@
AdminHolds /ADMIN data This class contains the admin details of the local server
BanItemA subclass of HostItem designed to hold channel bans (+b)
chanrecHolds all relevent information for a channel
char_traits
classbaseThe base class for all inspircd classes
command_tA structure that defines a command
ConfigReaderAllows reading of values from configuration files This class allows a module to read from either the main configuration file (inspircd.conf) or from a module-specified configuration file
FileReaderCaches a text file into memory and can be used to retrieve lines from it
GLineGLine class
HostItemHolds an entry for a ban list, exemption list, or invite list
InAddr_HashComp
InAddr_HashCompThis class returns true if two in_addr structs match
InvitedHolds a channel name to which a user has been invited
InviteItemA subclass of HostItem designed to hold channel invites (+I)
irc::irc_char_traitsThe irc_char_traits class is used for RFC-style comparison of strings
ircd_connectorEach connection has one or more of these each represents ONE outbound connection to another ircd so each inbound has multiple outbounds
KLineKLine class
ModeParameterHolds a custom parameter to a module-defined channel mode e.g
RequestUnicast message directed at a given module
ServerAllows server output and query functions This class contains methods which allow a module to query the state of the irc server, and produce output to users and other servers
serverrecA class that defines the local server or a remote server
StrHashComp
StrHashCompThis class returns true if two strings match
ucrecHolds a user's modes on a channel This class associates a users privilages with a channel by creating a pointer link between a userrec and chanrec class
userrecHolds all information about a user This class stores all information about a user connected to the irc server
VersionHolds a module's Version information The four members (set by the constructor only) indicate details as to the version number of a module
XLineXLine is the base class for ban lines such as G lines and K lines
ZLineZLine class
-
Generated on Fri May 13 15:49:18 2005 for InspIRCd by +
Generated on Sun May 15 17:02:54 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/base_8h-source.html b/docs/module-doc/base_8h-source.html index bd2bbd269..eb978937b 100644 --- a/docs/module-doc/base_8h-source.html +++ b/docs/module-doc/base_8h-source.html @@ -4,7 +4,7 @@ - +

base.h

Go to the documentation of this file.
00001 /*       +------------------------------------+
 00002  *       | Inspire Internet Relay Chat Daemon |
 00003  *       +------------------------------------+
@@ -55,7 +55,7 @@
 00079 
 00080 #endif
 00081 
-

Generated on Fri May 13 15:48:40 2005 for InspIRCd by +
Generated on Sun May 15 17:02:04 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/base_8h.html b/docs/module-doc/base_8h.html index eadd92c54..cf65200b7 100644 --- a/docs/module-doc/base_8h.html +++ b/docs/module-doc/base_8h.html @@ -4,7 +4,7 @@ - +

base.h File Reference

#include "inspircd_config.h"
#include <time.h>
#include <map>
@@ -61,7 +61,7 @@ This graph shows which files directly or indirectly include this file:

25 of file base.h. -
Generated on Fri May 13 15:48:43 2005 for InspIRCd by +
Generated on Sun May 15 17:02:09 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/channels_8cpp-source.html b/docs/module-doc/channels_8cpp-source.html index 19e1b9b67..c9117360a 100644 --- a/docs/module-doc/channels_8cpp-source.html +++ b/docs/module-doc/channels_8cpp-source.html @@ -4,7 +4,7 @@ - +

channels.cpp

Go to the documentation of this file.
00001 /*       +------------------------------------+
 00002  *       | Inspire Internet Relay Chat Daemon |
 00003  *       +------------------------------------+
@@ -26,216 +26,211 @@
 00019 #include "inspircd_util.h"
 00020 #include "inspircd_config.h"
 00021 #include <unistd.h>
-00022 #include <fcntl.h>
-00023 #include <sys/errno.h>
-00024 #include <sys/ioctl.h>
-00025 #include <sys/utsname.h>
-00026 #include <cstdio>
-00027 #include <time.h>
-00028 #include <string>
-00029 #ifdef GCC3
-00030 #include <ext/hash_map>
-00031 #else
-00032 #include <hash_map>
-00033 #endif
-00034 #include <map>
-00035 #include <sstream>
-00036 #include <vector>
-00037 #include <errno.h>
-00038 #include <deque>
-00039 #include <errno.h>
-00040 #include <unistd.h>
-00041 #include <sched.h>
-00042 #include "connection.h"
-00043 #include "users.h"
-00044 #include "servers.h"
-00045 #include "ctables.h"
-00046 #include "globals.h"
-00047 #include "modules.h"
-00048 #include "dynamic.h"
-00049 #include "wildcard.h"
-00050 #include "message.h"
-00051 #include "mode.h"
-00052 #include "xline.h"
-00053 #include "inspstring.h"
-00054 
-00055 #ifdef GCC3
-00056 #define nspace __gnu_cxx
-00057 #else
-00058 #define nspace std
-00059 #endif
-00060 
-00061 using namespace std;
-00062 
-00063 extern int MODCOUNT;
-00064 extern std::vector<Module*> modules;
-00065 extern std::vector<ircd_module*> factory;
-00066 
-00067 extern int LogLevel;
-00068 extern char ServerName[MAXBUF];
-00069 extern char Network[MAXBUF];
-00070 extern char ServerDesc[MAXBUF];
-00071 extern char AdminName[MAXBUF];
-00072 extern char AdminEmail[MAXBUF];
-00073 extern char AdminNick[MAXBUF];
-00074 extern char diepass[MAXBUF];
-00075 extern char restartpass[MAXBUF];
-00076 extern char motd[MAXBUF];
-00077 extern char rules[MAXBUF];
-00078 extern char list[MAXBUF];
-00079 extern char PrefixQuit[MAXBUF];
-00080 extern char DieValue[MAXBUF];
-00081 
-00082 extern int debugging;
-00083 extern int WHOWAS_STALE;
-00084 extern int WHOWAS_MAX;
-00085 extern int DieDelay;
-00086 extern time_t startup_time;
-00087 extern int NetBufferSize;
-00088 int MaxWhoResults;
-00089 extern time_t nb_start;
-00090 
-00091 extern std::vector<int> fd_reap;
-00092 extern std::vector<std::string> module_names;
-00093 
-00094 extern int boundPortCount;
-00095 extern int portCount;
-00096 extern int SERVERportCount;
-00097 extern int ports[MAXSOCKS];
-00098 extern int defaultRoute;
+00022 #include <sys/errno.h>
+00023 #include <sys/ioctl.h>
+00024 #include <sys/utsname.h>
+00025 #include <time.h>
+00026 #include <string>
+00027 #ifdef GCC3
+00028 #include <ext/hash_map>
+00029 #else
+00030 #include <hash_map>
+00031 #endif
+00032 #include <map>
+00033 #include <sstream>
+00034 #include <vector>
+00035 #include <deque>
+00036 #include "connection.h"
+00037 #include "users.h"
+00038 #include "servers.h"
+00039 #include "ctables.h"
+00040 #include "globals.h"
+00041 #include "modules.h"
+00042 #include "dynamic.h"
+00043 #include "wildcard.h"
+00044 #include "message.h"
+00045 #include "mode.h"
+00046 #include "xline.h"
+00047 #include "inspstring.h"
+00048 #include "helperfuncs.h"
+00049 
+00050 #ifdef GCC3
+00051 #define nspace __gnu_cxx
+00052 #else
+00053 #define nspace std
+00054 #endif
+00055 
+00056 using namespace std;
+00057 
+00058 extern int MODCOUNT;
+00059 extern std::vector<Module*> modules;
+00060 extern std::vector<ircd_module*> factory;
+00061 
+00062 extern int LogLevel;
+00063 extern char ServerName[MAXBUF];
+00064 extern char Network[MAXBUF];
+00065 extern char ServerDesc[MAXBUF];
+00066 extern char AdminName[MAXBUF];
+00067 extern char AdminEmail[MAXBUF];
+00068 extern char AdminNick[MAXBUF];
+00069 extern char diepass[MAXBUF];
+00070 extern char restartpass[MAXBUF];
+00071 extern char motd[MAXBUF];
+00072 extern char rules[MAXBUF];
+00073 extern char list[MAXBUF];
+00074 extern char PrefixQuit[MAXBUF];
+00075 extern char DieValue[MAXBUF];
+00076 
+00077 extern int debugging;
+00078 extern int WHOWAS_STALE;
+00079 extern int WHOWAS_MAX;
+00080 extern int DieDelay;
+00081 extern time_t startup_time;
+00082 extern int NetBufferSize;
+00083 int MaxWhoResults;
+00084 extern time_t nb_start;
+00085 
+00086 extern std::vector<int> fd_reap;
+00087 extern std::vector<std::string> module_names;
+00088 
+00089 extern int boundPortCount;
+00090 extern int portCount;
+00091 extern int SERVERportCount;
+00092 extern int ports[MAXSOCKS];
+00093 extern int defaultRoute;
+00094 
+00095 extern std::vector<long> auth_cookies;
+00096 extern std::stringstream config_f;
+00097 
+00098 extern serverrec* me[32];
 00099 
-00100 extern std::vector<long> auth_cookies;
-00101 extern std::stringstream config_f;
-00102 
-00103 extern serverrec* me[32];
-00104 
-00105 extern FILE *log_file;
-00106 
-00107 extern time_t TIME;
-00108 
-00109 using namespace std;
-00110 
-00111 std::vector<ModeParameter> custom_mode_params;
-00112 
-00113 chanrec::chanrec()
-00114 {
-00115         strcpy(name,"");
-00116         strcpy(custom_modes,"");
-00117         strcpy(topic,"");
-00118         strcpy(setby,"");
-00119         strcpy(key,"");
-00120         created = topicset = limit = 0;
-00121         binarymodes = 0;
-00122         internal_userlist.clear();
-00123 }
-00124 
-00125 void chanrec::SetCustomMode(char mode,bool mode_on)
-00126 {
-00127         if (mode_on) {
-00128                 static char m[3];
-00129                 m[0] = mode;
-00130                 m[1] = '\0';
-00131                 if (!strchr(this->custom_modes,mode))
-00132                 {
-00133                         strlcat(custom_modes,m,MAXMODES);
-00134                 }
-00135                 log(DEBUG,"Custom mode %c set",mode);
-00136         }
-00137         else {
+00100 extern FILE *log_file;
+00101 
+00102 extern time_t TIME;
+00103 
+00104 using namespace std;
+00105 
+00106 std::vector<ModeParameter> custom_mode_params;
+00107 
+00108 chanrec::chanrec()
+00109 {
+00110         strcpy(name,"");
+00111         strcpy(custom_modes,"");
+00112         strcpy(topic,"");
+00113         strcpy(setby,"");
+00114         strcpy(key,"");
+00115         created = topicset = limit = 0;
+00116         binarymodes = 0;
+00117         internal_userlist.clear();
+00118 }
+00119 
+00120 void chanrec::SetCustomMode(char mode,bool mode_on)
+00121 {
+00122         if (mode_on) {
+00123                 static char m[3];
+00124                 m[0] = mode;
+00125                 m[1] = '\0';
+00126                 if (!strchr(this->custom_modes,mode))
+00127                 {
+00128                         strlcat(custom_modes,m,MAXMODES);
+00129                 }
+00130                 log(DEBUG,"Custom mode %c set",mode);
+00131         }
+00132         else {
+00133 
+00134                 std::string a = this->custom_modes;
+00135                 int pos = a.find(mode);
+00136                 a.erase(pos,1);
+00137                 strncpy(this->custom_modes,a.c_str(),MAXMODES);
 00138 
-00139                 std::string a = this->custom_modes;
-00140                 int pos = a.find(mode);
-00141                 a.erase(pos,1);
-00142                 strncpy(this->custom_modes,a.c_str(),MAXMODES);
+00139                 log(DEBUG,"Custom mode %c removed: modelist='%s'",mode,this->custom_modes);
+00140                 this->SetCustomModeParam(mode,"",false);
+00141         }
+00142 }
 00143 
-00144                 log(DEBUG,"Custom mode %c removed: modelist='%s'",mode,this->custom_modes);
-00145                 this->SetCustomModeParam(mode,"",false);
-00146         }
-00147 }
-00148 
-00149 
-00150 void chanrec::SetCustomModeParam(char mode,char* parameter,bool mode_on)
-00151 {
-00152 
-00153         log(DEBUG,"SetCustomModeParam called");
-00154         ModeParameter M;
-00155         M.mode = mode;
-00156         strlcpy(M.channel,this->name,CHANMAX);
-00157         strlcpy(M.parameter,parameter,MAXBUF);
-00158         if (mode_on)
+00144 
+00145 void chanrec::SetCustomModeParam(char mode,char* parameter,bool mode_on)
+00146 {
+00147 
+00148         log(DEBUG,"SetCustomModeParam called");
+00149         ModeParameter M;
+00150         M.mode = mode;
+00151         strlcpy(M.channel,this->name,CHANMAX);
+00152         strlcpy(M.parameter,parameter,MAXBUF);
+00153         if (mode_on)
+00154         {
+00155                 log(DEBUG,"Custom mode parameter %c %s added",mode,parameter);
+00156                 custom_mode_params.push_back(M);
+00157         }
+00158         else
 00159         {
-00160                 log(DEBUG,"Custom mode parameter %c %s added",mode,parameter);
-00161                 custom_mode_params.push_back(M);
-00162         }
-00163         else
-00164         {
-00165                 if (custom_mode_params.size())
-00166                 {
-00167                         for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++)
-00168                         {
-00169                                 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel)))
-00170                                 {
-00171                                         log(DEBUG,"Custom mode parameter %c %s removed",mode,parameter);
-00172                                         custom_mode_params.erase(i);
-00173                                         return;
-00174                                 }
-00175                         }
-00176                 }
-00177                 log(DEBUG,"*** BUG *** Attempt to remove non-existent mode parameter!");
-00178         }
-00179 }
-00180 
-00181 bool chanrec::IsCustomModeSet(char mode)
-00182 {
-00183         log(DEBUG,"Checking ISCustomModeSet: %c %s",mode,this->custom_modes);
-00184         return (strchr(this->custom_modes,mode) != 0);
-00185 }
-00186 
-00187 std::string chanrec::GetModeParameter(char mode)
-00188 {
-00189         if (custom_mode_params.size())
-00190         {
-00191                 for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++)
-00192                 {
-00193                         if ((i->mode == mode) && (!strcasecmp(this->name,i->channel)))
-00194                         {
-00195                                 return i->parameter;
-00196                         }
-00197                 }
-00198         }
-00199         return "";
+00160                 if (custom_mode_params.size())
+00161                 {
+00162                         for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++)
+00163                         {
+00164                                 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel)))
+00165                                 {
+00166                                         log(DEBUG,"Custom mode parameter %c %s removed",mode,parameter);
+00167                                         custom_mode_params.erase(i);
+00168                                         return;
+00169                                 }
+00170                         }
+00171                 }
+00172                 log(DEBUG,"*** BUG *** Attempt to remove non-existent mode parameter!");
+00173         }
+00174 }
+00175 
+00176 bool chanrec::IsCustomModeSet(char mode)
+00177 {
+00178         log(DEBUG,"Checking ISCustomModeSet: %c %s",mode,this->custom_modes);
+00179         return (strchr(this->custom_modes,mode) != 0);
+00180 }
+00181 
+00182 std::string chanrec::GetModeParameter(char mode)
+00183 {
+00184         if (custom_mode_params.size())
+00185         {
+00186                 for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++)
+00187                 {
+00188                         if ((i->mode == mode) && (!strcasecmp(this->name,i->channel)))
+00189                         {
+00190                                 return i->parameter;
+00191                         }
+00192                 }
+00193         }
+00194         return "";
+00195 }
+00196 
+00197 long chanrec::GetUserCounter()
+00198 {
+00199         return (this->internal_userlist.size());
 00200 }
 00201 
-00202 long chanrec::GetUserCounter()
+00202 void chanrec::AddUser(char* castuser)
 00203 {
-00204         return (this->internal_userlist.size());
-00205 }
-00206 
-00207 void chanrec::AddUser(char* castuser)
-00208 {
-00209         internal_userlist.push_back(castuser);
-00210         log(DEBUG,"Added casted user to channel's internal list");
-00211 }
-00212 
-00213 void chanrec::DelUser(char* castuser)
-00214 {
-00215         for (std::vector<char*>::iterator a = internal_userlist.begin(); a < internal_userlist.end(); a++)
-00216         {
-00217                 if (*a == castuser)
-00218                 {
-00219                         log(DEBUG,"Removed casted user from channel's internal list");
-00220                         internal_userlist.erase(a);
-00221                         return;
-00222                 }
-00223         }
-00224         log(DEBUG,"BUG BUG BUG! Attempt to remove an uncasted user from the internal list of %s!",name);
+00204         internal_userlist.push_back(castuser);
+00205         log(DEBUG,"Added casted user to channel's internal list");
+00206 }
+00207 
+00208 void chanrec::DelUser(char* castuser)
+00209 {
+00210         for (std::vector<char*>::iterator a = internal_userlist.begin(); a < internal_userlist.end(); a++)
+00211         {
+00212                 if (*a == castuser)
+00213                 {
+00214                         log(DEBUG,"Removed casted user from channel's internal list");
+00215                         internal_userlist.erase(a);
+00216                         return;
+00217                 }
+00218         }
+00219         log(DEBUG,"BUG BUG BUG! Attempt to remove an uncasted user from the internal list of %s!",name);
+00220 }
+00221 
+00222 std::vector<char*> *chanrec::GetUsers()
+00223 {
+00224         return &internal_userlist;
 00225 }
-00226 
-00227 std::vector<char*> *chanrec::GetUsers()
-00228 {
-00229         return &internal_userlist;
-00230 }
-

Generated on Fri May 13 15:48:40 2005 for InspIRCd by +
Generated on Sun May 15 17:02:04 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/channels_8cpp.html b/docs/module-doc/channels_8cpp.html index 0a8560ac3..e653d96c0 100644 --- a/docs/module-doc/channels_8cpp.html +++ b/docs/module-doc/channels_8cpp.html @@ -4,26 +4,22 @@ - +

channels.cpp File Reference

#include "inspircd.h"
#include "inspircd_io.h"
#include "inspircd_util.h"
#include "inspircd_config.h"
#include <unistd.h>
-#include <fcntl.h>
#include <sys/errno.h>
#include <sys/ioctl.h>
#include <sys/utsname.h>
-#include <cstdio>
#include <time.h>
#include <string>
#include <hash_map>
#include <map>
#include <sstream>
#include <vector>
-#include <errno.h>
#include <deque>
-#include <sched.h>
#include "connection.h"
#include "users.h"
#include "servers.h"
@@ -36,18 +32,19 @@ #include "mode.h"
#include "xline.h"
#include "inspstring.h"
+#include "helperfuncs.h"

Include dependency graph for channels.cpp:

Include dependency graph
- - - - - - - - + + + + + + + +

@@ -159,7 +156,7 @@ Include dependency graph for channels.cpp:

58 of file channels.cpp. +Definition at line 53 of file channels.cpp.

Variable Documentation

@@ -169,7 +166,7 @@ Definition at line 58 -
char AdminEmail[MAXBUF] + char AdminEmail[MAXBUF]
@@ -184,7 +181,7 @@ Definition at line 58

-Definition at line 72 of file channels.cpp. +Definition at line 67 of file channels.cpp.

@@ -193,7 +190,7 @@ Definition at line 72 -
char AdminName[MAXBUF] + char AdminName[MAXBUF]
@@ -208,7 +205,7 @@ Definition at line 72

-Definition at line 71 of file channels.cpp. +Definition at line 66 of file channels.cpp.

@@ -217,7 +214,7 @@ Definition at line 71 -
char AdminNick[MAXBUF] + char AdminNick[MAXBUF]
@@ -232,7 +229,7 @@ Definition at line 71

-Definition at line 73 of file channels.cpp. +Definition at line 68 of file channels.cpp.

@@ -241,7 +238,7 @@ Definition at line 73 -
std::vector<long> auth_cookies + std::vector<long> auth_cookies
@@ -256,7 +253,7 @@ Definition at line 73

-Definition at line 100 of file channels.cpp. +Definition at line 95 of file channels.cpp.

@@ -265,7 +262,7 @@ Definition at line 100 -
int boundPortCount + int boundPortCount
@@ -280,7 +277,7 @@ Definition at line 100

-Definition at line 94 of file channels.cpp. +Definition at line 89 of file channels.cpp.

@@ -304,9 +301,9 @@ Definition at line 94

-Definition at line 101 of file channels.cpp. +Definition at line 96 of file channels.cpp.

-Referenced by userrec::HasPermission(). +Referenced by userrec::HasPermission().

@@ -330,9 +327,9 @@ Referenced by userrec::HasPer

-Definition at line 111 of file channels.cpp. +Definition at line 106 of file channels.cpp.

-Referenced by chanrec::GetModeParameter(), and chanrec::SetCustomModeParam(). +Referenced by chanrec::GetModeParameter(), and chanrec::SetCustomModeParam().

@@ -341,7 +338,7 @@ Referenced by chanrec::Get -
int debugging + int debugging
@@ -356,7 +353,7 @@ Referenced by
chanrec::Get

-Definition at line 82 of file channels.cpp. +Definition at line 77 of file channels.cpp.

@@ -365,7 +362,7 @@ Definition at line 82 -
int defaultRoute + int defaultRoute
@@ -380,7 +377,7 @@ Definition at line 82

-Definition at line 98 of file channels.cpp. +Definition at line 93 of file channels.cpp.

@@ -389,7 +386,7 @@ Definition at line 98 -
int DieDelay + int DieDelay
@@ -404,7 +401,7 @@ Definition at line 98

-Definition at line 85 of file channels.cpp. +Definition at line 80 of file channels.cpp.

@@ -413,7 +410,7 @@ Definition at line 85 -
char diepass[MAXBUF] + char diepass[MAXBUF]
@@ -428,7 +425,7 @@ Definition at line 85

-Definition at line 74 of file channels.cpp. +Definition at line 69 of file channels.cpp.

@@ -437,7 +434,7 @@ Definition at line 74 -
char DieValue[MAXBUF] + char DieValue[MAXBUF]
@@ -452,7 +449,7 @@ Definition at line 74

-Definition at line 80 of file channels.cpp. +Definition at line 75 of file channels.cpp.

@@ -476,7 +473,7 @@ Definition at line 80

-Definition at line 65 of file channels.cpp. +Definition at line 60 of file channels.cpp.

@@ -485,7 +482,7 @@ Definition at line 65 -
std::vector<int> fd_reap + std::vector<int> fd_reap
@@ -500,7 +497,7 @@ Definition at line 65

-Definition at line 91 of file channels.cpp. +Definition at line 86 of file channels.cpp.

@@ -509,7 +506,7 @@ Definition at line 91 -
char list[MAXBUF] + char list[MAXBUF]
@@ -524,9 +521,9 @@ Definition at line 91

-Definition at line 78 of file channels.cpp. +Definition at line 73 of file channels.cpp.

-Referenced by Server::GetUsers(). +Referenced by Server::GetUsers().

@@ -535,7 +532,7 @@ Referenced by Server::GetUs -
FILE* log_file + FILE* log_file
@@ -550,7 +547,7 @@ Referenced by
Server::GetUs

-Definition at line 105 of file channels.cpp. +Definition at line 100 of file channels.cpp.

@@ -559,7 +556,7 @@ Definition at line 105 -
int LogLevel + int LogLevel
@@ -574,7 +571,7 @@ Definition at line 105

-Definition at line 67 of file channels.cpp. +Definition at line 62 of file channels.cpp.

@@ -583,7 +580,7 @@ Definition at line 67 -
int MaxWhoResults + int MaxWhoResults
@@ -598,7 +595,7 @@ Definition at line 67

-Definition at line 88 of file channels.cpp. +Definition at line 83 of file channels.cpp.

@@ -607,7 +604,7 @@ Definition at line 88 -
serverrec* me[32] + serverrec* me[32]
@@ -622,7 +619,7 @@ Definition at line 88

-Definition at line 103 of file channels.cpp. +Definition at line 98 of file channels.cpp.

@@ -631,7 +628,7 @@ Definition at line 103 -
int MODCOUNT = -1 + int MODCOUNT = -1
@@ -646,9 +643,9 @@ Definition at line 103

-Definition at line 1067 of file modules.cpp. +Definition at line 996 of file modules.cpp.

-Referenced by Server::FindModule(). +Referenced by Server::FindModule().

@@ -657,7 +654,7 @@ Referenced by Server::FindM -
std::vector<std::string> module_names + std::vector<std::string> module_names
@@ -672,9 +669,9 @@ Referenced by
Server::FindM

-Definition at line 92 of file channels.cpp. +Definition at line 87 of file channels.cpp.

-Referenced by Server::FindModule(). +Referenced by Server::FindModule().

@@ -698,9 +695,9 @@ Referenced by Server::FindM

-Definition at line 64 of file channels.cpp. +Definition at line 59 of file channels.cpp.

-Referenced by Server::FindModule(). +Referenced by Server::FindModule().

@@ -709,7 +706,7 @@ Referenced by Server::FindM -
char motd[MAXBUF] + char motd[MAXBUF]
@@ -724,7 +721,7 @@ Referenced by
Server::FindM

-Definition at line 76 of file channels.cpp. +Definition at line 71 of file channels.cpp.

@@ -733,7 +730,7 @@ Definition at line 76 -
time_t nb_start + time_t nb_start
@@ -748,7 +745,7 @@ Definition at line 76

-Definition at line 89 of file channels.cpp. +Definition at line 84 of file channels.cpp.

@@ -757,7 +754,7 @@ Definition at line 89 -
int NetBufferSize + int NetBufferSize
@@ -772,7 +769,7 @@ Definition at line 89

-Definition at line 87 of file channels.cpp. +Definition at line 82 of file channels.cpp.

@@ -781,7 +778,7 @@ Definition at line 87 -
char Network[MAXBUF] + char Network[MAXBUF]
@@ -796,7 +793,7 @@ Definition at line 87

-Definition at line 69 of file channels.cpp. +Definition at line 64 of file channels.cpp.

@@ -805,7 +802,7 @@ Definition at line 69 -
int portCount + int portCount
@@ -820,7 +817,7 @@ Definition at line 69

-Definition at line 95 of file channels.cpp. +Definition at line 90 of file channels.cpp.

@@ -829,7 +826,7 @@ Definition at line 95 -
int ports[MAXSOCKS] + int ports[MAXSOCKS]
@@ -844,7 +841,7 @@ Definition at line 95

-Definition at line 97 of file channels.cpp. +Definition at line 92 of file channels.cpp.

@@ -853,7 +850,7 @@ Definition at line 97 -
char PrefixQuit[MAXBUF] + char PrefixQuit[MAXBUF]
@@ -868,7 +865,7 @@ Definition at line 97

-Definition at line 79 of file channels.cpp. +Definition at line 74 of file channels.cpp.

@@ -877,7 +874,7 @@ Definition at line 79 -
char restartpass[MAXBUF] + char restartpass[MAXBUF]
@@ -892,7 +889,7 @@ Definition at line 79

-Definition at line 75 of file channels.cpp. +Definition at line 70 of file channels.cpp.

@@ -901,7 +898,7 @@ Definition at line 75 -
char rules[MAXBUF] + char rules[MAXBUF]
@@ -916,7 +913,7 @@ Definition at line 75

-Definition at line 77 of file channels.cpp. +Definition at line 72 of file channels.cpp.

@@ -925,7 +922,7 @@ Definition at line 77 -
char ServerDesc[MAXBUF] + char ServerDesc[MAXBUF]
@@ -940,7 +937,7 @@ Definition at line 77

-Definition at line 70 of file channels.cpp. +Definition at line 65 of file channels.cpp.

@@ -949,7 +946,7 @@ Definition at line 70 -
char ServerName[MAXBUF] + char ServerName[MAXBUF]
@@ -964,7 +961,7 @@ Definition at line 70

-Definition at line 68 of file channels.cpp. +Definition at line 63 of file channels.cpp.

@@ -973,7 +970,7 @@ Definition at line 68 -
int SERVERportCount + int SERVERportCount
@@ -988,7 +985,7 @@ Definition at line 68

-Definition at line 96 of file channels.cpp. +Definition at line 91 of file channels.cpp.

@@ -997,7 +994,7 @@ Definition at line 96 -
time_t startup_time + time_t startup_time
@@ -1012,7 +1009,7 @@ Definition at line 96

-Definition at line 86 of file channels.cpp. +Definition at line 81 of file channels.cpp.

@@ -1036,9 +1033,9 @@ Definition at line 86

-Definition at line 107 of file channels.cpp. +Definition at line 102 of file channels.cpp.

-Referenced by serverrec::serverrec(), and userrec::userrec(). +Referenced by serverrec::serverrec(), and userrec::userrec().

@@ -1047,7 +1044,7 @@ Referenced by serverrec::se -
int WHOWAS_MAX + int WHOWAS_MAX
@@ -1062,7 +1059,7 @@ Referenced by
serverrec::se

-Definition at line 84 of file channels.cpp. +Definition at line 79 of file channels.cpp.

@@ -1071,7 +1068,7 @@ Definition at line 84 -
int WHOWAS_STALE + int WHOWAS_STALE
@@ -1086,10 +1083,10 @@ Definition at line 84

-Definition at line 83 of file channels.cpp. +Definition at line 78 of file channels.cpp. -


Generated on Fri May 13 15:48:50 2005 for InspIRCd by +
Generated on Sun May 15 17:02:17 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/channels_8cpp__incl.gif b/docs/module-doc/channels_8cpp__incl.gif index 8e12d08e2eb7e5a09096b1bf49b11da54e3a163f..73931eed597b0025495ed50ab1e591db677d1d2c 100644 GIT binary patch literal 37708 zcmV(=K-s@XNk%w1VblVA2jc($|Ns900092~{~sS8pP!%K-`_t!KVM&8zrVkKe}5Sn zaQ^@R000000000000000A^8LW00062EC2ui0Mr6}2LJ^A5XecZy*TU5yZ>M)j$~<` zXsWJk>%MR-&vb3yc&_h!@BhG{a7Zi~kI1BQ$!t2G(5Q4uty-_xtai)odcWYXcuX#v z&*-#z&2GEj@VIs;jK6uCK7Mva__cwzs&sy1Tr+zQ4f1!o$SH#>dFX%FE2n&d<=% z($mz{*4NnC+S}aS-rwNi;^XAy=I7|?>g(+7?(gvN^7Hid_V@Vt`uqI-{{Kf52pmYT zpuvL(0V*7Zu%SZ*G#(mUNYRr-f?)<$+<54s#yS2UIf|4cu_MHhD9JRe6f&htDJwy> zd`UA%%vAzw>a=mQ*2$efP4x7YGpJDvLy`SFS~H=wrA#S0^#(O6zNzMlT7`%8UDd7P zy59Q=_L|s#WXm=?*ifOt?uiw9b0}JLWLhf8xbzLEVvp9s| z!>1C{YV3wGh{upSN!DeVP3I4oGf&zK?6Vrv9zu&wMA{f?G_O0TUj3&vv)E>EZ2k9AjJ1+y>8}=I3Lxk7x9qD#AzuN_u z5P-md_7VsL2ryuA`v3+COduX0!2k&b9R5JxVg(p5fPBdTXaIitRnXph1T2SwcIQ#i zojU6Q&>sK@Y8at=8Xmx*i0rXPK!XQ-_}>8u03cw3E`CTN1sisFT?!OdsKkZvWEen$ z#2H`!Wj{*rUx^x0aO4C7=vTmaNdmCslKTNE;e^M8C4XYl znC1rMnU`e~Jo3{ek`sVfWC2T}$z%mh0`Me^Q(9o=l~}%6#Fj738RdZ-3KxKg1k9+X z1P3ezB8x7bNvVv2u1TH>IU2eGqChE190Kpb*B^drM)_rZ5*TRX1;iD|pqPVp(59QB z@>GypyV6=kuor~d>u$e_My!Lw{*HPqj>&GfY^y5FXYG74OiO{WhLT#Lwpf5W0k^$* zE2_9wpbG%GbD8_B1nN?uF1t~=`>qA?PC>5(`!*Hry&>calU676TghMuC#>+oxP@vj zz#j-41p+gXU@#>T|L|JH+5HQ#3K>5^F-8T$5^@iwdAzO4AGg5p%P_~B@WUKjEXm0{ zbXFJ5Ek6=xu_k|E*+V_c^m7F^M}qSXjS*e6(PuUH%F;TF?DW$XIpkQ-UU-Bx)I1~2 z^>M?A*Qp4f9sRY>VOx+iBvgAq9h4cwy*43jyFGRgbB|#6-GhAO@YFCq2w$TEdU)%Y z{sAZ;tOXu8w|j@{3b-o%OA4-7;VpIupPi6OY9fj%y4d224t7pA1%F>|NRDqi;-i%S z2uWmvdD1B*pH9wAyXCI80z2UuOj_%L0fb5Cq^>T1cJpioFTBOXlkKW4R^HfUN z`}3=ho453rP#Ak7rW*O7qoLzUL8Tn7czWNuv*|VYnvHNiBk2Qx>Uu6X99zMv zc9L^n{XTUO{8^+h)hpW&nx-`e=5K48OF{Tm#W+o!cAxU<)iXP5jV?Yz44nf00F0?6#N<`0P znz)5sK@nmy%cA}kw@4TY%;t)Q;G!6}NWCcD$PT(u3K-Y1#$y>#329`aQQFw6Hzt8O zp`l|s^!O$_A_0%7sh1h+b_YPp#wvXLRv`mfGei#Z0vRen2^YA521SW}Adn7b61m4m zR=|(c@<8{XN6IrEQfiL$B)o_)Nm61mVsi9iSvW}>A5ktsh=bLA@`J0!`RQ>4l9i@P zWUVm?>Xw9RBq~$sNgt`sMDYvJh;VhHO+^z^sI%TB6-c9J0*{f|Q41}VRXEz&u1ZGY z=I)gAz2b3`dF=UJ^kNy#SvIq9VzO28uBXm2d5T%a3@EiWSRTWSQymALOaJQhpF3?2 zIo<2ipZ?tGC*v(JSEd9fufUQ}VBr%IdCA!4iyBG;A%EZ|oY^wWg4+ zLg3gbotl}v>STyQT%McQZ2B>mqf$&n<6kv5Vd>Y*Lw; zZ7&$!%Ut%#mkadm>U8hhg~#~UImhKMc*DzG`wAEf|Ap^<51a*q4p^=X)>3^74B-e{ zNWtbkuZ6GRVD)x)!&T@ohCdAA3ujoi@h!25*Gu6FtJn#|jV_5_{DjYrc*Zn_lYVzB z-Wuz5%i+LjAC2c({`sZWiA zRI8fFtfsW4A+6?EdwSMnMzpPOy=gStbJx74wUJi}Y#Dso(y%Ue4vy_%PAj{!ZN~MR zpS|p8TRYj*t^u=4ed%mRq}RTlwzqi#ZfOg0+}bYpwHuA@89*1=?Cym}=1uQ<*PAZt z&bPQnVeh0gxZjff#Jii_?biW(e1WicBz`jIP+#`o0pA5|1;KC`7o5ZWCPzu~Fz{E$ z8%`5Pi)t^c?{$Sju_)II6FRzaj=pfkCMS3%0GmuCfU)J>ig4|c;nak5dmGGOacIJsHP*jA%G z?Khi&bzUhOrk{P+INZTW2Hy$XmMn6XT?0~mY}^r z^`y_nU=)+#qj#{;UHy_>pX+sp(L_IA0T8*W`QX#l)ivL4w*DKN_>foH@mFfmMXfKM zlrlf@r+OjBdiCcvnTI3z*Jt|oQ}p3E3UpJrluf7iecx1o>2`osXD|@Kd7R*Nd*^$< z2W=YYMf=i$7AJLUw=%!dM$_kA2?#+RxCtOgNMI*8H&=r2)<`p`2{niT8-qhv^n&OW zgMrk8Gq-}VWrQt2gzYsrNT`BSAXfY1gii=NQD}Tq_;>fGgH4qhS(trFs6R<#h5W^Y zV3&egCuBiMw< zqK0F^0(V$gfoC!0S147-h>hrnXBdf&IEiHhG@ynS{+I}ZnivtBco}kbe#Ms$^zw*1 zk%)o_1C{oPph$_LHHt%khMh=eglG@k!ipndi#9iWx3!DB$c2OCiYsS`!)S@BXpAXj zb|B}7%eaHhn2W&!jWAazC`gUf_=QFDa`?51y2y^M`hMmqsZJP$vo*Sq6TY0{K#u9mkbXiI>H|murwOctQiMjm2vTuh=G*+qXFj>9|QjMn(-MU>EtIzLMG_+etY5|@)UxynVt+-mh6c+ zw<$Xs(0%c=BnsLm8gebVV}Z`|QbpB;0=kpG2$`ZForu63?q>i8FhK2BA0oO=p(LRu zI!YMDoWgjD7%CElX$tO{gc%T0#F10DBqi%3niFsU+$o~^IidEcodZ>KExKNVNtkBI z5;OXNV+oG8ko!>680N}z5@2^>0y9#ENE_-$aSmqh89 z2G^veP#!$0FRCenNV=Y3N^x+i3g4kqQ+Swc=c0MKm2RpBWl9Q(i2{q^Z^^Z$8VaKW zY6pjE7izhBBgtJ!3Ji|Q2mXK>3yFFH6vU{7v8kE*3(pw`lPU|JY62YukEXbUoLQ5# zb)dwsswHqjhiQaxnVLhX5~;ciwn_pz!MM2XT)lX(z6G$W*^y01u)FoJ>PlD= z3zQ_et_pjGf0wb8wXwADMcQVu@&$#D7o#*`vZIBv3^qJ0yLBWx3;sAN=t^TUTaY5# zvP3khIU8qFHM6-^{k?xXabKH5YP79p%dLsmcyTMYV900n3Xv$8w=k54 ze4DT$x2J&njFmUIhYL1zOR+kLm2K9yG}x>#Q>`M{tKDiSl)Jg}vUCL|xjwiAL70bs z>x@_vtW-yf(aN)ni!!2ngM#&w6A3t|>!s#biG16-IrF+%D_MLwyLVH&02+#`yMR)Q zKD^5>7>Iu?QY{hO1LAnPF7TSg@lTg|GSKzCgu8}< zf-Pp^9`*4*xD=dtXCe>+OCn6X+UtOc!<+FjACQxuTiPH2LV8*?IXSGs3M{z@`w6B3 zDFfh5K1!bZ!F#EjwcT63A48qj)Hx*bIseg})})=|>3%E99#}lQvgyPxI(r|bA-_W$ zz^S7A3%%qkzpC3Zu~DA{FrPhT!sEFp{i&iTe8=evd~S?@3LM80npFdcwwAib*^5O9 ziah?_ho;E6Pgpvk;1|iZ`-h9nk)W_px$?k5dL8f^zj{o;9PptbY60$n03}Mtg$&B6 z%*LIChK82E9F!dTfuh7w#ea;;dpF6<%f*&lqyGm0ILahDI+{^(#v}qiXw1K9485c% zV&c=t8So;){3>(&Pujc^$NR>zsw1%>f$%b=5@@Bzvp76ODSFbSy1dKGbMt^T<; zjnld6()SC+GA)VTxY4fc1+5B>dSlcJOn6CM)0i97eKgd{o2%fvOrYz+M-VSai_$i| z(!CqBC}@&joqe3klpBoI3N0;d&8*Lw6XLkm6$jHA8PMpQXuhkCgqzpx$kz`2XEy}c z2`kuxy|7m;YK=QZZR=EP?URh1&SP6Lk?mNMP1%;)*Owi#kU5rmEs<~?*NzI>q0PYn zanM%XZYrDFn_Y;FJ=TO)R zZg$8F%(8!(K(Y@Tv3fY?W+|WJT%Kh1g0K7| z3j^OFm9(j~vI@KcJ)KZ1Ojgemt<^=q}H>?9GEWc#V$aBQh>RiDQtt3Ct=4JHe zB7L?{`_Ltf8ve@ycy8N)UFI0+j#-@nzUe*q8N`W$rh`&?iw=7J6F|!kh{H3y#KhDxK;R(&=Ia2Pyd&E2=S8SeH{HmeO({WDf&e6vv zT+H+-$f3tg_1RLB2Y_0-P6UnY6^hzG*5$nDvO;}#n7p79(4gb&Dhi5G1&{y-@E$^H zCJ;)YMrx<^1?|Ns;!4#4u>8^SL8AEtPtk-?29N*kOssY)S8INkG*hsKd?} zCBr!t?$^E`ot(?sEQuGt@gnKCG#&!WJ_geww$dD|zQ`>UUlu4??N)%(6* z!>~oFO3qPIu}R9(RMjEPRmjRY z71=yKSKHg5xmsM_UJ^9lI#|TcywG6eWD??2WoP8pXVcDMV_H$^?A53iZ0+yOXmF*k z*x9z@adlM|(DnCGad;e1(Qdfid3{22{`CF-SHJ)ok!8=?gmwcJ_Q{8E;ln}lAQp2- zjG{${3MX#7qR}5mkZL4?yoV7^#cLr|GU<14<;yW6AC@$TGNU(`IbSrpcwxa$ph1NW zC0f+zQKU$9+L8&di^*B#7%ipBW$K{}3sPyV%GBe&Q#GM7>smGvs%03sl3Hta+t+tt zv5w{G)^1dsS1GjR#P@D0f%D#ol{)sX+Z}m7O7M%R@!?W|)p2uUv!Y_iE4yIU``D7_ z%%miL7UD~o@1gz%zTwNS z=O-SpUTV_g?ssXeEC?pX83{JZ2dd<4XjqXOLn05t6=s1L{t%j8jlG7Biv00R)fAb<>~M8Qft z^VCz%FR^g(72N`yLd!nEDbPR^w=;8s0unf&L?hQU(m_f$lrR7}pPazXz0SasoIS5B zw1z+V2^5NI2pu(>L&g3iQ&R~HNC1HX&}4JdTQP8Q(Ma)=!%92yTonW{>6pZxREr(f zypv!|PJ;vF+>y=-69iI7B5^%3NdwsYQ9f-scuds(fL-=iWyv_Ui3}u3_gq&Fb@n?7 zI9yOp1wR~MfCPZFuv=~I9Uwys9Xt^^gb#G%U3FDlR#jtBYd2YV^>Jrjg-Zdh7jtQZ z*bKQ6p}1mrE=JVX$QVwUT?d5Kt{9#mzi0kyemo3S2*D?T;rTBoML z#z^dwzAihSIQ}eSw^NNNNgD3A-HzC#a)iFynZl@!naZsY`rGTkS0mfE#R`{s#>0b2 z9J{mmW(!@NyNZ0FxPPe2@~AUUW^=uN)gUR@W0!q)qChX5s?Y_S+=J7*OkH(f=*D>W za&L#+Zrg~*%H;EyQ66|<@@^gN;MsUSq}++V-bSjMe+qhzdzyE9@~nT@_|-dt(Ynhq z2cI4B3L~F9&I`@nHY-kJpCaVnXQ+M7&F>Kc1YG~(wLLENhJOU~U;g3;6$ZBGaQ6!y zIh>`yI2f>jgOi?RA}B%NQScTT98?B}=eP=P1Aqtl-~j!HzQ_^{yDKbE|G;WJiK8J#BvTIf-r?X+!EP>xUS_Tv4}P}qBW%0h%5HchFAoG_w-O1 z_f64MIcyI}#OSy!(k5L&LgpL=B`vmFOv`4WGqpIi`2N%G&8g1&oEO8n5=R@kmTSjk@ZSm_ELR2SzIucxi|QM z;DpUf$uphC%or_2m{=m_8l(vw%HU?3VuV<3#_30EHZvYLVPiNeW65-O@SEI&TRa#3 zcFuWLQfA^w2$m4=Pk;tgpaUgnK?)jB3xcw4xU**<@VUt4{cfKRO-81~U{O{`Qilv} z=r1U$Ng9qVlkf})Mzvs4(-pFWyy+;h!ofd@Qsbk+Kq(e#O2s^`l%*}@9Z8FjI2rLX zjLf;I6^g3RLg@2i@-Cp7Wv1uy=_l!l7h`_Os!2F1KUJ1h zuQ4?SUB%>6o23|0s%ET3xM@>Fn3j#ERjo$&C{17*R)3NKrTXb)640vGz4CR8WU(1s zlSx#;+Rh1g#b#c$npof9^C_Ei>`-SjS0ZF;Pnj@b4>60>|1lPc-()L9j%xm*ef_gU zCyLO7=mR1TbpQdOx~63>d)l?0b1-@9Y-=C#S|O1rN+9xboi&_9s(*{H83>Bro2sBTW~UAsr-g=D zMpz5!QZPCPnr`$jrNbOdzfXX}otsogndr!7^s(DjZOoCc2*qk_MwXJ<^fSx$n^=q}On@wj` zmn5Ws{Wh|%JiRvZXWB0eHw#U@>~e$jy!s_ZZ)nhPSW- zKF2$K8sG3;XA8Q!^%{?x+anZbC*ixo1C8_mcc z*Q6q#I82rcT%kadH8v$4&!YKF<${iRQfD6W?;*P9*g;mwBR%vAuXWk;#o*+_x+;(~y4eu(k@&H*e@6MLu;upq-r3CLFC-{`G9`a|LQICESh3 z+O~Jx<96Tn+!-llzSD!9ry{kq>0Ys~z~%61SUlB*y+5pXz30bV*u?|yY>`H%>XK)< z_e|ONI$s|1=waV=`YHNuqg$ORMm?#_xrmX=wDqaiJLj=Cdzn}B>ZZ3n!-KB+%CjE# zsMSNOcpv-Dw@#&q9X_0O|Fq-p{NO}J9@%l({M=vuxbM%Gh1zb_evuIj)oQ9ukN zL6?BQtV=$*0~-`1zKU5uJkY_g2{xg#JBo|29TLGg=?*pE!BW$=OB21K^OGB_ESll4 z7g)2Z!lZd~ySL*zZ0M$0A{`>+j^j8&D zfvqx+ZgaYg-_lr-_gy8}i0i>aXt zLLxdvkQx>avoA-16acUnOi8d9t1m_g#{5#n4EV&CgSv?0MPAdVDw9T5^F>9Glm)Am z3UCq`1H%qOj%{qP^3s3?l#Acvj6Z|BnkYc_V~?Tv#cIhHO{~Ok1Q%nR$7>NWS}cT+ zF|!{;x*){ApR$-mJjNN@mwthe5_!XWgq3id02*6J9=Wj(I7gV#KEpG_8ib=nEGBr- zK_#HV3BXA5YY0y>!Ef6&g48ymiT+1NAV~-jJgdVTbyUe_W672T!F8}kKoH3}p_EDq z!xu2g`U5#q1j2}_Jy4kpm^2T&8LkRcwgB--%d0`Al$)s`8KA6#-TE>?nKj|@gq@VM zfy_#+)CQ{rz!yZX`vZ`c@HBVqHOd3NHMqgG+`$(tv84&iJG({FQ_8!W*zr4JIuA~Eu+8VO#!Nwe^$DFgsq)H3JAFkZX#Qd^j5j&*J zrpolX2b!tIYfZ0|KiaHK+x({|E05G%t!wNO*|aWY+p5L;&GqQZ5@Jl{^GxCtzGUjI zk4#JK(}Z?}%K%bN!Sp-P{!F{)5I>zeAu=qQsG7@HlZvriEN0=(%K0>?lT6mUPC)9- z@(CaGj2{7npzQpj3LAibI;#HP%erW3#~3R04BSPz+AMVUTi@X3ekn?PVWRv6VDa|CVeqC5Dv>JweSjt+lc#YGPtkr@=%$%?&h{aUWc(9EM9ZoGyd97I0<5p`sOOBmT!^|JI4B7DzHjJ;8IL`3%Z>JP<9bpgrr1B zWRhv=#7QB549O8mJd!A(M+~rBC*j;BX~bSJ4$IZtO#$6NlpaTY*HUC9t_oE6!opBg zRDhr=ThYci*_2tF6bdNEff+_SDM#{}fJp?e4wIBNnGaYz-LpyExF|E0Fx3v`7y;yr4TWxtn;s_Fc z%wGwJmdibW%(W8^?pz&tSqhdE4?dCtF5YH5UvV`>(i)(v?W6B;)in%F#x26|Ef^+& zlCQJF61&hAHpNi`(uTF4-RsaCvf&RChfl31=MUmILh9zsX1 zIXMC+Nw$TbMFvsk*J@?d(GzA%O`l@!WFPaLeOTtntmTW$%~6%CVeZ)6W7KI5pM0}s zD8^=eC{}iEXMo~Y+pIWWo@20-9G}xBO-|o)#^qctEM+p<%yPM%ExLRbXN@|Za>kp@ zLgzqp(SP>W!j)(FDcW#8po6}Pf_}+`er99#JDhzB==E5U8z0xpX!%tBx}Gs<#L39m zor_5RXpojp^)Qzw+Si0Omd(rAijJnRXz3c#<+6*0dIsm)_~nwmX>Wo;byH~tWvr35 zIiT*S(HPiKK3c(J>M{2u|hE}S$F1IQI)?}t^)XoL4ouJI7 zznWX^7EL(MHb`PI(v{J$J~g?Ld&a+JJKi?Hp0dwHzU{{*C+Gf#>Z#mG{b}Wvax7Bi zn95#XL7Hv$3me_u?bhZuxXNxk+U|~s?n|CB0UU0}25j_msM_8c^bWV)E*BLAZ+`Z{ zH8#r!8_?#hZz?*s?pE)R0ygSiAM0kS!JBUd-fIOXCGY0I0nAG6GjP=jPrrWfG%{-F z7Oth+?_h)N!(F7e4yKGoomiUiutQM_e?IRUG7)zh%8JbUZtHSxZ!DxY5-;($jBTzd zm9c(kyROMe-M2Qn@${8(Ag6J~L)j1rWGSC=Dz9=Yzj7>}a#?K=2ah(^NvG169HPB?SjnTDgB>HY|J^M9z+9UmsiuyZvKblqVf z6YcMR8*dtvy9ICL86k8tfOLx?pczfq(`od?YDY|$hL45l81w;2CxcL*bn>b6$Gr3= zk6u0^PNgM56Z5xJ81+8Co+~`{%Gq>PXLO$o=@+(I3>VszHmnx=8dT@=H|MTY$07mm zFC4yul$G@dXN6&Rk79Svz)kjThVZkVT0D66;@rQsQz;k2_FRt+q&D!H51bX{`Rddq=o-EMHk424+j?S^=7{SR@C2N z3}6Tm5)RH4{Pm8Qmk;74dHb2^lYj9(=17Ny;a|V!m$!iI_@mnh+QZgKiebmGW%dr&KH^ZxO$MZLNV7Hhkd$;(!{;lNjcbo8Hj5%rmO5N^4t9eS*^|umv99^ZWjeonFt_U!e++Re<6mW256E zWTfOIrJ>uBWiZr>h~<9Mk`?bMnu{kNLa_-bWpQRRGltv|P11gxM+Y@E#_mhcwn%qIy-w-C zw}DwxHYU*ZKQDZ1(Eb*@`yoGqfN}SRxh-p4J*oi}AH0042*Z{0iEW4*CWiga9pwT7ni9l;JHJDb|pOdf}HxhsSIP;3*|OxDp*AS_TDN zE;4oEYB{aQVq!MF7*mebMJAn(HxlN-0!b>lB$G`#`6QH4N;xH!POe8!k+liu&|#(# znWa>UX|O;}WM+{fn7Il#VUX=bm!^7RT3{wjbXEiBWXnZ|$YyWi8Rm=|*vZnMOrZIv zhAO4hCUbrw{;Ff3f|lvnqqV6NQkRL*Q7KM^bx>$YplZTto~ndX8gHAD%95uXh`Q0M zPOMt$Yw6iqo{+On)T*S06kq`xEd-lFtUes7t2}|=+F(#JA}f)pBNSW406Pqe!n8ab z`)oP^<(KJU&T{*qTdrDiZ4oVGyTi8Qo>NzLY3&n6yY3oQZm%R1a6kY9AOJuC1_WTh zuMz}6zyJpujIhE03rw&D`}T{#A_hwk@W2HFaB#u|1i`S!*ive*bE)1MBuI>s{O)F- zns9)}2m=5!00bNWYyveK5kSra7;(U_Hd{cm%xwG|^UVhLd@av96Fc(CCN^3lxaF`J zHOnpjx?DoF8gvT4*8vo~^Vkw}UBK60TfBDKz?Qv%*lVA#t}s}e$Y*2BS_-b++$bxp z3Bwu+Ea4j$-bmqz@2q&@jEf8vh`IK?SF`o$vZuFD&h_Xv0i82jsR#*VY@y~f`E%kSD4LoD~=>?<05-Pxn15rE32D6lVy90{!u-yu}7`{j*>R%V4!N?Foi4oDQlq_>y8pjzceu+zRC&!rK5bh_Ygq z4heN8A^y;ae-L3vNa)0SA+d8iT;c(LXhZz5$9|TZBGfQrMJ0meU0U4Yv!I9us)2DW zRUD&9QaBD)ozaNjN`hZH*v3J;(Ofu@HaziUa6MS z?8pawam{faGn>p*hclnKAnAQmhNu)~6B42vvka^KwTWIrO0rrQ;hUF#wNYY-YdWmm&=C zFNq0(cqldL%og!I1SCudibxv97%@`twG;p}t=P?e%1C$d$tC+V;p^D>QKm@3W&r@2 z5EAgzdP?kO7?rA3qdL_^FbrlG#VEg^$_S^5RcBtssL#$iiHz!iOI~3MAD7D1NE85Z zHMOWsg>YAl?o|_m0t}G6)Xwv>i>NJX zZwg%C>J_jROV|L2dry0{Hb;;Js8VJ7lcov`s=mdjZarq(?JA4@!XQ1~#oe zL+ew|yH@4`MM8O+taMo-(v=GAx=$@Y0dmG&`+g5?on7Bc717_q0w8DKy{b6&w@w!^}GPr;j!p4S&(P0*R7{nBoCy9e2 z%ky9`#lc)B5n8Nc1;=<<7-kiUZOnxSa$(0t9`U$Z>t53Sz(~lNz_B5YEM-UZI3+($ z%^aPKq5bq?%3j7OQNuN3+6YI>%-}LNzU<{HljFJ5D6@?ls3A2^xynl}&U}_C=Z(NK zgWEK7ATf1iNR`Ejd*j;*d8gdJcjJ4^WJb3P&XY^_CG+Ms4lwf}UzjcQZd+cu>XkBzSveR@`{ zh?glNbne*h%|g7IU%0tNKXTu?-19D%TfN;fZespB$@`|xw@v(St??Vy12@U6<)>uX zAY0)JM`FWiy>3jlJA#O~jBSc~aU6EM)Eh@fzKMx9iJ z?|b+6Gvt15$lNCFYIpn8xwLC&#k(DfU%2(^4tdEEK2_Kgd*!Do(8V7~RcrEk=jZi# z7asQCm~~utG5$nrm-nLa?u^?1$4!?{{g@Fn<2)lA`KmYk z;nzrfq5A|5R|{0|zfK@us~Y;w54A{Sbb9ZzefwhX`1GaudJmSEF!cGpn8^?BZ&Vuo zqcq54!_$2GzeWD+zKSUE-=BR(bPZ%2?k1+27t+pf&(e2BzKynnnkP#{@>6Y=~eV9AB^f9_++ z2}a)T-CP02#0nlAP3U0U{b05kVbmbuFR=-Xe2Mc_pb{F&2^Jb`&07`PU=Rx73cj2a zb_xTE0pI-{8lj!hwcHTmAYfQU{uX-F6zWPF0?DF0q5t_{z;WDjxf~ff6N%`Y7QSKj zSRWo95aP|hqnvo0Yp_auVAF-SaHsKszcW#Z;cq8X&3T+t#1-Qizcq6uai?%?8`xFYo_;PBaE zt(fBNSf38AA|G&~(`}-B7$XNFW9)>31v2AINaGX%V>IcaL8KugUK=c6;}dCP5RoHT z$Rc;}V&_>SLvUj(n4{LgqZrQ66%qwFk|HPMAw5!&FwSE?j>;XvB4|*f=4{F#2IL+% zV+^5VJc42<4x2%8nk@kSlS2~XJp#~0-U~!J9$h$~pb;egb&5PTqg!%oWS2`eADumRa<)fVBfgl`K z;-g4z+uhZryqp+O7Rg3#P6a{bHfg27QC;5&=BT(OU-l(91Rh|rpJAqvi1<*0A!f3b zI)CZ}w5MI9ceQc@;z^5&bN(`v9o zb6V#%LPK=oC7@8}dvK?MV5fNwUTl!39eL+%wr5*Pr*=3egvr=>if6MFC#hK33gTxO z!RIUm=YwQtMQ&l@$>%K!sIB#eY>p>?He+h~CVavm5h7^U;aOvXRD)*YgVLvaHlcdn z5Llvz!`UYrerWMUAcS@(2MJ(^R-A%f=!XF4+m#r5s_2R$pcma6PX<)_%_YPcDCM9E zR}SYC$mrtjqvN58q*)$$`sl6zsaRr~c@k-XnkX^#TeOIQgjOk(GD?GPDPLw#ie4X+ zTB+7y>HfnNsa4h-Ym(?Jn&~Vd9fy*s3c_imwUy!dP>%xRf;ys|hNs@lsegj$3<6)8 zDq?RwVxNxYpBf3eO(~VCW|w}`X|NF;GHRRJ=sQj-lM39BM(S*4D4ta6Y;4I-8mTs! zBB3HnmSScEs%fK291zMQr=H0PI_Xu`>WsqOr!EVZf}n1+Uaeqgkoo5k#;T`%+wFaz zYMxB_1#9ks-+wZno7$?b8pyN?=ru^?ts!eNLaQx$tF^`;cowFp8V9l+Af$$dxE^E= z);GgN5rS(Zo+}sTo(lP08;NNARgN%lD;W+O1lemdW~Oe! z{wlz}7P;oD!eZydCZ@@lSjK7#=as96c5IMVED2rgQ)(czrklee)wX&As%|5+MG?ZP zDaaaPs7aB?Dg=7s<<#0+)S_P3Vo6j^(A5TF_03CQ=;_La(rL&gi4GRr#;x4WE#20w-QF$U z=B?fi)}f{Qcq-{)6KBZWTox?}?$IMr-j#q1)=GNG`8GAV4_H-06v0 zf8c4UdTiNV(Dscf4rs63@PNjgPP%N_lK!p-npxI0*VD1f%g!Cf4(HCMfchRm>Bs=O zn850?Y0CnMknteeI@>owuD)R`QcCCl=GYJna0yJXvKDEIrO3o>tOh%98Zp}fyXpV# z49G~pd412pgbxY}*nufc*O+j}TugQ`%?YCb2CrLl#+Q7nW+>FpHOwA+@uxys_ER6)v4En$d72~kv@`v&A85Xgh2Lmw(*QWkH`CH-|@y5K3 z0jQMQn2rRjG2^n1@Vw30FwNVXKn_0~ag4F2Rb^Ca3jPK$;DScg0%i%j4^RDz9OslG zH%|Kmj~qJ>3FNW&J{hGB*&l~-v+}X5fiV$BtOXo$@QgAFC(o~-3I`O8BO`Kh0SwbL z&IL!80v9Yih#4T`A18B)dv!4N;xQVt&QAHv#xODP1hY-uF(enx0p!dTuMR9vvMd|t zIo7f*YqA`6F_{%)YW6Y#|8n67m3B#$@q}_sdCV0D%Oe{>z>HKnKl2Ds@}pjY9m$Xn z|L`Vb^Sy#1of0KHmw*McZveMIKVw`Nc^nM!a)az5zmned5dJ9f#_}2~detd9&_G-kBRM?>5~s-Bp7G(M-=E|lg-L-a(b zbk)$atiE)1)*nG0Mfr&X(7GrzFK#ru)3?4L)d96a3-aGFC%oKr2k101ShYh_b4!-v zPsg;=wzRL2Dp2=rRc{1V3y4oIVLC;oQ_Hj+qU~6d^#+`^FVOXOYUwf+0$Y2vq(ZfK z>@8piHr`sYQKfB#9`%#56Cd^%SG%f^y0wqcwGT-410p0hZ!Kld0{6b&U9%;t<{@DQ z;8TOOC}j2yP_}X)G-axSV7InwzjkX!+=#?vvHTXe{VY|oANs7>qNRmwdo3!~bc9RisXVzY^_{_6k0;#qbcDWmUxc4_-Lqa z3cv8iBmfjA@eI>2JHOA0CG2HWHI^;qGVbR7b>6riDs*u-w?8ZKC?5=G9kDQ1u>d_l z!oNB9c!ryIkW+3Kx9Wqxx3q%87LK{Z?l=j+vFebG+|;rEcCW`i^kI+emWMcUa@d}4 zx9vuD_Y_tmBeEPva(D}OATK(X>&MSMxR#(CfnExkxfV+wljo(7Tj70Jw_omsR-$gMoA|CThJb4TDkE)mH!G)myP~h_EUJfLlKZoN zu&MKQ6HIhPU$CKXdbjJ}taB(ebS!DxJE`OTd$c3LNn7|)J1?>ae1|(KsOmWwda<+I z&o27)Uz>THFZ7JRI|2vkKBMH1W?05&wFj2DC8WCx6!7a9X{=|&xA*U|CpI1Jw6ovy z!vDeYvJeIyI~Bf`&EI^CUVI7`eOR!(A-H^cI2zbowcCcP#pIQ*tXDkRKNC%Bl<~j5?yHIGDc{^b5hwFGv{)qMr@}%CD#%~*D^keV z4}Y>?H03$v{Ea_eez+kr-it3IOX4BcKu1_^#?ZuCU{0(pzaI?6ksKwj zOx2aeKo4!@nJ(knzVV&!{f(m2=wuSt51CXhnN8No7|L`mL}&7J)gC{v?e}TrWx-{$ zC@Kv4jNgZxG#{I1=&# zI)YaPn4)|I8CtTVuNIevFUpnqL}%haYy>l!(??OFwvZi3TJy88Qb~#xJ%w4Lve&nL zFux4hIMUEUnme^T%#chb&n_&n6nUA^6i1rFc?(9$gy&sG{aWHRlzirrZm2cO;j`!SWN02G8?zqHn43cc%I!|yx}=v!rh`w$c;K(4%M&o6QS zj4&%?Sj$Z#<)*SpE_EJTP!;4Z!LX|dRn#U#6xGsj!+i|IZlxA=neh)26>{;fpt#^H zCmVUp(3coz!V#`OO8ZLz9Yt|cks)pHQ8oU8L{dtatYXV7A@!2+LGj86Us0dQR* zQc2OIG|&o}#5B`4ajH_-1RGsu*$YB_m4aP!1>gWz2{_{*p_0bY~-SOA{ zrc2hsL5uy0Kr7v4!c&r()olb(DKNkQTLI{{fNlYJ6kmOBb@g9fEh_h;VC7_o!*!*C zlRs?0h?m_fo{g3QRZB&+)Q+Lec+~&|E*N7K#{FU5rC{{0OW7P23*w_BmW)_tx45`~ zaA*FN)!$n`nAYc#Q#cvrly^#m!kOt(_vLzAzN!yE!tBOq3PL4-T0IBAnpA47HQ?iY zxz^cUlUw02z7@}PiRq@(dHN)V{{XL=ssX^0)UEYIK-XP09)Mty0pPn-tVu3=Xr}B= zOf{BsYS?X>C`9O)Ozw+iSrffur|taovjy3A*u(QG`LHboG*~3WY$62L$ghGNN)+gX2zm3Pi83?6Mpw%Ci6Xqf{?!+`^%XidhY8j zN}V6ILl<2{$fHkeGv+`+(QfYj$^Luw%9>5sBXvJt-t?U(CBpV$NB%g_lN-#^rvA3J zsEo)R*sFcSn53d?7;;`|VZK@{Q;iC3w2xo~MQPLwzONsbgdH1Mc&^HIvXq}Z8zT9*A5u>8l#NJU7Uw7){)NGjVX>6u z8Il%{qJ0KCix8%`Cek1q1uHqQ9OgudSxfTB50^f&gev2pvoET{m9JdnG#O~X5Mp7O zqDbfQJP8JF!oi!&>``Z;$u@FUY?JN$-HRl-P7u8F3h^WX(V%$_d)_l3ljBUYJXp7W zZnIvwIu+pzr?FO1fL5o%XsI-cfK_d+0;xo@wxtz)E0kC5g0njQi zEdwL~0Xb8vt5mzMdWB80a?NZ+#(CMdW!6fh<18_y!^Aj*_G3&X0N9G!Q;>E|WCc*_ zQNOiZpAHwYf{X1+DNENo?$);ZsSYhugWa0+)-%6-t5jmDB7fJ$e?T&9TjK2&nbDcOqQ*GfgEEBNBMW# zwJ?!oNW!&scLF@_gng$o=6~!G%wrKVmTU5537MIE6F!BSGr?vfqw60{j595!Y|eLF z6@q6*=L+}?(Ji;oj`6Vbpq-+$Usl<{c+RtB>I)nws1ekmUgM)#y1yw2nbIw>w4&vJ zYBFouuYzdJ(X?~vh21aJ6+RYa3KG6V(^*6Ge33B zd46+mW1G+{?+@)Fam%3BZ|Fo%dLL45@Br_e=i2O(yZQQbbVpt4+x~iyrH5Ut>l!+~ zI{O?XK5-|mJPUD_8m%ho0S|KeP({ zE+fLLex@*{s_Q`v``dH1)xE7J=3@k2sBtpifQS5dfg*Y_GLrXob}==a51Y4G7r&Zc zK3=0DkLahKD%Qu*fMc(H-W^}}t>1pHyN|o8rtbSxITHAVp5)cTSpDlaeET!+w8h0A z7cS1l6c1)%!l07R{PgcklEM8Fip12z=fKbJ`s)5TDE}02Zcb+c6Ut}+a62Rg`{)mu zDiDD#5CdnA0VB=-ChSETMea_g+j0;208RN$ko!`w|H>)+FbG~?Pz9|I{btZQYS0E3 zj{kCyfn4xIIX4vppE-sF$c?Fx+# zlHTycZ}kk8uvo!T_US zaTvv+7>!X12Phe}Bn0`v>|SmUDbN&2VH&A%ua2-4m+%@3&vF##8KLnTdn6pik*1LG z99^*+1x)8E3t`$3oZkKs9(#}+%aMT0&>lN(5HZ9jz%7{iaUA8*69t6)K*;I}G6wYr z+7ePBXXhUQvIT>YnD|XD*73-qu@gZ8B<~3&1`stWZU@<^3ti+OYsexmk_9DFARUsc zc8(}YvJ{KN#}Y{=r|Be7@|IN6mi7vAev-!Yu@@CIfCY><;dx=PUW}EK4pe)iMiPavm2? z7si6yIOHm^GA!NEJpwb2UXc3evLUm~p~%uOMeZ&4u`u!S2IuiHmohR1v)Oo!P!3~w zAn`I|2r&~gCH^Z?`h2a_GQ~5&aWW~>2pLicCkY`13A65NU8>?UThlek12$vxOQ_Nx zGc7e$Gc&{NE_XBWdebYr4mgjgHb;&)2Xm!TFf>IoBZZQmjKM>qul8OBH>HX?k+TYy zvn|u`15xie6R9lQZAJ#{rNpx<*m5!Xa_bi3wg#v=|4ZxkDLmm*yU4RVH6;K|Gd+DL zKlPI=)u%uGGdcHC1kH0meN#9Jv}wL`eFiQS{Sz_E=r{FDEAKNu4)g){)59D{M9*hK zIW#+IGeEtndYZBd6EyZrltBe>K5umMx=Th2)On_oIYn^t-l#_RM=!BcWo|6y-tI)l z5!kBk{wJ1ncT!YE3sCxe^wp#hN@=P|XS6Vew2X?>NTqE=cXTsPElXL@3>)xCy;MTL z^g`n;!uoPT-!5|2kmM-GN;gqT6OT&KbR@@;HS07@`)^IzG(H`)9_z$UgX}Ne@k|%B zLM9MI3^hd>@Xp*aLSd4f=I~L2)2}3zOeu8}M5quk^_tN01&YR3xbNRG|)I^Ar~kj$;e9CnuIk$xvKnQ_+kHSsfN#)w5Q+b!E+g3CHtg zJ2bppsyJyj2xk^rOY9YM&Qo2sXMMK#I80=3(@2umXfe|uIwjfG^U8j<$)2`YP*!Tu zCueCvK6Wrey^-vkR%nTFV2c*X!c^VZl{c3*N!Erm8&+t&_G{aA8Ez23^EOEV^lgv!HL=zUwJtG#E^Q@mZP_;B_Ez@XRx1CtPhakFi8gZUa&Z0$R&Not zL=MnT%hsl}sU4hyYrFPXb{1?Aci-fbPf=GfFOM+o_HLV2OGh_R%dY%xHe+3KHEa)Z zKi2?*w_1I7E@!uS-*k8xjwwO$c#-!Dw=i~pmuhU+Ra>eHl@J3732^5(@zs zHG`I2O}1Ox1X&G!`H=ZIks*?k3J%ls(30Uax7-DPbg3F}=B+|Ky#e zB%XIN>14N_?OAtQ_sNL3_QF|D#~Gld6`v8!p&gENX&5pPT0s@s5&yZNkw&nF-N26F5yUI-?4Ws#*4jwHT*A zRgect)Y4jr`gT;wr=3ljQme_RH#(=S`l@fui|Y%AIQXZN*_feP>CSqpA+xCGw52gG zgUV#DFS)OmI)nlHiv^po=^AqtIqT@|Jyoj57`w6l1rk_@xaDvX##^_R*S44Wc~OXa1gi!F zYPz&ykOK9Jp%<>>`bVzLy4e~~VL7W2fe6~02jE+;<$J#An~48fxQAQ66&Ss-JD~sD z%edQ723)aODVGivl*L=RrT10KT6od$oMl;gRfl5oWpIegy@Lv+Na~`TYQ<7YT(IXq zH{7K=9GX9T|5)|GfzQX)Id?+jzyPOY1dINsmdaXy>H?msr_v>OYW%e0V!;J=ypvm? zD|?<-4o7={PY%EUlzhbl0IpmsRov>WA}hWlZ-1v5$Gc6(cU;7EwZC1o#8sOFawc%X z{9^_yo)AZ~)x3k7qspnUf$lNR<^0Eua?5$3%fEcj=Znlmz|YgXD|yms+x*ww9M1Fg z(1AJ8C45gtV93XO#YslEh-=B|tH5<%4V(Ji~qcY6d-+@p#d(&Y=% zrHj%%wADT1zVTbrH@&tI-P3FR){{WDon7R@TXc%uP?09#M7MnX`_n<)c$j-)(%EvU zolUKs#5o&M%YDv)ygAqG+ok<=G5$T#jvd77+HfP>)|-7to*fDF9g-xu7GoP3>P>J< zILpx;-=`rI_}vE-9tb2`V&FY%aV@E@oYNpk@KEzFa#8Ey`Hhu^6eTs4U3q?9Ji9NR=GkaA z*&R}C2Rmh+K_4UJLOR=v-stNQOR~VznnbO)o;S{&>5tmd7aZ!VK8jI(vQPf@g!Fx1 zz2v_hpPgPq8-CkKui%9~(%{Vd*uLcPqORc{J`45YyNbeiui8>R+VohbZT6cb7v`zs z?A*O&tGl!-?c=Oc@9W*|{#DTL#Z%t3oU5f1m#y;McrrCBO1Qze{KR z=v_Z>AA0kVv-54f^>cqt??N<`lX(@Nq<>1s`2F(p zjb9sE1cZnFxWgDAYv1+*-Cd_2*{h#wJ#mhk%n7-FHznTQ%YLHwo;1>q6Ca&1$z)fRP(}PPb!h8LTpjSLbdL3V-`V@?|@Y&+GS4 zHNP`<*CaSZ_~*y|A=oDMhi5nuRd@0A*l2l)i9?wg0=QR60~&`2qNp^g*XNZA z8!H=D6}$N9I1Bm3Hs>j+8!GzRN>R2MoUELToNAgk{1Tl->YG*yyeu8c3JF-N9WLJ3 zoJlwegWhY)yKQZfJ$@}*?41ZMpRcb~e)*{00^lig?N+^8f@2H!L`}pn zff6{63&t7MYPbj#Z(=u&k&JnQC^Dr=Y#TkM%cap@L5cwrC0vOx$IOyYUbVyt)K*1u z97n}GG*hR$oCkI zNoZdSy=4A6w`yH_dC?|u%Qo;bz(?U0wjy^&N5lrRB}RHBX^CT99t*xa$Oa#%am~ct z%lPiiu2-q?nEZ<{=G6qB;v!<%-XM*jBR3u`Rbp+Or_1J4%{n;b-L{>8;c9ttXVIi( zizKeJBxPc;g|58xqG?AJqb+!eS{eR@PQ7GC2hC|?xl+4Ek27PbQ6eDZA=pC$wzrxkpD3ihFK zXZ7Spg%_@vUWxbd17n9ZxCmlV_>HHF8Y(^{VqWU42qbsF$;e@7A9{FP z1=;!Nq^7R(AEAS8xzIhK+8Cdw{NUN>fMSkT>Z!WgWGiw`s+!R^uW|}2l}(Z~XE1?+ zB-^mNu7u{0O8&}fDd;8Jo?T%c+oiLfMFnZ3&yFicKSW+?X{#P!3#GQka;vGgs({O< zL-LXvQMB)7O0ByCk-#o2E#>N9Isrcjkyypti!XV`Nc(TLY)1Sr!v$`43rWH){u{2i z3gau`zCKudYq7i*LGr~IQ*7vU{U|)w!5>=}vN|c3jHrV$=g8O{VcpyrN{nC#^vui@ zv2C!k2qdd}Y{@m`KSkFlw9d8~J#NS%|8lg-CbT&9#It3rsf9nDcx#JTXN~mM9V_d# z4z#ND*nU2Ty||`d2W3(lyRX>Y-aDIqC2U#R?*R14|#Or3dIZ+9UQo z`=qrSvU}?z6HoK%tPkFNC&K^0eDP~i?~}T!OVdp9f)@Ea`L>Oku(T&`{UnKlD0S9xJohO z%Uk#c=sX`aWPuoLU;!P)HM%KAVI3rvcYIeu@VwzHL$jR+?Uz7i0YyU7NnxDK@C+BS z24>}>9Kl}bx|;yThH1H01TUi^0#yn~JY?Z-fXGB4zKe(>q!<;ocfxC2v04l3;uE2G zA@iwaixnfC`C#Z3Ir)iHUR)sVCd=yyk4Oo){^V~X(V!OK`GZ%UIJ6SjT`KoROPHEPOX4`C_H z9s2Qc;wa=Ql=w6O)v%c;d?hraiN;5wZ*IO5CEbQa7-U8=Sfs2MD#4krPaY642Q(Kh zapEjmIwzRZVki9Q$4_|f3r+9zimxCzNrzEu3U;jEJ5VFTf(jIKC$pzT=1EN*>QP?$ zjFJlw0Md|(bfhFLsYy?Y(v+qYFShKH$Ot;oT=J?4BqJyHewWBp=E+#UWAz~vXrNy&dXnki}!?9LS9dm=<>?%Hm)j5Nb;T-0q zsKBT+$Q1ll8&?%9Qwb}+xEl7bD1vDc#ahNd*0C*w>#JXZx(mySqMb>D>1LHVO;0Ws zuY(<}SsxqOv|3=Y83;gcLEu{s1Xl$?Rqb0dlCZ+QmXLfL9S*A_v!-FLXjCz62Y8Et z;aWhu8sKhrS@2Wi9(N$gmFsd5$W=NZ2ehFrTv?ZPH2ggk0NA~NcPDUP`*t9|8bE+} zDZ(-Ho>!+rZHisL#@^I^oqFMb|@-2xb3{s06BZg3?W00R_20s%n405m)S1Q;Ly z6y~r5DooE*I;^^QE!G#B<|-=(tgxE(!ucGlXycEH$)#)@495vUj|%k@RM~w2 zuinYDT}{Az6Xn_bMl)44Fo2(KIu<6k2FjbQ^1)=5G?cjai%HvW+9>2~Aq+VNSe#)y zr=sVm`uUfGE_B^S(C9~BdeYsb(5z~G()ytKzpValtos;wskJDA&^z=rrc&&uExY{C zPI0yK>}PabFSKmlXs_$dolgFjhuQCm_lfHrO2|{rfnUvBSoaQrXZk2=EvI;9FPzvsKT9zm!`~rL1qg>tEl>0LnXiqyM|;yDUPw*ZuUZOg+$xclbTj zS1gqTP5<7$mZ^gM@4AQZ>z@z(=#w<|zQ6kFDO*K5AXrf>?`7y^PEWlIp74LtwwE*i zx8UnxvY-keWU*P`*av0CH4=Z+P6hJwYaaO6M;W6?K|?JCZ8IWGW9K2sM|(}jNQfsD zv$rN^N0l+3~+1QR5FoK+fhF|xB7a@!87ljTb zTEJ8~`)CFAm2RDwWxbe-nwVq;z+vVlkG|Mn0s?v+2s~25Kkx^R<+ydkxGVL=a4zO{a0-+$zWu7aRP~8YZyIo z!i>4~fI1m#0P~V?6bL}s2Q(>5CUcWn=#0t0lGJB@uE3ZTuNW8ugDajhm&#I?LS=MW*@84vUe8h@r}h(P z#Ei#jD$*yN(^;6Ncr6z}R*dP5u!w(b_m;piW2v@zie{aL!kTENou>(y-N~C?1)i^o zn&T;Zl}Vl-h-l5Edb%Qjy=j?SC7$xxEyjf`3^hz1SR2Zxm5vEpyi+Rw37`R5nmBfj z8HJfhL^jZ=mO?py%hxQx`Ji{@gzYDx^cJ6Ul!ED*bissIZWJacx-lX;h#-oJ!`S|t z`-z)hsiB;OZ;!%pABrFX#2IdNml*mSb26b!WTW55p<&sgK5Cjm+LEYKg}S+!oZ_PD znWJ#Gqa9kJPD%^xA_j}WoHmn|FZz#4nn6s;Q(k&)-q$O-Q;b1MrO0`v8+c}1N}z1I zDExw!C}^V9;-bZbNIN1&ZgHieLsVuMIAF+mXBnvP^hZh3LWZiR+El088JU`C8cT|z zg1VuB*P(e@sW9;&#D`OU$_&uerS^BJrIeJhGex6{E-~41u7YhzM5C#hqQtfX3aCy6nqBfHGncD*Nw2&b zuWi(m`s$hupVD=h@H)?y=>R6A)q7RF(OFBI5`drP~V*!hR&^bUBvj)3ysBAND z-%zI96J0mcqhBepkXBOCHM>)CGqW_Crc?PoK1&}M z$up}ecpz(WfI~q;OSBqTb36&Lym6p@BdXttv~zl{9a~^hJGK4UD>vJXPi&clqvs$`ZY38@Cq_>c3g$&!rPCv^V z@e;G8YkR1>xMbU44>VA%o4PLbd-^7=LEE{itGHL|g%hh@t;M^&TeUU|wF3&U!wa{z zYrOK4x5>M^%geaW`I)UDquH9W*IT#W__b<_AJGw%Dg{Hs7E`m`IEWfT4P1E zt?BET`2)M<>K!l#xHH+J^INcNi>LRCzr-?o>^m!qGHr5OOU5U_RkL=ePtwR!oo=-7g|j| zJfs>Nx%Hc9L|nxNi>}n$RQbYGTnw|d`NA-47D{@2v|GloLZEaM#8*Kp$w(rGi>d7y z#=JVmms`gt*I8I>z4!zne4MHo@_7{kO0+aYg$y1rgU1+)Nsb4`7X=-UtaLJUKXgpV z*ECaT+?TXd3Q$?Nr*MHqyMaTqwWE9`%!0^K`l4#E0J*HoyUfeFYy`aw%)u}v@1kuR{66$==0_}qwt0oS;4;uZ5^^6^+icVf7S+-mARN771CVnJ$A@_MW&j6qaVFL$)^Kr1jZhbe8=%uDY{0CG zrd3VG>s);9Y|59x)uEVh2T5d}_+$srZT@BbZJS7LmPn1G=+tk0gg@ht5Jah0eSlMK zyd^6ET>WRFwrg`{lEXHQ==Ns6#%K1G*&V>xdA+Nx$-+e~+4k(sw_Ck|!PU6Gj~U?7N2=B1>z6$e*{w~0A$_}+Jpr@ri@~+oP=;&kHf+xQhDxZ78t~iU ztD6qnxRA}-#{Cjase4iiB+UKU;1<|}jb9=eX9`IG3<+hP$X(a%+Y9T_8EmerEz;o4 z5;k3i%Dvo_*4$$qbrV3=#kPlLJz^&5Z!P9xw#@-3-LKNj-P0>`#m(P=)RY_;)c8rw z59_Y*Ta(27-5EXy8~%7DE22Lg{tg`Npr5;!`_19_&COZ034H6}KfvPJpwTU>E)|}; z0EFQtZq2S>SB&Y$PyNpYDwRMUhN&SN3QnahEx=tnu?mf>1PLe zo<8W1Y|O3h>aPy#!%X7g$mXRU*QegRprgu5rz`x zPT8=Hrl)M_#jd6U$jG(+w3CUO&tIXPFFQB@o<7_QgKe(Eq2lYV%q@rHKv0an(vH+} zV@3ch!97df(H>46zV7Uk{EOH=Lv#l~Mw;}bmW^j_@XKI3u<85Aq9eBQ~N6VdmM z@4u_>i_XdI!k<<+jw7z_Ztm^YLxZn7?iMan?W*cSZO*11@z$5T|J$Zd{;@M?@52hy zD4+61>`4T_!NmKRNX_jydfyyh^W=9th#tk7yYs0L!6rZRd5-V$7VdTJua>*;Is5ZR z|MN5-^szWPYA$zKC-Z!1(b#Uw0PpOM-W5;p=c~AHQ}5qn|Mlz)^jVLSjPv5A(LP7D zN_hR|=G%jP9`OFoEMH26@OM?eFAu*VuJpF~#btlhfe*Tk{?UbR_{ZMZiLdx|+wsNY z_%n`2_4@W?kNEf8&y243#%*=U`5BRS@s!`CR2ai?FZVY8A8>v7PdoC9ulI9RH_e{* ze~wxB@L5`V`+mQwc>n8<|M!6Z`#>Fj!Y}r2-uuRH?g!8KjlcZ(ny{+B^Q8*YQk=wN z6#HpM_odJK+W+z{68e+>{c9TjiYNHh|HkI;o<`dJ&Y#8L-~Q|Q{=5IF*;HF$4*@_< zTJ6PIZ?5Wn1@!V|fNqz#dDd5l|O28m2DJDPi=bLeqVBZ-dq^3efv8?OB)hAvy1zhI&5@& z#M6u70}~>Igu^WQ>FWu6(#%ZUkhAyzMSF#|^nGjdf1o{r%ql{xE5^!tyU8omJWa)({2CQ$TE3~)#%!A+ z?yA9Qkd4Jwc#L9$d4KkW?Dy<9%7Ph(x?D@yTWXofV0K(K@@PnZi3Y|6*|Wj9H9m)R zx7syCy^~4bjx_lgJ-U2l*HHMHY`Wh|X+OrD{Elf#NZu5Gda`w6;o{&yPc0g`a_((l zHRml_b!n4@Hwz^kx?y+ri1hBRy}mE@DATRG&l(%9`kL+iGrh{W>>|TXDR8hjk2qSW zU~aGf9t0=A@ElAFI{SL6&MgHOX1SZU%XHL#EV8- z?L@l(f$g58@`{f>7=xk*z8MKL!$2o8J8T;tRU8S3C4Y1&$X6zO@({*stO&>as;Y7t z+IoaC%={$Wjz$Er%u>tymg!QkFP#)KPRqfq&0kwg zQc`Dqj}KcCRn@V8z7L*6&Cg$H-j)Vscq# zn{@VBD5ITnT4OaMN7rnL@uy5#y_FN(I>jxqq*W1YE?OFJ3ooPk}rXO1fYdcu!}9=d3r zN4@sXnlaLNXQzMc>!!c{FzlFUZmI05>E5wit;x9>MYFty zJ8oCR#=C91%?_1q9`&x9X{-b1PVBkoLZEWXFULG{%{S+~bI(85{OrTgu9)$~k*4YG zz50ecx6@vxoFD{<9i8=V>s=f5)Uj5*_3nz{2=CbkLZEi4SN>G`OWk*m7;xX)10Esa zCo&%KSJOK^AE9}F{CR49fXR9ahELb_X-HPYbf9`S%Y5%CmM4eliC?-`<+Uf9`{v&t z_bmCTARjyem@*C}41f7^5&QVpzsmei0|Rsi1oKtE+qEiY`%~Zomp^8B)n!c$Afetu;EF z01n%rL=GS^h1c8PC{p#e_6qTP`!FH^HBbNp41fS596$j8P=EnQAOHjyz!@cg00RWT zi)KXQ04kS80whra1vr2kA$UeQ<`6xAa-pZLNJZya{&9ox>);VJaDW5=AdeDYBmf9- z05dl7ixPO_B>@lsN}|z{B^==a>WD@Q1mKf?oFEiQw8C*QD3FG1+(r_q#SDaTj3Xp~ z0RUit;RQg9n=GXne+f!E0-%f;@TD11nYe6ZkPbgQ(kiP6%R@#*3Lew|F@b%(mT+MraPTUO^6`{3fQcr7zH z=+4EkC!)4#=tOg5sG?jzhh5Yp01%K&kH(SyqaGdU7~3dEpq|qL>r@{z=@U~ouymd> za}-HGP^C+VDRQY(U-{Q<{Y|j6^ha7F!Br6yhjf7T>S7t| zkmkJ$vI3+a^;r2JsrhxYQ|m14QcBq5O=PsB72;P<%gj}dwE~i*1#XK(*-9PlX=RY@ zY*m_ChtZX_Nxe&rS{7T)3YUk(^&se^J6-BlmvgA#twr7mE#^kixwHkCZ3A~%oLwfn z&zxCvziYo17T0&@ZOD~`m0s_zcZdEIvI=>>RnNm#gJFB?uYC(!+xozFK?dd)84$eP z+%5RD3e2y51;<~O?x|Gtb&-Id+ulnBm{JaYYdk-UVQFeOui$2s=#)`&b0eytc~F;>>Bj-25nvzW$U zcD&Byz}YjHiX)9=P!~*^IR227sl!T900U>dF)nngeT!dMYp1Q8UTmLQ*Vhp1T5+}Q zb+dj4Y|WlR)@`kD*NlB*M4Mtp%&zsEvwc6f5!Yl~9hbi|SguS+ADia6hl3v}- z@iK9hi=1F%w$!#Y{!X1oJY%qY#>;*F&~_l|IjH8+@0u`lu+^91OaHkmoj!1*OQ+~P zH_q30Uh}JCJwpQ7{yNudj$Nt`cMxJ9JI`@$b_+i&Jf*E*+Xn$#|5CH;Wv9D{?G89+ z=Z@6sA^ohyA$tCipWEA~704sX?v)2$ z@jE`u(+cT+rHenF?!P`AO9oF!zo-%zS9zhvTRHfHw9GOsfKxA{DZsWlz}I^(!;>oi zizWb!uaxNiKFeT0L8HCiTQ}|tISOPI4g`tds6dGcL5P!>E^9v%Y&R5)1qBQ_ir5SW zc|im`KM%Y>8Vo-hbPE1!8Xc?$SnEL_bcVhwK_PTJBK*LFIl=?cj6Rz$5v;qIOSS%! z!X&`KX@WreO9m`#7cF$c?_<6U{KCDvH(6l`XETxsM6D^bLN#1Nv1&s%T%5PTiJO=X zI;@`<6g)hH!r|M)Xj7TBvq1N9h9&GRQiuykJcm4-zCESR6915MOZvR-B6W#I+E?H zv%k#q_2t@Q#jtJAUZu=B3)J8(Q zoutdZJ3A9_$qa@nz~qycWfp?NJwn-mW_PBj+_J8 zy2r{YwTXJ8?Tz6Tn#9$qrJtR0AGHA%>X@ z1LG0McCtMnM9Q6%8zwoP-(Ve~l*H=s$`PbWoWwqz#L5Cgz&YeMo2VVcy05CVO8$6D zN~jSSq8Y zd4s*P^fv2pxhIi51Dnh;JUL4&xugutLb-^??25=VKs$Q~ihQ}xQ~~Rf&Dpe^EdUqM zQNhsEy;5_q)u7Ga1Wwt6NxS4rWcwQ3x&q|1HaIaux~#pf61YJ$1LaJG0J0mrL^Rkm zAx)spv)P&E^q=QUP1P7O-;^Ej2}>8t&g10H=krd{IlawPGNEBK^JJ~I+(KSsPfVa8 zJ88|avKM=@vee-;`;08yyw3bIPN(TkCio!Dti~af&jHm4oAi!4Xwdeg{++{7(Dh_c z3Pn$u!MI1$m!5PrdSjtB$WZ>=(DVetYtYURSkVgjB^a>I>%^1`2~c6oNYU~N3}pdx z3Z@uPBBN3#4z0uliqT~X0&aSN;gQNt?7}xRQOy&Jn={ZL9a0!5(iSKliyX}GTG9`g zQ3^0p83juh#Xu_5&6g<5qRY}1=u#rxQn4J*HyhI?(g0hssyk{U1NbF8(xXiZfDz&% zyBekhaMFpy&wT7ckfTtWfG8lv09)Fr*|91i6)G<(AweZ7Hgcmns-!aFB2FzOH0mfO zy;G9gPYe(xNunf35~E3iq)|Gi5_(ly-6R62(HTn9<=Y!bja0S%K)g7mfLG-xOQIxA z%_v;8Rbv_@P~ufbY9x&^(^HaB_<6NFU8otNqyr$IW9rjIB`0pW)sczPoWvLUd$I$Q zIyyKZ1fV2=(j{K%CNR>c5+c`wngBj6(qY=pP_#R4U9DO&CNnM6LLDc5^`*M22ggN)c& z1QW{Q84I0HEubNK-K7NhCr$NNn56)LA}Emx+L2AClC8cd!r7M4p=3SQS^Xz)m84t! zrCg0whg~DEL`*%*u6t?P*2)4JQq)F*+K#1GN5a*TDx>}Y04b4b)-BcAht<}BMcE73 zSPD2)TN0{4Ra-wr)R?^}1Xa^s%s|OxJ643(2Xb4TYFxD4B~t}lqVg$`id;<+skvRF zx;@zsWzkNAN^Gn&>5RRqQ_=G@Su!M*GPTV#m002;-N{<6(><6 zUesOM;)R>*m4N{oovD<*(ZnnTThj0yUdXIoelgz|fFLC0#>5L-w%DOf676N`!gIr32J%z>oXsp*sbtj-6m}(03!cHhDo7}f;`?FFa753KW2`I|&&MOm!;MTF9uF*D zJ0d0`f1AEy1=A*mDlzt56jZeCr4hA6IyFu=HlDMZ;-CsC96wf9E285zl|nMJVzRLj zG)7^W64txaz`qzZV2fkbRbeMSIYLIDAoDl^MH@$MW4MZBPTn#&tKbS@>_}jZ?0yDsT1dX%5Uy4a#Ut?p385r z%R9N`r_{)E21LK~PASO;a!%a6oTwUR%#K`VW<)P{o<_0^W^bP5A93M`j^1O~-a7Wi zdlm{mPUptpFWh`@MxA^MRw*cEan!CWCm7D ztFFhdfNK&OgBy*~WFuU}dE)U(M!w$0)cETPkZbHMY{TZ-B|~JrHr#WXzQq`nG z1ynzk+@SL8UiH=8^<{PWxFu9~4+hsYdNE z7CQtd>f^9)Iz5(O{m1X7Z=F-|KxXj}cYzUqAQ*q=QRMJ}hPfJ7O2!VHkM`0MpToja zw(kn>B#l1$(q$uOf$Z(>PhP_xH}FTk;t!5;r+#m)uD`rCa7%V&BYtRzcIpi8+%UIj zAdjmAB)iHU6e(YU2OXO@m|rY^uqH2LX~w}WH*1)TbB>gAEar2ROlC8Wa*1wX681eH zYqdk4QikO6BbMTo1Y&TO^caTcK|k}QD`B;Ew@sIBhCbj=2X*G{z z;$q)*h2CiBb10U4#uN6xZ%*e>M@4>KL{@P2e+HRq7I#@9_jOHh8Fpk{7T^MJcL81T zW%mlf^No$ zSI_vP_-SuLNJou^w=7fN@QSziRj+7+M#c(WQ-&XQUrTwcBt16PzoVOHQIC1QG%p68 z^jf@m%Kpor|6&iW>RxntgI;w~7cPw>Sl(q*p$GaNhk8MWOf55dlmEhX(fEuvwLINX zf}DDQRC*J0vi_uQNZ$TMtv`1nlCbwZdoAwwCRuw%uFMasGqlh66&(9EBOS4Rd#vBX zBP8gscjm73?Q_9PR zcicDr;*XpzQ~ub0cjQlg()V6oX?@#2c#lW@kks`IPRmk|ei3PtmYwe!>U; z@E8AuhCde6_Rmj$^$PH$-!Zvt zp6M#uvvZva+t~6s-G`ly-1R-bZ;$Hvq4nTJ2_7Qy-34kSIzB=g+Av0vP$IcqR&H|2 z#1!UrijJCPf&wh0s;;uOy1v53%BHGlT87w?>h5afdM4Ag+ZL=O9dYapR_b86e7WsOHGT9l%7C;KH~z&41tc37K;Y}-%9k@JhD>0@0=;CJ6=`O8HQKm?S;OY*xz4X9n z0=5Ah$bI1Jfy=%*1jxNPk7=ib0P>72{p9S|)33Kk{Q2wB0T;Xj7;w43SMUYEV+gRF zG?g@}v9tC?SQ7mDB@$oYK0!YK{`~_0c$a@5%=H{}^w|d(4D$h!po1Uaw_pB#6QBp4 zcmR<1om~^+^+XbxJg6WA3{DcFiKv9&-)_DA794QI8D{`;9EMQfRS24NVp>v=_)U*G zZWLjE9Cl{e1(_{}SpXLfDWQ`!{)FR!KoZ3x6xC6wAeIj`v4)pfW@Tj+TY_1obAs5| z0*KL->64gTklE%!dSQ^J7j~NSUXF71#N&^}V8tgf&4Gg_7lvA)=ahnSbVHzBKFVk! z&Gix|qE%cfhF^P1+GsR?vJ`2jWKfDyMjm7eMXD&l!|A9OISMKcqP|K*sc)PLVKPIk z!)C2>h9j#dPyH$cp|3@{suRlks;Cjg!Wt|hr$Niyt-R*iA)3Z&>i%lA^|&Xjt<*|- zY!^|bFpIkDvb(NXw@CSII^mLY=5>S;%LYkq+47;h2Dx|EpypbHue~unt5z=l{;N;G z;_hK^oDoYru{sIwxQw?7?*kpgoK#HktRZhS#mBl#6EDZs1T3(9A&ab)qx|N%@ygY- z?DEY+&Ag*G4DZ}=I2Z@*=Fl>`v}n=K#H#et(GpEnP&Pl!(5FsU3h>ck4uW;oC|~XM z*Yj>I^^IbW-AU6_r!7v-Q>Dbi$!%X5HrjL#dbg)-m5n#pBR1=|Glk5pHfpH}zRR0> zCk`^(FERLbQgGJF`2t{bEn(eKA2Q;A< zEXFDpc7uc~EC>M61;aA9@P#+@(L^pNhYRjxha>Ev50{oh(*dg}GZbRo;wHo+rmtW{ z3?dWZB*PsP@mo-wpF*-oohq&`a$f9IzPOb{94-<5j7->K6v4+vHJuTMW8C2zF;Trb zCXI$aoZ||qcsSPKv1<;)2p?hS$9SMFkY^htA=RkFD_WwEuu-Ie@*&AII&uj%)E?a^ z$rnb(FOwj|GHItgh4B#}i`Ko=QsD6&VH7HpmngP^_b>6 zg~AVLV+<%ZA*!)qSX7+`?d6{MNKuS_RA2ssOI-;!x=4>T(oG@72uM3pQj>ZjI+tAO z?Pwaxzqyo@FlEW=OvzAq+B9P1XkA9#SUX+*lwv_ers#;eQ`j9<5J{EeQl+VmqN4Pv zsdQC5r#dFDI__em7@$`9raXm~aZ+H#+*om{)3Q=fd>LIU8q(T6wP6)Od5s?XVz);x zk}G4abL(E0hYHtu?qK8Ei(v{|SgykLll+_>$V?MMe8Fe0kA-YxD@o3`R#swQ%4=1j z>DSJFR%M%g8dg{9E!WEK61YR{X&XAy+R}D(HiIq4TI*26=GK0~rR+|NTH0U&H@K<& z9%x%>Tzu+Qxx<}qb2B;DcScvb%l=I*Z+~UcJ+O2K_!E3wkZd1J4{n>0cir(~= zZ@koPqcDMK-dXuFx$;%-2D_W3`{oh8@!cJ0E`g~R zLH$Pby%R2Qg)MyH0~@lYdZciNF>ERhXZUtqByoxPJGuxHGr=onaf^uyM-(3q#vLr! zWNS?07nmZVzTW{mGmmh zMgAie0ZCFYBT>v;#&43d=4D)c5MF9NGMPc_w>Ja1f@7ZZOH29Vl|8pl^yRabH#g<9 z;aSRp9yFnC3>AV@Ezxl`{u-kjOAitlQJ<`hYu(`fBRG(1Fx&R7fx?e|NGJ&Qn=JK>+pb^HR9zCW3?f- zZ+^!|vKrqwRpBi~$6kD^2ah;fy_E9$+B!BpdU+yiio1(HJD1b>5zT9^yHn(Rh-2;f z!$m%FT`RRglv~4H8+27ZFY9ZTs%xqqkgu=N z>?&TP*rQB#lGxI&m_s`~KGyWu4wSK^qI=r!&QZ3vee4}kETrUqRlft?n1KiQ+bK$? zyjz=ri+B6nVtQ2V`iQ0SE$e({SM{Z_QC`p4gXGqV5vo|iwa&rg3l-(Tfu%>VNFf9m-A zU(^NQVF>=!0OFqkI@u2);QaaDHRawdEnv7YRRqEu1!|o@S>OfUpXNOv3w0m{LDUDD z(Cy_`2xefLsUPf#U>_l1pq-$}(H{v)TmY_M?`YNwVj1trpa5Fn4mwv`;o$$7-fGpL z8Wmxed0h}%-Qw}q5jv6+vQ~FNp%J#7f=!_jUSY#np%U^G%Q09MS{K4W7Z>iBviYD8 zl3}tD+OdJ5eYIhm%-b8fA)lS08m3_xLYc$KVK>#G;Phbv-eJAT*B{njAlB7>5u&si zBAW$QB8J)`T1RI&Vi!Up#%a|gQeq`OT5-|d9!jEnJ)kE_qA0@32a@6_I@b!GB5Gmc zgZ{K)ooOPoJ&_ZxVj~*T6xL!R<|5OHTP&_00lnfZ`Qo|kqKJveFs{=b?O`z@A~RA< z$RT4w#TF?#V}~`LE3RTSwpcKN3pXNHG|rAU;!H7WW0qaxx{0IkfnzO|Bg2JAJJMk~ z<`X>5;5xPtJ)Tgn+2i2hBNp}Jz3t;d$>ZMrqXq_~Kx*SaF4RGO9(J4~)G(yth~h)0 zP((^(8!Dt#StLVHWMUO$nr$RUc4R_jWcGxl+hE=`=pCz_q{F0S<&~sZwIuV6WCy(@ zpv~m#RUP4t%|}MyN)Ay>MpI70%}o+qO}ZjcDopn=B~PB0QbHy1MP(rR`V&zuSPgi=S`haCva?egD9{WnU)FUjk;A3Z^{@W?{C?VIpQvE+#T6W@APgWDetFN@grorY2J6W!_9?YG!YB zCM0s^XF{K7QYC4YrfK3JE}`a6e!^;|rct_P{smTS8sN3iW&>W|ZQ`a=>She`W^c;h zZvyB00p)PYCQ=%wq&UWMGG}u-=W{}5bV}!RQfGBmCu}C?@gM*|g=Tg_!FG00cY5a& zfTz}srvsH|L8Rw-($9M4gL|^4`M@VV%x8R7PklB?imysfrM(nQkb6z$lHJDVp9Vfi?-4dgyp$DTH>ZWS}UG_~`^JhM?wWp6coHsHv0u zC;`Zbhw^BDM(U)71$T_baLg%iY-gfshLdtBol!EZ7R|Mig0^Do&2XzId~3HhOt^9axr*zzm@BcKtCTK8x~}W5xT~_h>*ZKyz1r)& c;%mM(=e+W3zxwOH0&Ktv?7$MNeMA5NJNT?z%K!iX literal 40063 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 diff --git a/docs/module-doc/channels_8h-source.html b/docs/module-doc/channels_8h-source.html index 97845d1e3..2c736052b 100644 --- a/docs/module-doc/channels_8h-source.html +++ b/docs/module-doc/channels_8h-source.html @@ -4,7 +4,7 @@ - +

channels.h

Go to the documentation of this file.
00001 /*       +------------------------------------+
 00002  *       | Inspire Internet Relay Chat Daemon |
 00003  *       +------------------------------------+
@@ -146,7 +146,7 @@
 00238 
 00239 #endif
 00240 
-

Generated on Fri May 13 15:48:40 2005 for InspIRCd by +
Generated on Sun May 15 17:02:04 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/channels_8h.html b/docs/module-doc/channels_8h.html index 4250c94b5..58076771b 100644 --- a/docs/module-doc/channels_8h.html +++ b/docs/module-doc/channels_8h.html @@ -4,7 +4,7 @@ - +

channels.h File Reference

#include "inspircd_config.h"
#include "base.h"
#include <time.h>
@@ -433,7 +433,7 @@ Holds a complete invite list. Definition at line 95 of file channels.h. -
Generated on Fri May 13 15:48:52 2005 for InspIRCd by +
Generated on Sun May 15 17:02:20 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classAdmin-members.html b/docs/module-doc/classAdmin-members.html index 35e715bfb..fc99a14ef 100644 --- a/docs/module-doc/classAdmin-members.html +++ b/docs/module-doc/classAdmin-members.html @@ -4,7 +4,7 @@ - +

Admin Member List

This is the complete list of members for Admin, including all inherited members. @@ -13,7 +13,7 @@ -
Admin(std::string name, std::string email, std::string nick)Admin
ageclassbase
NameAdmin
NickAdmin
~classbase()classbase [inline]

Generated on Fri May 13 15:49:19 2005 for InspIRCd by +
Generated on Sun May 15 17:02:55 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classAdmin.html b/docs/module-doc/classAdmin.html index 54252f78a..588f9d9e5 100644 --- a/docs/module-doc/classAdmin.html +++ b/docs/module-doc/classAdmin.html @@ -4,7 +4,7 @@ - +

Admin Class Reference

Holds /ADMIN data This class contains the admin details of the local server. More...

@@ -82,9 +82,9 @@ Definition at line 123 of

-Definition at line 314 of file modules.cpp. +Definition at line 238 of file modules.cpp.

-

00314 : Name(name), Email(email), Nick(nick) { };
+
00238 : Name(name), Email(email), Nick(nick) { };
 
@@ -163,7 +163,7 @@ Definition at line 126 of
The documentation for this class was generated from the following files: -
Generated on Fri May 13 15:49:19 2005 for InspIRCd by +
Generated on Sun May 15 17:02:55 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classBanItem-members.html b/docs/module-doc/classBanItem-members.html index 80d27e7cd..caf6514f1 100644 --- a/docs/module-doc/classBanItem-members.html +++ b/docs/module-doc/classBanItem-members.html @@ -4,7 +4,7 @@ - +

BanItem Member List

This is the complete list of members for BanItem, including all inherited members. @@ -14,7 +14,7 @@ -
ageclassbase
classbase()classbase [inline]
set_timeHostItem
~classbase()classbase [inline]
~HostItem()HostItem [inline, virtual]

Generated on Fri May 13 15:49:20 2005 for InspIRCd by +
Generated on Sun May 15 17:02:57 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classBanItem.html b/docs/module-doc/classBanItem.html index 852b7aa0b..79cbe2fbc 100644 --- a/docs/module-doc/classBanItem.html +++ b/docs/module-doc/classBanItem.html @@ -4,7 +4,7 @@ - +

BanItem Class Reference

A subclass of HostItem designed to hold channel bans (+b). More...

@@ -30,7 +30,7 @@ A subclass of HostItem designed to h

Definition at line 52 of file channels.h.


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:20 2005 for InspIRCd by +
Generated on Sun May 15 17:02:57 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classConfigReader-members.html b/docs/module-doc/classConfigReader-members.html index 4d4508557..1e20db98d 100644 --- a/docs/module-doc/classConfigReader-members.html +++ b/docs/module-doc/classConfigReader-members.html @@ -4,7 +4,7 @@ - +

ConfigReader Member List

This is the complete list of members for ConfigReader, including all inherited members. @@ -24,7 +24,7 @@ -
ageclassbase
cacheConfigReader [protected]
Verify()ConfigReader
~classbase()classbase [inline]
~ConfigReader()ConfigReader

Generated on Fri May 13 15:49:26 2005 for InspIRCd by +
Generated on Sun May 15 17:03:09 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classConfigReader.html b/docs/module-doc/classConfigReader.html index cb2e2e0f5..166aab65b 100644 --- a/docs/module-doc/classConfigReader.html +++ b/docs/module-doc/classConfigReader.html @@ -4,7 +4,7 @@ - +

ConfigReader Class Reference

Allows reading of values from configuration files This class allows a module to read from either the main configuration file (inspircd.conf) or from a module-specified configuration file. More...

@@ -73,7 +73,7 @@ It may either be instantiated with one parameter or none. Constructing the class

-Definition at line 1147 of file modules.h.


Constructor & Destructor Documentation

+Definition at line 1150 of file modules.h.

Constructor & Destructor Documentation

@@ -103,17 +103,17 @@ Default constructor.

This constructor initialises the ConfigReader class to read the inspircd.conf file as specified when running ./configure.

-Definition at line 870 of file modules.cpp. +Definition at line 799 of file modules.cpp.

-References cache, CONF_FILE_NOT_FOUND, error, errorlog, and readerror. +References cache, CONF_FILE_NOT_FOUND, error, errorlog, and readerror.

-

00871 {
-00872         this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out);
-00873         this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out);
-00874         this->readerror = LoadConf(CONFIG_FILE,this->cache,this->errorlog);
-00875         if (!this->readerror)
-00876                 this->error = CONF_FILE_NOT_FOUND;
-00877 }
+
00800 {
+00801         this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out);
+00802         this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out);
+00803         this->readerror = LoadConf(CONFIG_FILE,this->cache,this->errorlog);
+00804         if (!this->readerror)
+00805                 this->error = CONF_FILE_NOT_FOUND;
+00806 }
 
@@ -147,17 +147,17 @@ Overloaded constructor.

This constructor initialises the ConfigReader class to read a user-specified config file

-Definition at line 889 of file modules.cpp. +Definition at line 818 of file modules.cpp.

-References cache, CONF_FILE_NOT_FOUND, error, errorlog, and readerror. +References cache, CONF_FILE_NOT_FOUND, error, errorlog, and readerror.

-

00890 {
-00891         this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out);
-00892         this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out);
-00893         this->readerror = LoadConf(filename.c_str(),this->cache,this->errorlog);
-00894         if (!this->readerror)
-00895                 this->error = CONF_FILE_NOT_FOUND;
-00896 };
+
00819 {
+00820         this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out);
+00821         this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out);
+00822         this->readerror = LoadConf(filename.c_str(),this->cache,this->errorlog);
+00823         if (!this->readerror)
+00824                 this->error = CONF_FILE_NOT_FOUND;
+00825 };
 
@@ -190,16 +190,16 @@ Default destructor.

This method destroys the ConfigReader class.

-Definition at line 880 of file modules.cpp. +Definition at line 809 of file modules.cpp.

-References cache, and errorlog. +References cache, and errorlog.

-

00881 {
-00882         if (this->cache)
-00883                 delete this->cache;
-00884         if (this->errorlog)
-00885                 delete this->errorlog;
-00886 }
+
00810 {
+00811         if (this->cache)
+00812                 delete this->cache;
+00813         if (this->errorlog)
+00814                 delete this->errorlog;
+00815 }
 
@@ -243,40 +243,40 @@ Dumps the list of errors in a config file to an output location.

If bail is true, then the program will abort. If bail is false and user points to a valid user record, the error report will be spooled to the given user by means of NOTICE. if bool is false AND user is false, the error report will be spooled to all opers by means of a NOTICE to all opers.

-Definition at line 967 of file modules.cpp. -

-References errorlog, connection::fd, and userrec::nick. -

-

00968 {
-00969         if (bail)
-00970         {
-00971                 printf("There were errors in your configuration:\n%s",errorlog->str().c_str());
-00972                 exit(0);
-00973         }
-00974         else
-00975         {
-00976                 char dataline[1024];
-00977                 if (user)
-00978                 {
-00979                         WriteServ(user->fd,"NOTICE %s :There were errors in the configuration file:",user->nick);
-00980                         while (!errorlog->eof())
-00981                         {
-00982                                 errorlog->getline(dataline,1024);
-00983                                 WriteServ(user->fd,"NOTICE %s :%s",user->nick,dataline);
-00984                         }
-00985                 }
-00986                 else
-00987                 {
-00988                         WriteOpers("There were errors in the configuration file:",user->nick);
-00989                         while (!errorlog->eof())
-00990                         {
-00991                                 errorlog->getline(dataline,1024);
-00992                                 WriteOpers(dataline);
-00993                         }
-00994                 }
-00995                 return;
-00996         }
-00997 }
+Definition at line 896 of file modules.cpp.
+

+References errorlog, connection::fd, and userrec::nick. +

+

00897 {
+00898         if (bail)
+00899         {
+00900                 printf("There were errors in your configuration:\n%s",errorlog->str().c_str());
+00901                 exit(0);
+00902         }
+00903         else
+00904         {
+00905                 char dataline[1024];
+00906                 if (user)
+00907                 {
+00908                         WriteServ(user->fd,"NOTICE %s :There were errors in the configuration file:",user->nick);
+00909                         while (!errorlog->eof())
+00910                         {
+00911                                 errorlog->getline(dataline,1024);
+00912                                 WriteServ(user->fd,"NOTICE %s :%s",user->nick,dataline);
+00913                         }
+00914                 }
+00915                 else
+00916                 {
+00917                         WriteOpers("There were errors in the configuration file:",user->nick);
+00918                         while (!errorlog->eof())
+00919                         {
+00920                                 errorlog->getline(dataline,1024);
+00921                                 WriteOpers(dataline);
+00922                         }
+00923                 }
+00924                 return;
+00925         }
+00926 }
 
@@ -310,13 +310,13 @@ Counts the number of times a given tag appears in the config file.

This method counts the number of times a tag appears in a config file, for use where there are several tags of the same kind, e.g. with opers and connect types. It can be used with the index value of ConfigReader::ReadValue to loop through all copies of a multiple instance tag.

-Definition at line 1000 of file modules.cpp. +Definition at line 929 of file modules.cpp.

-References cache. +References cache.

-

01001 {
-01002         return EnumConf(cache,tag.c_str());
-01003 }
+
00930 {
+00931         return EnumConf(cache,tag.c_str());
+00932 }
 
@@ -359,13 +359,13 @@ Returns the number of items within a tag.

For example if the tag was <test tag="blah" data="foo"> then this function would return 2. Spaces and newlines both qualify as valid seperators between values.

-Definition at line 1005 of file modules.cpp. +Definition at line 934 of file modules.cpp.

-References cache. +References cache.

-

01006 {
-01007         return EnumValues(cache, tag.c_str(), index);
-01008 }
+
00935 {
+00936         return EnumValues(cache, tag.c_str(), index);
+00937 }
 
@@ -398,15 +398,15 @@ Returns the last error to occur.

Valid errors can be found by looking in modules.h. Any nonzero value indicates an error condition. A call to GetError() resets the error flag back to 0.

-Definition at line 960 of file modules.cpp. +Definition at line 889 of file modules.cpp.

-References error. +References error.

-

00961 {
-00962         long olderr = this->error;
-00963         this->error = 0;
-00964         return olderr;
-00965 }
+
00890 {
+00891         long olderr = this->error;
+00892         this->error = 0;
+00893         return olderr;
+00894 }
 
@@ -455,25 +455,25 @@ Retrieves a boolean value from the config file.

This method retrieves a boolean value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve. The values "1", "yes" and "true" in the config file count as true to ReadFlag, and any other value counts as false.

-Definition at line 914 of file modules.cpp. -

-References cache, CONF_VALUE_NOT_FOUND, and error. -

-

00915 {
-00916         char val[MAXBUF];
-00917         char t[MAXBUF];
-00918         char n[MAXBUF];
-00919         strlcpy(t,tag.c_str(),MAXBUF);
-00920         strlcpy(n,name.c_str(),MAXBUF);
-00921         int res = ReadConf(cache,t,n,index,val);
-00922         if (!res)
-00923         {
-00924                 this->error = CONF_VALUE_NOT_FOUND;
-00925                 return false;
-00926         }
-00927         std::string s = val;
-00928         return ((s == "yes") || (s == "YES") || (s == "true") || (s == "TRUE") || (s == "1"));
-00929 }
+Definition at line 843 of file modules.cpp.
+

+References cache, CONF_VALUE_NOT_FOUND, and error. +

+

00844 {
+00845         char val[MAXBUF];
+00846         char t[MAXBUF];
+00847         char n[MAXBUF];
+00848         strlcpy(t,tag.c_str(),MAXBUF);
+00849         strlcpy(n,name.c_str(),MAXBUF);
+00850         int res = ReadConf(cache,t,n,index,val);
+00851         if (!res)
+00852         {
+00853                 this->error = CONF_VALUE_NOT_FOUND;
+00854                 return false;
+00855         }
+00856         std::string s = val;
+00857         return ((s == "yes") || (s == "YES") || (s == "true") || (s == "TRUE") || (s == "1"));
+00858 }
 
@@ -528,37 +528,37 @@ Retrieves an integer value from the config file.

This method retrieves an integer value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve. Any invalid integer values in the tag will cause the objects error value to be set, and any call to GetError() will return CONF_INVALID_NUMBER to be returned. needs_unsigned is set if the number must be unsigned. If a signed number is placed into a tag which is specified unsigned, 0 will be returned and GetError() will return CONF_NOT_UNSIGNED

-Definition at line 931 of file modules.cpp. -

-References cache, CONF_NOT_A_NUMBER, CONF_NOT_UNSIGNED, CONF_VALUE_NOT_FOUND, and error. -

-

00932 {
-00933         char val[MAXBUF];
-00934         char t[MAXBUF];
-00935         char n[MAXBUF];
-00936         strlcpy(t,tag.c_str(),MAXBUF);
-00937         strlcpy(n,name.c_str(),MAXBUF);
-00938         int res = ReadConf(cache,t,n,index,val);
-00939         if (!res)
-00940         {
-00941                 this->error = CONF_VALUE_NOT_FOUND;
-00942                 return 0;
-00943         }
-00944         for (int i = 0; i < strlen(val); i++)
-00945         {
-00946                 if (!isdigit(val[i]))
-00947                 {
-00948                         this->error = CONF_NOT_A_NUMBER;
-00949                         return 0;
-00950                 }
-00951         }
-00952         if ((needs_unsigned) && (atoi(val)<0))
-00953         {
-00954                 this->error = CONF_NOT_UNSIGNED;
-00955                 return 0;
-00956         }
-00957         return atoi(val);
-00958 }
+Definition at line 860 of file modules.cpp.
+

+References cache, CONF_NOT_A_NUMBER, CONF_NOT_UNSIGNED, CONF_VALUE_NOT_FOUND, and error. +

+

00861 {
+00862         char val[MAXBUF];
+00863         char t[MAXBUF];
+00864         char n[MAXBUF];
+00865         strlcpy(t,tag.c_str(),MAXBUF);
+00866         strlcpy(n,name.c_str(),MAXBUF);
+00867         int res = ReadConf(cache,t,n,index,val);
+00868         if (!res)
+00869         {
+00870                 this->error = CONF_VALUE_NOT_FOUND;
+00871                 return 0;
+00872         }
+00873         for (int i = 0; i < strlen(val); i++)
+00874         {
+00875                 if (!isdigit(val[i]))
+00876                 {
+00877                         this->error = CONF_NOT_A_NUMBER;
+00878                         return 0;
+00879                 }
+00880         }
+00881         if ((needs_unsigned) && (atoi(val)<0))
+00882         {
+00883                 this->error = CONF_NOT_UNSIGNED;
+00884                 return 0;
+00885         }
+00886         return atoi(val);
+00887 }
 
@@ -607,24 +607,24 @@ Retrieves a value from the config file.

This method retrieves a value from the config file. Where multiple copies of the tag exist in the config file, index indicates which of the values to retrieve.

-Definition at line 898 of file modules.cpp. -

-References cache, CONF_VALUE_NOT_FOUND, and error. -

-

00899 {
-00900         char val[MAXBUF];
-00901         char t[MAXBUF];
-00902         char n[MAXBUF];
-00903         strlcpy(t,tag.c_str(),MAXBUF);
-00904         strlcpy(n,name.c_str(),MAXBUF);
-00905         int res = ReadConf(cache,t,n,index,val);
-00906         if (!res)
-00907         {
-00908                 this->error = CONF_VALUE_NOT_FOUND;
-00909                 return "";
-00910         }
-00911         return val;
-00912 }
+Definition at line 827 of file modules.cpp.
+

+References cache, CONF_VALUE_NOT_FOUND, and error. +

+

00828 {
+00829         char val[MAXBUF];
+00830         char t[MAXBUF];
+00831         char n[MAXBUF];
+00832         strlcpy(t,tag.c_str(),MAXBUF);
+00833         strlcpy(n,name.c_str(),MAXBUF);
+00834         int res = ReadConf(cache,t,n,index,val);
+00835         if (!res)
+00836         {
+00837                 this->error = CONF_VALUE_NOT_FOUND;
+00838                 return "";
+00839         }
+00840         return val;
+00841 }
 
@@ -657,13 +657,13 @@ Returns true if a config file is valid.

This method is partially implemented and will only return false if the config file does not exist or could not be opened.

-Definition at line 1010 of file modules.cpp. +Definition at line 939 of file modules.cpp.

-References readerror. +References readerror.

-

01011 {
-01012         return this->readerror;
-01013 }
+
00940 {
+00941         return this->readerror;
+00942 }
 
@@ -691,9 +691,9 @@ The contents of the configuration file This protected member should never be acc

It will contain a pointer to the configuration file data with unneeded data (such as comments) stripped from it.

-Definition at line 1155 of file modules.h. +Definition at line 1158 of file modules.h.

-Referenced by ConfigReader(), Enumerate(), EnumerateValues(), ReadFlag(), ReadInteger(), ReadValue(), and ~ConfigReader(). +Referenced by ConfigReader(), Enumerate(), EnumerateValues(), ReadFlag(), ReadInteger(), ReadValue(), and ~ConfigReader().

@@ -717,9 +717,9 @@ Referenced by ConfigReader(

-Definition at line 1160 of file modules.h. +Definition at line 1163 of file modules.h.

-Referenced by ConfigReader(), GetError(), ReadFlag(), ReadInteger(), and ReadValue(). +Referenced by ConfigReader(), GetError(), ReadFlag(), ReadInteger(), and ReadValue().

@@ -743,9 +743,9 @@ Referenced by ConfigReader(

-Definition at line 1156 of file modules.h. +Definition at line 1159 of file modules.h.

-Referenced by ConfigReader(), DumpErrors(), and ~ConfigReader(). +Referenced by ConfigReader(), DumpErrors(), and ~ConfigReader().

@@ -771,14 +771,14 @@ Used to store errors.

-Definition at line 1159 of file modules.h. +Definition at line 1162 of file modules.h.

-Referenced by ConfigReader(), and Verify(). +Referenced by ConfigReader(), and Verify().


The documentation for this class was generated from the following files: -
Generated on Fri May 13 15:49:26 2005 for InspIRCd by +
Generated on Sun May 15 17:03:09 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classConnectClass-members.html b/docs/module-doc/classConnectClass-members.html index d6235b042..eae51ce7a 100644 --- a/docs/module-doc/classConnectClass-members.html +++ b/docs/module-doc/classConnectClass-members.html @@ -4,7 +4,7 @@ - +

ConnectClass Member List

This is the complete list of members for ConnectClass, including all inherited members. @@ -19,7 +19,7 @@ -
ageclassbase
classbase()classbase [inline]
thresholdConnectClass
typeConnectClass
~classbase()classbase [inline]

Generated on Fri May 13 15:49:28 2005 for InspIRCd by +
Generated on Sun May 15 17:03:11 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classConnectClass.html b/docs/module-doc/classConnectClass.html index 9e60c867e..131cb49be 100644 --- a/docs/module-doc/classConnectClass.html +++ b/docs/module-doc/classConnectClass.html @@ -4,7 +4,7 @@ - +

ConnectClass Class Reference

Holds information relevent to <connect allow> and <connect deny> tags in the config file. More...

@@ -355,7 +355,7 @@ Definition at line 50 of fi


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:28 2005 for InspIRCd by +
Generated on Sun May 15 17:03:11 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classDNS-members.html b/docs/module-doc/classDNS-members.html index decd6c889..4c1ae1319 100644 --- a/docs/module-doc/classDNS-members.html +++ b/docs/module-doc/classDNS-members.html @@ -4,7 +4,7 @@ - +

DNS Member List

This is the complete list of members for DNS, including all inherited members. @@ -33,7 +33,7 @@ -
binipDNS [private]
DNS()DNS
SetNS(std::string dnsserver)DNS
tDNS [private]
~DNS()DNS

Generated on Fri May 13 15:49:30 2005 for InspIRCd by +
Generated on Sun May 15 17:03:18 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classDNS.html b/docs/module-doc/classDNS.html index ba7e9eaa0..4a4a413df 100644 --- a/docs/module-doc/classDNS.html +++ b/docs/module-doc/classDNS.html @@ -4,7 +4,7 @@ - +

DNS Class Reference

The DNS class allows fast nonblocking resolution of hostnames and ip addresses. More...

@@ -891,7 +891,7 @@ Definition at line 40 of file


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:30 2005 for InspIRCd by +
Generated on Sun May 15 17:03:18 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classELine-members.html b/docs/module-doc/classELine-members.html index b0e74a97f..d0ccc1410 100644 --- a/docs/module-doc/classELine-members.html +++ b/docs/module-doc/classELine-members.html @@ -4,7 +4,7 @@ - +

ELine Member List

This is the complete list of members for ELine, including all inherited members. @@ -15,7 +15,7 @@ -
ageclassbase
classbase()classbase [inline]
set_timeXLine
sourceXLine
~classbase()classbase [inline]

Generated on Fri May 13 15:49:32 2005 for InspIRCd by +
Generated on Sun May 15 17:03:20 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classELine.html b/docs/module-doc/classELine.html index c3bdac0da..24279c0f2 100644 --- a/docs/module-doc/classELine.html +++ b/docs/module-doc/classELine.html @@ -4,7 +4,7 @@ - +

ELine Class Reference

#include <xline.h>

Inheritance diagram for ELine:

Inheritance graph
@@ -53,7 +53,7 @@ Definition at line 88 of fi
The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:32 2005 for InspIRCd by +
Generated on Sun May 15 17:03:20 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classEvent-members.html b/docs/module-doc/classEvent-members.html index 15b37e1c3..2764d3dce 100644 --- a/docs/module-doc/classEvent-members.html +++ b/docs/module-doc/classEvent-members.html @@ -4,7 +4,7 @@ - +

Event Member List

This is the complete list of members for Event, including all inherited members. @@ -17,7 +17,7 @@ -
ageclassbase
classbase()classbase [inline]
Send()Event [virtual]
sourceEvent [protected]
~classbase()classbase [inline]

Generated on Fri May 13 15:49:33 2005 for InspIRCd by +
Generated on Sun May 15 17:03:22 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classEvent.html b/docs/module-doc/classEvent.html index fc2d4dd6f..a7ee526da 100644 --- a/docs/module-doc/classEvent.html +++ b/docs/module-doc/classEvent.html @@ -4,7 +4,7 @@ - +

Event Class Reference

The Event class is a unicast message directed at all modules. More...

@@ -103,9 +103,9 @@ Create a new Event.

-Definition at line 345 of file modules.cpp. +Definition at line 269 of file modules.cpp.

-

00345 : data(anydata), source(src), id(eventid) { };
+
00269 : data(anydata), source(src), id(eventid) { };
 
@@ -139,13 +139,13 @@ Get the Event data.

-Definition at line 347 of file modules.cpp. +Definition at line 271 of file modules.cpp.

References data.

-

00348 {
-00349         return this->data;
-00350 }
+
00272 {
+00273         return this->data;
+00274 }
 
@@ -178,13 +178,13 @@ Get the event ID.

Use this to determine the event type for safe casting of the data

-Definition at line 363 of file modules.cpp. +Definition at line 287 of file modules.cpp.

References id.

-

00364 {
-00365         return this->id;
-00366 }
+
00288 {
+00289         return this->id;
+00290 }
 
@@ -217,13 +217,13 @@ Get the event Source.

-Definition at line 352 of file modules.cpp. +Definition at line 276 of file modules.cpp.

References source.

-

00353 {
-00354         return this->source;
-00355 }
+
00277 {
+00278         return this->source;
+00279 }
 
@@ -258,14 +258,14 @@ The return result of an Event::Send() Implements ModuleMessage.

-Definition at line 357 of file modules.cpp. +Definition at line 281 of file modules.cpp.

References FOREACH_MOD.

-

00358 {
-00359         FOREACH_MOD OnEvent(this);
-00360         return NULL;
-00361 }
+
00282 {
+00283         FOREACH_MOD OnEvent(this);
+00284         return NULL;
+00285 }
 
@@ -295,7 +295,7 @@ This member holds a pointer to arbitary data set by the emitter of the message.

Definition at line 199 of file modules.h.

-Referenced by GetData(). +Referenced by GetData().

@@ -323,7 +323,7 @@ This is arbitary text which should be used to distinguish one type of event from

Definition at line 208 of file modules.h.

-Referenced by GetEventID(). +Referenced by GetEventID().

@@ -351,12 +351,12 @@ This is a pointer to the sender of the message, which can be used to directly tr

Definition at line 203 of file modules.h.

-Referenced by GetSource(). +Referenced by GetSource().


The documentation for this class was generated from the following files: -
Generated on Fri May 13 15:49:33 2005 for InspIRCd by +
Generated on Sun May 15 17:03:21 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classExemptItem-members.html b/docs/module-doc/classExemptItem-members.html index a83b3446b..052a4d876 100644 --- a/docs/module-doc/classExemptItem-members.html +++ b/docs/module-doc/classExemptItem-members.html @@ -4,7 +4,7 @@ - +

ExemptItem Member List

This is the complete list of members for ExemptItem, including all inherited members. @@ -14,7 +14,7 @@ -
ageclassbase
classbase()classbase [inline]
set_timeHostItem
~classbase()classbase [inline]
~HostItem()HostItem [inline, virtual]

Generated on Fri May 13 15:49:34 2005 for InspIRCd by +
Generated on Sun May 15 17:03:23 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classExemptItem.html b/docs/module-doc/classExemptItem.html index 18f6048fb..afc704ef7 100644 --- a/docs/module-doc/classExemptItem.html +++ b/docs/module-doc/classExemptItem.html @@ -4,7 +4,7 @@ - +

ExemptItem Class Reference

A subclass of HostItem designed to hold channel exempts (+e). More...

@@ -30,7 +30,7 @@ A subclass of HostItem designed to h

Definition at line 60 of file channels.h.


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:34 2005 for InspIRCd by +
Generated on Sun May 15 17:03:23 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classExtMode-members.html b/docs/module-doc/classExtMode-members.html index 1f7b195a5..7804a6447 100644 --- a/docs/module-doc/classExtMode-members.html +++ b/docs/module-doc/classExtMode-members.html @@ -4,7 +4,7 @@ - +

ExtMode Member List

This is the complete list of members for ExtMode, including all inherited members. @@ -16,7 +16,7 @@ -
ageclassbase
classbase()classbase [inline]
params_when_onExtMode
typeExtMode
~classbase()classbase [inline]

Generated on Fri May 13 15:49:37 2005 for InspIRCd by +
Generated on Sun May 15 17:03:25 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classExtMode.html b/docs/module-doc/classExtMode.html index 6626c7c88..88af67a5c 100644 --- a/docs/module-doc/classExtMode.html +++ b/docs/module-doc/classExtMode.html @@ -4,7 +4,7 @@ - +

ExtMode Class Reference

Inheritance diagram for ExtMode:

Inheritance graph
@@ -88,11 +88,11 @@

-Definition at line 212 of file modules.cpp. +Definition at line 136 of file modules.cpp.

-References modechar, needsoper, params_when_off, params_when_on, and type. +References modechar, needsoper, params_when_off, params_when_on, and type.

-

00212 : modechar(mc), type(ty), needsoper(oper), params_when_on(p_on), params_when_off(p_off) { };
+
00136 : modechar(mc), type(ty), needsoper(oper), params_when_on(p_on), params_when_off(p_off) { };
 
@@ -118,7 +118,7 @@ References modechar,

-Definition at line 211 of file modules.cpp. +Definition at line 135 of file modules.cpp.

@@ -142,9 +142,9 @@ Definition at line 211

-Definition at line 206 of file modules.cpp. +Definition at line 130 of file modules.cpp.

-Referenced by ExtMode(). +Referenced by ExtMode().

@@ -168,9 +168,9 @@ Referenced by ExtMode()

-Definition at line 210 of file modules.cpp. +Definition at line 134 of file modules.cpp.

-Referenced by ExtMode(). +Referenced by ExtMode().

@@ -194,9 +194,9 @@ Referenced by ExtMode()

-Definition at line 209 of file modules.cpp. +Definition at line 133 of file modules.cpp.

-Referenced by ExtMode(). +Referenced by ExtMode().

@@ -220,9 +220,9 @@ Referenced by ExtMode()

-Definition at line 208 of file modules.cpp. +Definition at line 132 of file modules.cpp.

-Referenced by ExtMode(). +Referenced by ExtMode().

@@ -246,14 +246,14 @@ Referenced by ExtMode()

-Definition at line 207 of file modules.cpp. +Definition at line 131 of file modules.cpp.

-Referenced by ExtMode(). +Referenced by ExtMode().


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:37 2005 for InspIRCd by +
Generated on Sun May 15 17:03:25 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classExtensible-members.html b/docs/module-doc/classExtensible-members.html index 4d874896a..93a96a694 100644 --- a/docs/module-doc/classExtensible-members.html +++ b/docs/module-doc/classExtensible-members.html @@ -4,7 +4,7 @@ - +

Extensible Member List

This is the complete list of members for Extensible, including all inherited members. @@ -13,7 +13,7 @@ -
ageclassbase
classbase()classbase [inline]
GetExt(std::string key)Extensible
Shrink(std::string key)Extensible
~classbase()classbase [inline]

Generated on Fri May 13 15:49:36 2005 for InspIRCd by +
Generated on Sun May 15 17:03:24 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classExtensible.html b/docs/module-doc/classExtensible.html index 8883a804f..2465aed61 100644 --- a/docs/module-doc/classExtensible.html +++ b/docs/module-doc/classExtensible.html @@ -4,7 +4,7 @@ - +

Extensible Class Reference

class Extensible is the parent class of many classes such as userrec and chanrec. More...

@@ -180,7 +180,7 @@ Definition at line 54 of fil


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:36 2005 for InspIRCd by +
Generated on Sun May 15 17:03:24 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classFileReader-members.html b/docs/module-doc/classFileReader-members.html index 4beac30ad..7a0140fd2 100644 --- a/docs/module-doc/classFileReader-members.html +++ b/docs/module-doc/classFileReader-members.html @@ -4,7 +4,7 @@ - +

FileReader Member List

This is the complete list of members for FileReader, including all inherited members. @@ -17,7 +17,7 @@ -
ageclassbase
classbase()classbase [inline]
LoadFile(std::string filename)FileReader
~classbase()classbase [inline]
~FileReader()FileReader

Generated on Fri May 13 15:49:38 2005 for InspIRCd by +
Generated on Sun May 15 17:03:26 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classFileReader.html b/docs/module-doc/classFileReader.html index d9be72a02..646b92de9 100644 --- a/docs/module-doc/classFileReader.html +++ b/docs/module-doc/classFileReader.html @@ -4,7 +4,7 @@ - +

FileReader Class Reference

Caches a text file into memory and can be used to retrieve lines from it. More...

@@ -53,7 +53,7 @@ This class contains methods for read-only manipulation of a text file in memory.

-Definition at line 1236 of file modules.h.


Constructor & Destructor Documentation

+Definition at line 1239 of file modules.h.

Constructor & Destructor Documentation

@@ -83,10 +83,10 @@ Default constructor.

This method does not load any file into memory, you must use the LoadFile method after constructing the class this way.

-Definition at line 1023 of file modules.cpp. +Definition at line 952 of file modules.cpp.

-

01024 {
-01025 }
+
00953 {
+00954 }
 
@@ -120,15 +120,15 @@ Secondary constructor.

This method initialises the class with a file loaded into it ready for GetLine and and other methods to be called. If the file could not be loaded, FileReader::FileSize returns 0.

-Definition at line 1016 of file modules.cpp. +Definition at line 945 of file modules.cpp.

-References fc, and file_cache. +References fc, and file_cache.

-

01017 {
-01018         file_cache c;
-01019         readfile(c,filename.c_str());
-01020         this->fc = c;
-01021 }
+
00946 {
+00947         file_cache c;
+00948         readfile(c,filename.c_str());
+00949         this->fc = c;
+00950 }
 
@@ -161,10 +161,10 @@ Default destructor.

This deletes the memory allocated to the file.

-Definition at line 1035 of file modules.cpp. +Definition at line 964 of file modules.cpp.

-

01036 {
-01037 }
+
00965 {
+00966 }
 
@@ -198,20 +198,20 @@ Returns true if the file exists This function will return false if the file coul

-Definition at line 1039 of file modules.cpp. +Definition at line 968 of file modules.cpp.

-References fc. +References fc.

-

01040 {
-01041         if (fc.size() == 0)
-01042         {
-01043                 return(false);
-01044         }
-01045         else
-01046         {
-01047                 return(true);
-01048         }
-01049 }
+
00969 {
+00970         if (fc.size() == 0)
+00971         {
+00972                 return(false);
+00973         }
+00974         else
+00975         {
+00976                 return(true);
+00977         }
+00978 }
 
@@ -244,13 +244,13 @@ Returns the size of the file in lines.

This method returns the number of lines in the read file. If it is 0, no lines have been read into memory, either because the file is empty or it does not exist, or cannot be opened due to permission problems.

-Definition at line 1058 of file modules.cpp. +Definition at line 987 of file modules.cpp.

-References fc. +References fc.

-

01059 {
-01060         return fc.size();
-01061 }
+
00988 {
+00989         return fc.size();
+00990 }
 
@@ -284,15 +284,15 @@ Retrieve one line from the file.

This method retrieves one line from the text file. If an empty non-NULL string is returned, the index was out of bounds, or the line had no data on it.

-Definition at line 1051 of file modules.cpp. +Definition at line 980 of file modules.cpp.

-References fc. +References fc.

-

01052 {
-01053         if ((x<0) || (x>fc.size()))
-01054                 return "";
-01055         return fc[x];
-01056 }
+
00981 {
+00982         if ((x<0) || (x>fc.size()))
+00983                 return "";
+00984         return fc[x];
+00985 }
 
@@ -326,15 +326,15 @@ Used to load a file.

This method loads a file into the class ready for GetLine and and other methods to be called. If the file could not be loaded, FileReader::FileSize returns 0.

-Definition at line 1027 of file modules.cpp. +Definition at line 956 of file modules.cpp.

-References fc, and file_cache. +References fc, and file_cache.

-

01028 {
-01029         file_cache c;
-01030         readfile(c,filename.c_str());
-01031         this->fc = c;
-01032 }
+
00957 {
+00958         file_cache c;
+00959         readfile(c,filename.c_str());
+00960         this->fc = c;
+00961 }
 
@@ -360,14 +360,14 @@ References fc, and

-Definition at line 1238 of file modules.h. +Definition at line 1241 of file modules.h.

-Referenced by Exists(), FileReader(), FileSize(), GetLine(), and LoadFile(). +Referenced by Exists(), FileReader(), FileSize(), GetLine(), and LoadFile().


The documentation for this class was generated from the following files: -
Generated on Fri May 13 15:49:38 2005 for InspIRCd by +
Generated on Sun May 15 17:03:26 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classGLine-members.html b/docs/module-doc/classGLine-members.html index 8d5af13f3..8cedfd02a 100644 --- a/docs/module-doc/classGLine-members.html +++ b/docs/module-doc/classGLine-members.html @@ -4,7 +4,7 @@ - +

GLine Member List

This is the complete list of members for GLine, including all inherited members. @@ -15,7 +15,7 @@ -
ageclassbase
classbase()classbase [inline]
set_timeXLine
sourceXLine
~classbase()classbase [inline]

Generated on Fri May 13 15:49:39 2005 for InspIRCd by +
Generated on Sun May 15 17:03:28 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classGLine.html b/docs/module-doc/classGLine.html index 3d1f7e735..901ef24ff 100644 --- a/docs/module-doc/classGLine.html +++ b/docs/module-doc/classGLine.html @@ -4,7 +4,7 @@ - +

GLine Class Reference

GLine class. More...

@@ -61,7 +61,7 @@ Definition at line 79 of fi


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:39 2005 for InspIRCd by +
Generated on Sun May 15 17:03:28 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classHostItem-members.html b/docs/module-doc/classHostItem-members.html index 5269c6e75..9927250bc 100644 --- a/docs/module-doc/classHostItem-members.html +++ b/docs/module-doc/classHostItem-members.html @@ -4,7 +4,7 @@ - +

HostItem Member List

This is the complete list of members for HostItem, including all inherited members. @@ -14,7 +14,7 @@ -
ageclassbase
classbase()classbase [inline]
set_timeHostItem
~classbase()classbase [inline]
~HostItem()HostItem [inline, virtual]

Generated on Fri May 13 15:49:40 2005 for InspIRCd by +
Generated on Sun May 15 17:03:29 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classHostItem.html b/docs/module-doc/classHostItem.html index 6176efaa7..2d9cab15c 100644 --- a/docs/module-doc/classHostItem.html +++ b/docs/module-doc/classHostItem.html @@ -4,7 +4,7 @@ - +

HostItem Class Reference

Holds an entry for a ban list, exemption list, or invite list. More...

@@ -185,7 +185,7 @@ Definition at line 39 of


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:40 2005 for InspIRCd by +
Generated on Sun May 15 17:03:29 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classInviteItem-members.html b/docs/module-doc/classInviteItem-members.html index 44a656368..30f42926f 100644 --- a/docs/module-doc/classInviteItem-members.html +++ b/docs/module-doc/classInviteItem-members.html @@ -4,7 +4,7 @@ - +

InviteItem Member List

This is the complete list of members for InviteItem, including all inherited members. @@ -14,7 +14,7 @@ -
ageclassbase
classbase()classbase [inline]
set_timeHostItem
~classbase()classbase [inline]
~HostItem()HostItem [inline, virtual]

Generated on Fri May 13 15:49:42 2005 for InspIRCd by +
Generated on Sun May 15 17:03:31 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classInviteItem.html b/docs/module-doc/classInviteItem.html index e5aa8959a..db260931e 100644 --- a/docs/module-doc/classInviteItem.html +++ b/docs/module-doc/classInviteItem.html @@ -4,7 +4,7 @@ - +

InviteItem Class Reference

A subclass of HostItem designed to hold channel invites (+I). More...

@@ -30,7 +30,7 @@ A subclass of HostItem designed to h

Definition at line 68 of file channels.h.


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:42 2005 for InspIRCd by +
Generated on Sun May 15 17:03:31 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classInvited-members.html b/docs/module-doc/classInvited-members.html index a1ea18bea..f4718eea6 100644 --- a/docs/module-doc/classInvited-members.html +++ b/docs/module-doc/classInvited-members.html @@ -4,13 +4,13 @@ - +

Invited Member List

This is the complete list of members for Invited, including all inherited members. -
ageclassbase
channelInvited
classbase()classbase [inline]
~classbase()classbase [inline]

Generated on Fri May 13 15:49:41 2005 for InspIRCd by +
Generated on Sun May 15 17:03:30 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classInvited.html b/docs/module-doc/classInvited.html index 6cf22b4d9..383a50357 100644 --- a/docs/module-doc/classInvited.html +++ b/docs/module-doc/classInvited.html @@ -4,7 +4,7 @@ - +

Invited Class Reference

Holds a channel name to which a user has been invited. More...

@@ -53,12 +53,12 @@ Definition at line 36 of fi

Definition at line 39 of file users.h.

-Referenced by userrec::InviteTo(). +Referenced by userrec::InviteTo().


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:41 2005 for InspIRCd by +
Generated on Sun May 15 17:03:30 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classKLine-members.html b/docs/module-doc/classKLine-members.html index 4e085f5e3..1ee263413 100644 --- a/docs/module-doc/classKLine-members.html +++ b/docs/module-doc/classKLine-members.html @@ -4,7 +4,7 @@ - +

KLine Member List

This is the complete list of members for KLine, including all inherited members. @@ -15,7 +15,7 @@ -
ageclassbase
classbase()classbase [inline]
set_timeXLine
sourceXLine
~classbase()classbase [inline]

Generated on Fri May 13 15:49:45 2005 for InspIRCd by +
Generated on Sun May 15 17:03:34 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classKLine.html b/docs/module-doc/classKLine.html index f9efa2bea..3902144d2 100644 --- a/docs/module-doc/classKLine.html +++ b/docs/module-doc/classKLine.html @@ -4,7 +4,7 @@ - +

KLine Class Reference

KLine class. More...

@@ -61,7 +61,7 @@ Definition at line 68 of fi


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:45 2005 for InspIRCd by +
Generated on Sun May 15 17:03:34 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModeParameter-members.html b/docs/module-doc/classModeParameter-members.html index d71c58eb3..a5404a735 100644 --- a/docs/module-doc/classModeParameter-members.html +++ b/docs/module-doc/classModeParameter-members.html @@ -4,7 +4,7 @@ - +

ModeParameter Member List

This is the complete list of members for ModeParameter, including all inherited members. @@ -12,7 +12,7 @@ -
ageclassbase
channelModeParameter
modeModeParameter
parameterModeParameter
~classbase()classbase [inline]

Generated on Fri May 13 15:49:46 2005 for InspIRCd by +
Generated on Sun May 15 17:03:35 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModeParameter.html b/docs/module-doc/classModeParameter.html index 6f4a05668..f19b1776c 100644 --- a/docs/module-doc/classModeParameter.html +++ b/docs/module-doc/classModeParameter.html @@ -4,7 +4,7 @@ - +

ModeParameter Class Reference

Holds a custom parameter to a module-defined channel mode e.g. More...

@@ -59,7 +59,7 @@ Definition at line 77 of

Definition at line 82 of file channels.h.

-Referenced by chanrec::SetCustomModeParam(). +Referenced by chanrec::SetCustomModeParam().

@@ -85,7 +85,7 @@ Referenced by chanrec::Set

Definition at line 80 of file channels.h.

-Referenced by chanrec::SetCustomModeParam(). +Referenced by chanrec::SetCustomModeParam().

@@ -111,12 +111,12 @@ Referenced by chanrec::Set

Definition at line 81 of file channels.h.

-Referenced by chanrec::SetCustomModeParam(). +Referenced by chanrec::SetCustomModeParam().


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:46 2005 for InspIRCd by +
Generated on Sun May 15 17:03:35 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModule-members.html b/docs/module-doc/classModule-members.html index 4ecacaa9d..dd6ad7db9 100644 --- a/docs/module-doc/classModule-members.html +++ b/docs/module-doc/classModule-members.html @@ -4,7 +4,7 @@ - +

Module Member List

This is the complete list of members for Module, including all inherited members. @@ -65,7 +65,7 @@ -
ageclassbase
classbase()classbase [inline]
OnWhois(userrec *source, userrec *dest)Module [virtual]
~classbase()classbase [inline]
~Module()Module [virtual]

Generated on Fri May 13 15:49:48 2005 for InspIRCd by +
Generated on Sun May 15 17:03:37 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModule.html b/docs/module-doc/classModule.html index 407b3a446..0e509f674 100644 --- a/docs/module-doc/classModule.html +++ b/docs/module-doc/classModule.html @@ -4,7 +4,7 @@ - +

Module Class Reference

Base class for all InspIRCd modules This class is the base class for InspIRCd modules. More...

@@ -227,9 +227,9 @@ Default constructor creates a module class.

-Definition at line 370 of file modules.cpp. +Definition at line 294 of file modules.cpp.

-

00370 { }
+
00294 { }
 
@@ -262,9 +262,9 @@ Default destructor destroys a module class.

-Definition at line 371 of file modules.cpp. +Definition at line 295 of file modules.cpp.

-

00371 { }
+
00295 { }
 
@@ -298,11 +298,11 @@ Returns the version number of a Module.

The method should return a Version object with its version information assigned via Version::Version

-Definition at line 383 of file modules.cpp. +Definition at line 307 of file modules.cpp.

References VF_VENDOR.

-

00383 { return Version(1,0,0,0,VF_VENDOR); }
+
00307 { return Version(1,0,0,0,VF_VENDOR); }
 
@@ -336,9 +336,9 @@ Called when a 005 numeric is about to be output.

The module should modify the 005 numeric if needed to indicate its features.

-Definition at line 395 of file modules.cpp. +Definition at line 319 of file modules.cpp.

-

00395 { };
+
00319 { };
 
@@ -405,11 +405,11 @@ This function is called before many functions which check a users status on a ch
Upon returning from your function you must return either ACR_DEFAULT, to indicate the module wishes to do nothing, or ACR_DENY where approprate to deny the action, and ACR_ALLOW where appropriate to allow the action. Please note that in the case of some access checks (such as AC_GENERAL_MODE) access may be denied 'upstream' causing other checks such as AC_DEOP to not be reached. Be very careful with use of the AC_GENERAL_MODE type, as it may inadvertently override the behaviour of other modules. When the access_type is AC_GENERAL_MODE, the destination of the mode will be NULL (as it has not yet been determined).

-Definition at line 392 of file modules.cpp. +Definition at line 316 of file modules.cpp.

References ACR_DEFAULT.

-

00392 { return ACR_DEFAULT; };
+
00316 { return ACR_DEFAULT; };
 
@@ -458,9 +458,9 @@ Called whenever a ban is added to a channel's list.

Return a non-zero value to 'eat' the mode change and prevent the ban from being added.

-Definition at line 420 of file modules.cpp. +Definition at line 344 of file modules.cpp.

-

00420 { return 0; };
+
00344 { return 0; };
 
@@ -494,9 +494,9 @@ Called once every five seconds for background processing.

This timer can be used to control timed features. Its period is not accurate enough to be used as a clock, but it is gauranteed to be called at least once in any five second period, directly from the main loop of the server.

-Definition at line 398 of file modules.cpp. +Definition at line 322 of file modules.cpp.

-

00398 { };
+
00322 { };
 
@@ -539,9 +539,9 @@ Called whenever a change of a local users GECOS (fullname field) is attempted.

return 1 to deny the name change, or 0 to allow it.

-Definition at line 412 of file modules.cpp. +Definition at line 336 of file modules.cpp.

-

00412 { return 0; };
+
00336 { return 0; };
 
@@ -584,9 +584,9 @@ Called whenever a change of a local users displayed host is attempted.

Return 1 to deny the host change, or 0 to allow it.

-Definition at line 411 of file modules.cpp. +Definition at line 335 of file modules.cpp.

-

00411 { return 0; };
+
00335 { return 0; };
 
@@ -620,11 +620,11 @@ Called during a netburst to sync channel data.

This is called during the netburst on a per-channel basis. You should use this call to up any special channel-related things which are implemented by your module, e.g. sending listmodes. You may return multiple commands in the string_list.

-Definition at line 394 of file modules.cpp. +Definition at line 318 of file modules.cpp.

References string_list.

-

00394 { string_list empty; return empty; }
+
00318 { string_list empty; return empty; }
 
@@ -667,9 +667,9 @@ Called whenever a user joins a channel, to determine if banlist checks should go

This method will always be called for each join, wether or not the user actually matches a channel ban, and determines the outcome of an if statement around the whole section of ban checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event.

-Definition at line 409 of file modules.cpp. +Definition at line 333 of file modules.cpp.

-

00409 { return 0; };
+
00333 { return 0; };
 
@@ -712,9 +712,9 @@ Called whenever a user joins a channel, to determine if invite checks should go

This method will always be called for each join, wether or not the channel is actually +i, and determines the outcome of an if statement around the whole section of invite checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event.

-Definition at line 406 of file modules.cpp. +Definition at line 330 of file modules.cpp.

-

00406 { return 0; };
+
00330 { return 0; };
 
@@ -763,9 +763,9 @@ Called whenever a user joins a channel, to determine if key checks should go ahe

This method will always be called for each join, wether or not the channel is actually +k, and determines the outcome of an if statement around the whole section of key checking code. if the user specified no key, the keygiven string will be a valid but empty value. return 1 to explicitly allow the join to go ahead or 0 to ignore the event.

-Definition at line 407 of file modules.cpp. +Definition at line 331 of file modules.cpp.

-

00407 { return 0; };
+
00331 { return 0; };
 
@@ -808,9 +808,9 @@ Called whenever a user joins a channel, to determine if channel limit checks sho

This method will always be called for each join, wether or not the channel is actually +l, and determines the outcome of an if statement around the whole section of channel limit checking code. return 1 to explicitly allow the join to go ahead or 0 to ignore the event.

-Definition at line 408 of file modules.cpp. +Definition at line 332 of file modules.cpp.

-

00408 { return 0; };
+
00332 { return 0; };
 
@@ -844,9 +844,9 @@ Called to check if a user who is connecting can now be allowed to register If an

For example a module which implements ident lookups will continue to return false for a user until their ident lookup is completed. Note that the registration timeout for a user overrides these checks, if the registration timeout is reached, the user is disconnected even if modules report that the user is not ready to connect.

-Definition at line 401 of file modules.cpp. +Definition at line 325 of file modules.cpp.

-

00401 { return true; };
+
00325 { return true; };
 
@@ -895,9 +895,9 @@ Called whenever a ban is removed from a channel's list.

Return a non-zero value to 'eat' the mode change and prevent the ban from being removed.

-Definition at line 421 of file modules.cpp. +Definition at line 345 of file modules.cpp.

-

00421 { return 0; };
+
00345 { return 0; };
 
@@ -931,9 +931,9 @@ Called whenever an Event class is sent

Please see the documentation of Event::Send() for further information. The Event sent can always be assumed to be non-NULL, you should *always* check the value of Event::GetEventID() before doing anything to the event data, and you should *not* change the event data in any way!

-Definition at line 415 of file modules.cpp. +Definition at line 339 of file modules.cpp.

-

00415 { return; };
+
00339 { return; };
 
@@ -998,11 +998,11 @@ Definition at line 415

Called whenever an extended mode is to be processed.

-The type parameter is MT_SERVER, MT_CLIENT or MT_CHANNEL, dependent on where the mode is being changed. mode_on is set when the mode is being set, in which case params contains a list of parameters for the mode as strings. If mode_on is false, the mode is being removed, and parameters may contain the parameters for the mode, dependent on wether they were defined when a mode handler was set up with Server::AddExtendedMode If the mode is a channel mode, target is a chanrec*, and if it is a user mode, target is a userrec*. You must cast this value yourself to make use of it. +The type parameter is MT_SERVER, MT_CLIENT or MT_CHANNEL, dependent on where the mode is being changed. mode_on is set when the mode is being set, in which case params contains a list of parameters for the mode as strings. If mode_on is false, the mode is being removed, and parameters may contain the parameters for the mode, dependent on wether they were defined when a mode handler was set up with Server::AddExtendedMode If the mode is a channel mode, target is a chanrec*, and if it is a user mode, target is a userrec*. You must cast this value yourself to make use of it.

-Definition at line 382 of file modules.cpp. +Definition at line 306 of file modules.cpp.

-

00382 { return false; }
+
00306 { return false; }
 
@@ -1036,9 +1036,9 @@ Called whenever a user connects, anywhere on the network.

This event is informational only. You should not change any user information in this event. To do so, use the OnUserConnect method to change the state of local users.

-Definition at line 419 of file modules.cpp. +Definition at line 343 of file modules.cpp.

-

00419 { };
+
00343 { };
 
@@ -1072,9 +1072,9 @@ Called whenever a user is given usermode +o, anywhere on the network.

You cannot override this and prevent it from happening as it is already happened and such a task must be performed by another server. You can however bounce modes by sending servermodes out to reverse mode changes.

-Definition at line 418 of file modules.cpp. +Definition at line 342 of file modules.cpp.

-

00418 { };
+
00342 { };
 
@@ -1109,9 +1109,9 @@ Called whenever a user types /INFO. The userrec will contain the information of the user who typed the command. Modules may use this method to output their own credits in /INFO (which is the ircd's version of an about box). It is purposefully not possible to modify any info that has already been output, or halt the list. You must write a 371 numeric to the user, containing your info in the following format:

<nick> :information here

-Definition at line 385 of file modules.cpp. +Definition at line 309 of file modules.cpp.

-

00385 { };
+
00309 { };
 
@@ -1160,9 +1160,9 @@ Called when a client is disconnected by KILL.

If a client is killed by a server, e.g. a nickname collision or protocol error, source is NULL. Return 1 from this function to prevent the kill, and 0 from this function to allow it as normal. If you prevent the kill no output will be sent to the client, it is down to your module to generate this information. NOTE: It is NOT advisable to stop kills which originate from servers. If you do so youre risking race conditions, desyncs and worse!

-Definition at line 396 of file modules.cpp. +Definition at line 320 of file modules.cpp.

-

00396 { return 0; };
+
00320 { return 0; };
 
@@ -1205,9 +1205,9 @@ Called whenever a module is loaded.

mod will contain a pointer to the module, and string will contain its name, for example m_widgets.so. This function is primary for dependency checking, your module may decide to enable some extra features if it sees that you have for example loaded "m_killwidgets.so" with "m_makewidgets.so". It is highly recommended that modules do *NOT* bail if they cannot satisfy dependencies, but instead operate under reduced functionality, unless the dependency is absolutely neccessary (e.g. a module that extends the features of another module).

-Definition at line 397 of file modules.cpp. +Definition at line 321 of file modules.cpp.

-

00397 { };
+
00321 { };
 
@@ -1256,9 +1256,9 @@ Called whenever a topic is changed by a local user.

Return 1 to deny the topic change, or 0 to allow it.

-Definition at line 413 of file modules.cpp. +Definition at line 337 of file modules.cpp.

-

00413 { return 0; };
+
00337 { return 0; };
 
@@ -1331,9 +1331,9 @@ Called whenever an unknown token is received in a server to server link.

The token value is the unknown token -- please check that no other modules are using the token that you use. Returning 1 supresses the 'unknown token type' error which is usually sent to all opers with +s. The params list is a list of parameters, and if any parameters start with a colon (:) it is treated as the whole of the last parameter, identical to how RFC messages are handled. source is the sender of the message, and reply is what should be replied to for a unicast message. Note that there are not many messages in the mesh protocol which require unicast messaging. tcp_host is the server name as a string, ipaddr is its ip address in dotted decimal notation and port is the port number it is using.

-Definition at line 414 of file modules.cpp. +Definition at line 338 of file modules.cpp.

-

00414 { return 0; };
+
00338 { return 0; };
 
@@ -1367,9 +1367,9 @@ Called whenever a user opers locally.

The userrec will contain the oper mode 'o' as this function is called after any modifications are made to the user's structure by the core.

-Definition at line 384 of file modules.cpp. +Definition at line 308 of file modules.cpp.

-

00384 { };
+
00308 { };
 
@@ -1412,9 +1412,9 @@ Called whenever an oper password is to be compared to what a user has input.

The password field (from the config file) is in 'password' and is to be compared against 'input'. This method allows for encryption of oper passwords and much more besides. You should return a nonzero value if you want to allow the comparison or zero if you wish to do nothing.

-Definition at line 417 of file modules.cpp. +Definition at line 341 of file modules.cpp.

-

00417 { return 0; };
+
00341 { return 0; };
 
@@ -1457,9 +1457,9 @@ Called after a packet is received from another irc server.

This allows you to easily represent it in the correct ways to implement encryption, compression, digital signatures and anything else you may want to add. This should be regarded as a pre-processor and will be called immediately after the packet is received but before any other operations with the core of the ircd.

-Definition at line 378 of file modules.cpp. +Definition at line 302 of file modules.cpp.

-

00378 { }
+
00302 { }
 
@@ -1502,9 +1502,9 @@ Called before a packet is transmitted across the irc network between two irc ser

This allows you to easily represent it in the correct ways to implement encryption, compression, digital signatures and anything else you may want to add. This should be regarded as a pre-processor and will be called before ANY other operations within the ircd core program.

-Definition at line 377 of file modules.cpp. +Definition at line 301 of file modules.cpp.

-

00377 { }
+
00301 { }
 
@@ -1557,11 +1557,11 @@ Definition at line 377

Called whenever any command is about to be executed.

-This event occurs for all registered commands, wether they are registered in the core, or another module, but it will not occur for invalid commands (e.g. ones which do not exist within the command table). By returning 1 from this method you may prevent the command being executed. If you do this, no output is created by the core, and it is down to your module to produce any output neccessary. Note that unless you return 1, you should not destroy any structures (e.g. by using Server::QuitUser) otherwise when the command's handler function executes after your method returns, it will be passed an invalid pointer to the user object and crash!) +This event occurs for all registered commands, wether they are registered in the core, or another module, but it will not occur for invalid commands (e.g. ones which do not exist within the command table). By returning 1 from this method you may prevent the command being executed. If you do this, no output is created by the core, and it is down to your module to produce any output neccessary. Note that unless you return 1, you should not destroy any structures (e.g. by using Server::QuitUser) otherwise when the command's handler function executes after your method returns, it will be passed an invalid pointer to the user object and crash!)

-Definition at line 400 of file modules.cpp. +Definition at line 324 of file modules.cpp.

-

00400 { return 0; };
+
00324 { return 0; };
 
@@ -1628,9 +1628,9 @@ Called whenever a mode character is processed.

Return 1 from this function to block the mode character from being processed entirely, so that you may perform your own code instead. Note that this method allows you to override modes defined by other modes, but this is NOT RECOMMENDED!

-Definition at line 405 of file modules.cpp. +Definition at line 329 of file modules.cpp.

-

00405 { return 0; };
+
00329 { return 0; };
 
@@ -1679,9 +1679,9 @@ Called immediately after any connection is accepted.

This is intended for raw socket processing (e.g. modules which wrap the tcp connection within another library) and provides no information relating to a user record as the connection has not been assigned yet. There are no return values from this call as all modules get an opportunity if required to process the connection.

-Definition at line 422 of file modules.cpp. +Definition at line 346 of file modules.cpp.

-

00422 { };
+
00346 { };
 
@@ -1715,9 +1715,9 @@ Called immediately before any socket is closed.

When this event is called, shutdown() has not yet been called on the socket.

-Definition at line 424 of file modules.cpp. +Definition at line 348 of file modules.cpp.

-

00424 { };
+
00348 { };
 
@@ -1772,9 +1772,9 @@ Called immediately before any read() operation on a client socket in the core.

This occurs AFTER the select() or poll() so there is always data waiting to be read when this event occurs. Your event should return 1 if it has handled the reading itself, which prevents the core just using read(). You should place any data read into buffer, up to but NOT GREATER THAN the value of count. The value of readresult must be identical to an actual result that might be returned from the read() system call, for example, number of bytes read upon success, 0 upon EOF or closed socket, and -1 for error. If your function returns a nonzero value, you MUST set readresult.

-Definition at line 425 of file modules.cpp. +Definition at line 349 of file modules.cpp.

-

00425 { return 0; };
+
00349 { return 0; };
 
@@ -1823,9 +1823,9 @@ Called immediately before any write() operation on a user's socket in the core.

Because this event is a low level event no user information is associated with it. It is intended for use by modules which may wrap connections within another API such as SSL for example. return a non-zero result if you have handled the write operation, in which case the core will not call write().

-Definition at line 423 of file modules.cpp. +Definition at line 347 of file modules.cpp.

-

00423 { return 0; };
+
00347 { return 0; };
 
@@ -1858,9 +1858,9 @@ Called on rehash.

This method is called prior to a /REHASH or when a SIGHUP is received from the operating system. You should use it to reload any files so that your module keeps in step with the rest of the application.

-Definition at line 379 of file modules.cpp. +Definition at line 303 of file modules.cpp.

-

00379 { }
+
00303 { }
 
@@ -1894,11 +1894,11 @@ Called whenever a Request class is se

Please see the documentation of Request::Send() for further information. The Request sent can always be assumed to be non-NULL, you should not change the request object or its data. Your method may return arbitary data in the char* result which the requesting module may be able to use for pre-determined purposes (e.g. the results of an SQL query, etc).

-Definition at line 416 of file modules.cpp. +Definition at line 340 of file modules.cpp.

-Referenced by Request::Send(). +Referenced by Request::Send().

-

00416 { return NULL; };
+
00340 { return NULL; };
 
@@ -1947,9 +1947,9 @@ Called whenever a list is needed for a listmode.

For example, when a /MODE #channel +b (without any other parameters) is called, if a module was handling +b this function would be called. The function can then output any lists it wishes to. Please note that all modules will see all mode characters to provide the ability to extend each other, so please only output a list if the mode character given matches the one(s) you want to handle.

-Definition at line 399 of file modules.cpp. +Definition at line 323 of file modules.cpp.

-

00399 { };
+
00323 { };
 
@@ -1998,9 +1998,9 @@ Called when a raw command is transmitted or received.

This method is the lowest level of handler available to a module. It will be called with raw data which is passing through a connected socket. If you wish, you may munge this data by changing the string parameter "raw". If you do this, after your function exits it will immediately be cut down to 510 characters plus a carriage return and linefeed. For INBOUND messages only (where inbound is set to true) the value of user will be the userrec of the connection sending the data. This is not possible for outbound data because the data may be being routed to multiple targets.

-Definition at line 380 of file modules.cpp. +Definition at line 304 of file modules.cpp.

-

00380 { }
+
00304 { }
 
@@ -2034,9 +2034,9 @@ Called on all /STATS commands This method is triggered for all /STATS use, inclu

-Definition at line 410 of file modules.cpp. +Definition at line 334 of file modules.cpp.

-

00410 { };
+
00334 { };
 
@@ -2070,9 +2070,9 @@ Called when a user connects.

The details of the connecting user are available to you in the parameter userrec *user

-Definition at line 372 of file modules.cpp. +Definition at line 296 of file modules.cpp.

-

00372 { }
+
00296 { }
 
@@ -2106,9 +2106,9 @@ Called whenever a user's socket is closed.

The details of the exiting user are available to you in the parameter userrec *user This event is called for all users, registered or not, as a cleanup method for modules which might assign resources to user, such as dns lookups, objects and sockets.

-Definition at line 374 of file modules.cpp. +Definition at line 298 of file modules.cpp.

-

00374 { }
+
00298 { }
 
@@ -2151,9 +2151,9 @@ Called when a user joins a channel.

The details of the joining user are available to you in the parameter userrec *user, and the details of the channel they have joined is available in the variable chanrec *channel

-Definition at line 375 of file modules.cpp. +Definition at line 299 of file modules.cpp.

-

00375 { }
+
00299 { }
 
@@ -2208,9 +2208,9 @@ Called whenever a user is kicked.

If this method is called, the kick is already underway and cannot be prevented, so to prevent a kick, please use Module::OnUserPreKick instead of this method.

-Definition at line 404 of file modules.cpp. +Definition at line 328 of file modules.cpp.

-

00404 { };
+
00328 { };
 
@@ -2253,9 +2253,9 @@ Called when a user parts a channel.

The details of the leaving user are available to you in the parameter userrec *user, and the details of the channel they have left is available in the variable chanrec *channel

-Definition at line 376 of file modules.cpp. +Definition at line 300 of file modules.cpp.

-

00376 { }
+
00300 { }
 
@@ -2298,9 +2298,9 @@ Called after any nickchange, local or remote.

This can be used to track users after nickchanges have been applied. Please note that although you can see remote nickchanges through this function, you should NOT make any changes to the userrec if the user is a remote user as this may cause a desnyc. check user->server before taking any action (including returning nonzero from the method). Because this method is called after the nickchange is taken place, no return values are possible to indicate forbidding of the nick change. Use OnUserPreNick for this.

-Definition at line 391 of file modules.cpp. +Definition at line 315 of file modules.cpp.

-

00391 { };
+
00315 { };
 
@@ -2349,9 +2349,9 @@ Called whenever a user is about to invite another user into a channel, before an

Returning 1 from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter invites to channels.

-Definition at line 387 of file modules.cpp. +Definition at line 311 of file modules.cpp.

-

00387 { return 0; };
+
00311 { return 0; };
 
@@ -2402,9 +2402,9 @@ Returning a value of 1 from this function stops the process immediately, causing IMPORTANT NOTE!

If the user joins a NEW channel which does not exist yet, OnUserPreJoin will be called BEFORE the channel record is created. This will cause chanrec* chan to be NULL. There is very little you can do in form of processing on the actual channel record at this point, however the channel NAME will still be passed in char* cname, so that you could for example implement a channel blacklist or whitelist, etc.

-Definition at line 381 of file modules.cpp. +Definition at line 305 of file modules.cpp.

-

00381 { return 0; }
+
00305 { return 0; }
 
@@ -2459,9 +2459,9 @@ Called whenever a user is about to be kicked.

Returning a value of 1 from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc.

-Definition at line 403 of file modules.cpp. +Definition at line 327 of file modules.cpp.

-

00403 { return 0; };
+
00327 { return 0; };
 
@@ -2516,9 +2516,9 @@ Called whenever a user is about to PRIVMSG A user or a channel, before any proce

Returning any nonzero value from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter or redirect messages. target_type can be one of TYPE_USER or TYPE_CHANNEL. If the target_type value is a user, you must cast dest to a userrec* otherwise you must cast it to a chanrec*, this is the details of where the message is destined to be sent.

-Definition at line 388 of file modules.cpp. +Definition at line 312 of file modules.cpp.

-

00388 { return 0; };
+
00312 { return 0; };
 
@@ -2561,9 +2561,9 @@ Called before any nickchange, local or remote.

This can be used to implement Q-lines etc. Please note that although you can see remote nickchanges through this function, you should NOT make any changes to the userrec if the user is a remote user as this may cause a desnyc. check user->server before taking any action (including returning nonzero from the method). If your method returns nonzero, the nickchange is silently forbidden, and it is down to your module to generate some meaninful output.

-Definition at line 390 of file modules.cpp. +Definition at line 314 of file modules.cpp.

-

00390 { return 0; };
+
00314 { return 0; };
 
@@ -2618,9 +2618,9 @@ Called whenever a user is about to NOTICE A user or a channel, before any proces

Returning any nonzero value from this function stops the process immediately, causing no output to be sent to the user by the core. If you do this you must produce your own numerics, notices etc. This is useful for modules which may want to filter or redirect messages. target_type can be one of TYPE_USER or TYPE_CHANNEL. If the target_type value is a user, you must cast dest to a userrec* otherwise you must cast it to a chanrec*, this is the details of where the message is destined to be sent. You may alter the message text as you wish before relinquishing control to the next module in the chain, and if no other modules block the text this altered form of the text will be sent out to the user and possibly to other servers.

-Definition at line 389 of file modules.cpp. +Definition at line 313 of file modules.cpp.

-

00389 { return 0; };
+
00313 { return 0; };
 
@@ -2654,9 +2654,9 @@ Called when a user quits.

The details of the exiting user are available to you in the parameter userrec *user This event is only called when the user is fully registered when they quit. To catch raw disconnections, use the OnUserDisconnect method.

-Definition at line 373 of file modules.cpp. +Definition at line 297 of file modules.cpp.

-

00373 { }
+
00297 { }
 
@@ -2690,9 +2690,9 @@ Called whenever a user is about to register their connection (e.g.

before the user is sent the MOTD etc). Modules can use this method if they are performing a function which must be done before the actual connection is completed (e.g. ident lookups, dnsbl lookups, etc). Note that you should NOT delete the user record here by causing a disconnection! Use OnUserConnect for that instead.

-Definition at line 402 of file modules.cpp. +Definition at line 326 of file modules.cpp.

-

00402 { };
+
00326 { };
 
@@ -2726,11 +2726,11 @@ Called during a netburst to sync user data.

This is called during the netburst on a per-user basis. You should use this call to up any special user-related things which are implemented by your module, e.g. sending listmodes. You may return multiple commands in the string_list.

-Definition at line 393 of file modules.cpp. +Definition at line 317 of file modules.cpp.

References string_list.

-

00393 { string_list empty; return empty; }
+
00317 { string_list empty; return empty; }
 
@@ -2773,15 +2773,15 @@ Called whenever a /WHOIS is performed on a local user.

The source parameter contains the details of the user who issued the WHOIS command, and the dest parameter contains the information of the user they are whoising.

-Definition at line 386 of file modules.cpp. +Definition at line 310 of file modules.cpp.

-

00386 { };
+
00310 { };
 

The documentation for this class was generated from the following files: -
Generated on Fri May 13 15:49:48 2005 for InspIRCd by +
Generated on Sun May 15 17:03:37 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModuleFactory-members.html b/docs/module-doc/classModuleFactory-members.html index 5519f0ffb..5ef77ef04 100644 --- a/docs/module-doc/classModuleFactory-members.html +++ b/docs/module-doc/classModuleFactory-members.html @@ -4,7 +4,7 @@ - +

ModuleFactory Member List

This is the complete list of members for ModuleFactory, including all inherited members. @@ -12,7 +12,7 @@ -
ageclassbase
classbase()classbase [inline]
ModuleFactory()ModuleFactory [inline]
~classbase()classbase [inline]
~ModuleFactory()ModuleFactory [inline, virtual]

Generated on Fri May 13 15:49:49 2005 for InspIRCd by +
Generated on Sun May 15 17:03:38 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModuleFactory.html b/docs/module-doc/classModuleFactory.html index b00be9c94..a1a0d2868 100644 --- a/docs/module-doc/classModuleFactory.html +++ b/docs/module-doc/classModuleFactory.html @@ -4,7 +4,7 @@ - +

ModuleFactory Class Reference

Instantiates classes inherited from Module This class creates a class inherited from type Module, using new. More...

@@ -36,7 +36,7 @@ This is to allow for modules to create many different variants of

-Definition at line 1291 of file modules.h.


Constructor & Destructor Documentation

+Definition at line 1294 of file modules.h.

Constructor & Destructor Documentation

@@ -64,9 +64,9 @@ Definition at line 1291 o

-Definition at line 1294 of file modules.h. +Definition at line 1297 of file modules.h.

-

01294 { }
+
01297 { }
 
@@ -97,9 +97,9 @@ Definition at line 1294 o

-Definition at line 1295 of file modules.h. +Definition at line 1298 of file modules.h.

-

01295 { }
+
01298 { }
 
@@ -136,7 +136,7 @@ Your inherited class of ModuleFactory must return a pointer to your modules.h -
Generated on Fri May 13 15:49:49 2005 for InspIRCd by +
Generated on Sun May 15 17:03:38 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModuleMessage-members.html b/docs/module-doc/classModuleMessage-members.html index 3a8e5ed5f..d8ce77629 100644 --- a/docs/module-doc/classModuleMessage-members.html +++ b/docs/module-doc/classModuleMessage-members.html @@ -4,13 +4,13 @@ - +

ModuleMessage Member List

This is the complete list of members for ModuleMessage, including all inherited members. -
ageclassbase
classbase()classbase [inline]
Send()=0ModuleMessage [pure virtual]
~classbase()classbase [inline]

Generated on Fri May 13 15:49:50 2005 for InspIRCd by +
Generated on Sun May 15 17:03:39 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classModuleMessage.html b/docs/module-doc/classModuleMessage.html index 131048528..5a0bdc877 100644 --- a/docs/module-doc/classModuleMessage.html +++ b/docs/module-doc/classModuleMessage.html @@ -4,7 +4,7 @@ - +

ModuleMessage Class Reference

The ModuleMessage class is the base class of Request and Event This class is used to represent a basic data structure which is passed between modules for safe inter-module communications. More...

@@ -67,7 +67,7 @@ Implemented in Request, and


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:50 2005 for InspIRCd by +
Generated on Sun May 15 17:03:39 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classQLine-members.html b/docs/module-doc/classQLine-members.html index 608837f36..276be9e04 100644 --- a/docs/module-doc/classQLine-members.html +++ b/docs/module-doc/classQLine-members.html @@ -4,7 +4,7 @@ - +

QLine Member List

This is the complete list of members for QLine, including all inherited members. @@ -16,7 +16,7 @@ -
ageclassbase
classbase()classbase [inline]
set_timeXLine
sourceXLine
~classbase()classbase [inline]

Generated on Fri May 13 15:49:51 2005 for InspIRCd by +
Generated on Sun May 15 17:03:40 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classQLine.html b/docs/module-doc/classQLine.html index 2bf8bc2e1..e2497ebd0 100644 --- a/docs/module-doc/classQLine.html +++ b/docs/module-doc/classQLine.html @@ -4,7 +4,7 @@ - +

QLine Class Reference

QLine class. More...

@@ -90,7 +90,7 @@ Definition at line 114 of f


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:51 2005 for InspIRCd by +
Generated on Sun May 15 17:03:40 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classRequest-members.html b/docs/module-doc/classRequest-members.html index 4c2a09d65..93ea57e2a 100644 --- a/docs/module-doc/classRequest-members.html +++ b/docs/module-doc/classRequest-members.html @@ -4,7 +4,7 @@ - +

Request Member List

This is the complete list of members for Request, including all inherited members. @@ -17,7 +17,7 @@ -
ageclassbase
classbase()classbase [inline]
Send()Request [virtual]
sourceRequest [protected]
~classbase()classbase [inline]

Generated on Fri May 13 15:49:53 2005 for InspIRCd by +
Generated on Sun May 15 17:03:41 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classRequest.html b/docs/module-doc/classRequest.html index bf74a61c4..d4d3154d4 100644 --- a/docs/module-doc/classRequest.html +++ b/docs/module-doc/classRequest.html @@ -4,7 +4,7 @@ - +

Request Class Reference

The Request class is a unicast message directed at a given module. More...

@@ -103,9 +103,9 @@ Create a new Request.

-Definition at line 316 of file modules.cpp. +Definition at line 240 of file modules.cpp.

-

00316 : data(anydata), source(src), dest(dst) { };
+
00240 : data(anydata), source(src), dest(dst) { };
 
@@ -139,13 +139,13 @@ Fetch the Request data.

-Definition at line 318 of file modules.cpp. +Definition at line 242 of file modules.cpp.

References data.

-

00319 {
-00320         return this->data;
-00321 }
+
00243 {
+00244         return this->data;
+00245 }
 
@@ -178,13 +178,13 @@ Fetch the request destination (should be 'this' in the receiving module).

-Definition at line 328 of file modules.cpp. +Definition at line 252 of file modules.cpp.

References dest.

-

00329 {
-00330         return this->dest;
-00331 }
+
00253 {
+00254         return this->dest;
+00255 }
 
@@ -217,13 +217,13 @@ Fetch the request source.

-Definition at line 323 of file modules.cpp. +Definition at line 247 of file modules.cpp.

References source.

-

00324 {
-00325         return this->source;
-00326 }
+
00248 {
+00249         return this->source;
+00250 }
 
@@ -258,20 +258,20 @@ Upon returning the result will be arbitary data returned by the module you sent

Implements ModuleMessage.

-Definition at line 333 of file modules.cpp. +Definition at line 257 of file modules.cpp.

-References dest, and Module::OnRequest(). +References dest, and Module::OnRequest().

-

00334 {
-00335         if (this->dest)
-00336         {
-00337                 return dest->OnRequest(this);
-00338         }
-00339         else
-00340         {
-00341                 return NULL;
-00342         }
-00343 }
+
00258 {
+00259         if (this->dest)
+00260         {
+00261                 return dest->OnRequest(this);
+00262         }
+00263         else
+00264         {
+00265                 return NULL;
+00266         }
+00267 }
 
@@ -301,7 +301,7 @@ This member holds a pointer to arbitary data set by the emitter of the message.

Definition at line 159 of file modules.h.

-Referenced by GetData(). +Referenced by GetData().

@@ -329,7 +329,7 @@ The single destination of the Request.

Definition at line 166 of file modules.h.

-Referenced by GetDest(), and Send(). +Referenced by GetDest(), and Send().

@@ -357,12 +357,12 @@ This is a pointer to the sender of the message, which can be used to directly tr

Definition at line 163 of file modules.h.

-Referenced by GetSource(). +Referenced by GetSource().


The documentation for this class was generated from the following files: -
Generated on Fri May 13 15:49:53 2005 for InspIRCd by +
Generated on Sun May 15 17:03:41 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classServer-members.html b/docs/module-doc/classServer-members.html index 7458e46db..fddda36eb 100644 --- a/docs/module-doc/classServer-members.html +++ b/docs/module-doc/classServer-members.html @@ -4,72 +4,73 @@ - +

Server Member List

This is the complete list of members for Server, including all inherited members. - - - - - - - - + + + + + + + + - - - - - + + + + + - - - - - + + + + + - + - + + - + - - - + + + - - - - - - - - - - - + + + + + + + + + + + - + - + - + -
AddCommand(char *cmd, handlerfunc f, char flags, int minparams, char *source)Server [virtual]
AddELine(long duration, std::string source, std::string reason, std::string hostmask)Server [virtual]
AddExtendedListMode(char modechar)Server [virtual]
AddExtendedMode(char modechar, int type, bool requires_oper, int params_when_on, int params_when_off)Server [virtual]
AddGLine(long duration, std::string source, std::string reason, std::string hostmask)Server [virtual]
AddKLine(long duration, std::string source, std::string reason, std::string hostmask)Server [virtual]
AddQLine(long duration, std::string source, std::string reason, std::string nickname)Server [virtual]
AddZLine(long duration, std::string source, std::string reason, std::string ipaddr)Server [virtual]
AddCommand(char *cmd, handlerfunc f, char flags, int minparams, char *source)Server [virtual]
AddELine(long duration, std::string source, std::string reason, std::string hostmask)Server [virtual]
AddExtendedListMode(char modechar)Server [virtual]
AddExtendedMode(char modechar, int type, bool requires_oper, int params_when_on, int params_when_off)Server [virtual]
AddGLine(long duration, std::string source, std::string reason, std::string hostmask)Server [virtual]
AddKLine(long duration, std::string source, std::string reason, std::string hostmask)Server [virtual]
AddQLine(long duration, std::string source, std::string reason, std::string nickname)Server [virtual]
AddZLine(long duration, std::string source, std::string reason, std::string ipaddr)Server [virtual]
ageclassbase
CalcDuration(std::string duration)Server [virtual]
CallCommandHandler(std::string commandname, char **parameters, int pcnt, userrec *user)Server [virtual]
ChangeGECOS(userrec *user, std::string gecos)Server [virtual]
ChangeHost(userrec *user, std::string host)Server [virtual]
ChangeUserNick(userrec *user, std::string nickname)Server [virtual]
CalcDuration(std::string duration)Server [virtual]
CallCommandHandler(std::string commandname, char **parameters, int pcnt, userrec *user)Server [virtual]
ChangeGECOS(userrec *user, std::string gecos)Server [virtual]
ChangeHost(userrec *user, std::string host)Server [virtual]
ChangeUserNick(userrec *user, std::string nickname)Server [virtual]
ChanMode(userrec *User, chanrec *Chan)Server [virtual]
classbase()classbase [inline]
CommonChannels(userrec *u1, userrec *u2)Server [virtual]
CountUsers(chanrec *c)Server [virtual]
DelELine(std::string hostmask)Server [virtual]
DelGLine(std::string hostmask)Server [virtual]
DelKLine(std::string hostmask)Server [virtual]
DelQLine(std::string nickname)Server [virtual]
DelZLine(std::string ipaddr)Server [virtual]
DelELine(std::string hostmask)Server [virtual]
DelGLine(std::string hostmask)Server [virtual]
DelKLine(std::string hostmask)Server [virtual]
DelQLine(std::string nickname)Server [virtual]
DelZLine(std::string ipaddr)Server [virtual]
FindChannel(std::string channel)Server [virtual]
FindDescriptor(int socket)Server [virtual]
FindModule(std::string name)Server [virtual]
FindModule(std::string name)Server [virtual]
FindNick(std::string nick)Server [virtual]
GetAdmin()Server [virtual]
GetAdmin()Server [virtual]
GetNetworkName()Server [virtual]
GetServerDescription()Server [virtual]
GetServerName()Server [virtual]
GetUsers(chanrec *chan)Server [virtual]
GetUsers(chanrec *chan)Server [virtual]
IsNick(std::string nick)Server [virtual]
IsOnChannel(userrec *User, chanrec *Chan)Server [virtual]
IsUlined(std::string server)Server [virtual]
IsValidMask(std::string mask)Server [virtual]
JoinUserToChannel(userrec *user, std::string cname, std::string key)Server [virtual]
IsUlined(std::string server)Server [virtual]
IsValidMask(std::string mask)Server [virtual]
JoinUserToChannel(userrec *user, std::string cname, std::string key)Server [virtual]
Log(int level, std::string s)Server [virtual]
MatchText(std::string sliteral, std::string spattern)Server [virtual]
MeshCheckChan(chanrec *c, std::string servername)Server [virtual]
MeshCheckCommon(userrec *u, std::string servername)Server [virtual]
MeshSendAll(std::string text)Server [virtual]
MeshSendAllAlive(std::string text)Server [virtual]
MeshSendAllExcept(std::string target, std::string text)Server [virtual]
MeshSendCommon(userrec *user, std::string text)Server [virtual]
MeshSendUnicast(std::string destination, std::string text)Server [virtual]
PartUserFromChannel(userrec *user, std::string cname, std::string reason)Server [virtual]
PseudoToUser(userrec *alive, userrec *zombie, std::string message)Server [virtual]
QuitUser(userrec *user, std::string reason)Server [virtual]
MatchText(std::string sliteral, std::string spattern)Server [virtual]
MeshCheckChan(chanrec *c, std::string servername)Server [virtual]
MeshCheckCommon(userrec *u, std::string servername)Server [virtual]
MeshSendAll(std::string text)Server [virtual]
MeshSendAllAlive(std::string text)Server [virtual]
MeshSendAllExcept(std::string target, std::string text)Server [virtual]
MeshSendCommon(userrec *user, std::string text)Server [virtual]
MeshSendUnicast(std::string destination, std::string text)Server [virtual]
PartUserFromChannel(userrec *user, std::string cname, std::string reason)Server [virtual]
PseudoToUser(userrec *alive, userrec *zombie, std::string message)Server [virtual]
QuitUser(userrec *user, std::string reason)Server [virtual]
Send(int Socket, std::string s)Server [virtual]
SendChannel(userrec *User, chanrec *Channel, std::string s, bool IncludeSender)Server [virtual]
SendChannelServerNotice(std::string ServName, chanrec *Channel, std::string text)Server [virtual]
SendCommon(userrec *User, std::string text, bool IncludeSender)Server [virtual]
SendFrom(int Socket, userrec *User, std::string s)Server [virtual]
SendMode(char **parameters, int pcnt, userrec *user)Server [virtual]
SendMode(char **parameters, int pcnt, userrec *user)Server [virtual]
SendOpers(std::string s)Server [virtual]
SendServ(int Socket, std::string s)Server [virtual]
SendTo(userrec *Source, userrec *Dest, std::string s)Server [virtual]
SendToModeMask(std::string modes, int flags, std::string text)Server [virtual]
SendToModeMask(std::string modes, int flags, std::string text)Server [virtual]
SendWallops(userrec *User, std::string text)Server [virtual]
Server()Server
UserToPseudo(userrec *user, std::string message)Server [virtual]
UserToPseudo(userrec *user, std::string message)Server [virtual]
~classbase()classbase [inline]
~Server()Server [virtual]

Generated on Fri May 13 15:49:55 2005 for InspIRCd by +
Generated on Sun May 15 17:03:43 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classServer.html b/docs/module-doc/classServer.html index b065a5dd7..1b20ba109 100644 --- a/docs/module-doc/classServer.html +++ b/docs/module-doc/classServer.html @@ -4,7 +4,7 @@ - +

Server Class Reference

Allows server output and query functions This class contains methods which allow a module to query the state of the irc server, and produce output to users and other servers. More...

@@ -87,120 +87,123 @@ Inheritance diagram for Server:

virtual std::string GetNetworkName ()  Returns the network name, global to all linked servers.

-virtual Admin GetAdmin () +virtual std::string GetServerDescription () - Returns the information of the server as returned by the /ADMIN command.


-virtual bool AddExtendedMode (char modechar, int type, bool requires_oper, int params_when_on, int params_when_off) + Returns the server description string of the local server.


+virtual Admin GetAdmin () - Adds an extended mode letter which is parsed by a module.


-virtual bool AddExtendedListMode (char modechar) + Returns the information of the server as returned by the /ADMIN command.


+virtual bool AddExtendedMode (char modechar, int type, bool requires_oper, int params_when_on, int params_when_off) - Adds an extended mode letter which is parsed by a module and handled in a list fashion.


-virtual void AddCommand (char *cmd, handlerfunc f, char flags, int minparams, char *source) + Adds an extended mode letter which is parsed by a module.


+virtual bool AddExtendedListMode (char modechar) - Adds a command to the command table.


-virtual void SendMode (char **parameters, int pcnt, userrec *user) + Adds an extended mode letter which is parsed by a module and handled in a list fashion.


+virtual void AddCommand (char *cmd, handlerfunc f, char flags, int minparams, char *source) - Sends a servermode.


-virtual void SendToModeMask (std::string modes, int flags, std::string text) + Adds a command to the command table.


+virtual void SendMode (char **parameters, int pcnt, userrec *user) - Sends to all users matching a mode mask You must specify one or more usermodes as the first parameter.


-virtual chanrecJoinUserToChannel (userrec *user, std::string cname, std::string key) + Sends a servermode.


+virtual void SendToModeMask (std::string modes, int flags, std::string text) - Forces a user to join a channel.


-virtual chanrecPartUserFromChannel (userrec *user, std::string cname, std::string reason) + Sends to all users matching a mode mask You must specify one or more usermodes as the first parameter.


+virtual chanrecJoinUserToChannel (userrec *user, std::string cname, std::string key) - Forces a user to part a channel.


-virtual void ChangeUserNick (userrec *user, std::string nickname) + Forces a user to join a channel.


+virtual chanrecPartUserFromChannel (userrec *user, std::string cname, std::string reason) - Forces a user nickchange.


-virtual void QuitUser (userrec *user, std::string reason) + Forces a user to part a channel.


+virtual void ChangeUserNick (userrec *user, std::string nickname) - Forces a user to quit with the specified reason.


-virtual bool MatchText (std::string sliteral, std::string spattern) + Forces a user nickchange.


+virtual void QuitUser (userrec *user, std::string reason) - Matches text against a glob pattern.


-virtual void CallCommandHandler (std::string commandname, char **parameters, int pcnt, userrec *user) + Forces a user to quit with the specified reason.


+virtual bool MatchText (std::string sliteral, std::string spattern) - Calls the handler for a command, either implemented by the core or by another module.


-virtual void ChangeHost (userrec *user, std::string host) + Matches text against a glob pattern.


+virtual void CallCommandHandler (std::string commandname, char **parameters, int pcnt, userrec *user) - Change displayed hostname of a user.


-virtual void ChangeGECOS (userrec *user, std::string gecos) + Calls the handler for a command, either implemented by the core or by another module.


+virtual void ChangeHost (userrec *user, std::string host) - Change GECOS (fullname) of a user.


-virtual bool IsUlined (std::string server) + Change displayed hostname of a user.


+virtual void ChangeGECOS (userrec *user, std::string gecos) - Returns true if the servername you give is ulined.


-virtual chanuserlist GetUsers (chanrec *chan) + Change GECOS (fullname) of a user.


+virtual bool IsUlined (std::string server) - Fetches the userlist of a channel.


-virtual bool UserToPseudo (userrec *user, std::string message) + Returns true if the servername you give is ulined.


+virtual chanuserlist GetUsers (chanrec *chan) - Remove a user's connection to the irc server, but leave their client in existence in the user hash.


-virtual bool PseudoToUser (userrec *alive, userrec *zombie, std::string message) + Fetches the userlist of a channel.


+virtual bool UserToPseudo (userrec *user, std::string message) - This user takes one user, and switches their file descriptor with another user, so that one user "becomes" the other.


-virtual void AddGLine (long duration, std::string source, std::string reason, std::string hostmask) + Remove a user's connection to the irc server, but leave their client in existence in the user hash.


+virtual bool PseudoToUser (userrec *alive, userrec *zombie, std::string message) - Adds a G-line The G-line is propogated to all of the servers in the mesh and enforced as soon as it is added.


-virtual void AddQLine (long duration, std::string source, std::string reason, std::string nickname) + This user takes one user, and switches their file descriptor with another user, so that one user "becomes" the other.


+virtual void AddGLine (long duration, std::string source, std::string reason, std::string hostmask) - Adds a Q-line The Q-line is propogated to all of the servers in the mesh and enforced as soon as it is added.


-virtual void AddZLine (long duration, std::string source, std::string reason, std::string ipaddr) + Adds a G-line The G-line is propogated to all of the servers in the mesh and enforced as soon as it is added.


+virtual void AddQLine (long duration, std::string source, std::string reason, std::string nickname) - Adds a Z-line The Z-line is propogated to all of the servers in the mesh and enforced as soon as it is added.


-virtual void AddKLine (long duration, std::string source, std::string reason, std::string hostmask) + Adds a Q-line The Q-line is propogated to all of the servers in the mesh and enforced as soon as it is added.


+virtual void AddZLine (long duration, std::string source, std::string reason, std::string ipaddr) - Adds a K-line The K-line is enforced as soon as it is added.


-virtual void AddELine (long duration, std::string source, std::string reason, std::string hostmask) + Adds a Z-line The Z-line is propogated to all of the servers in the mesh and enforced as soon as it is added.


+virtual void AddKLine (long duration, std::string source, std::string reason, std::string hostmask) - Adds a E-line The E-line is enforced as soon as it is added.


-virtual bool DelGLine (std::string hostmask) + Adds a K-line The K-line is enforced as soon as it is added.


+virtual void AddELine (long duration, std::string source, std::string reason, std::string hostmask) - Deletes a G-Line from all servers on the mesh.


-virtual bool DelQLine (std::string nickname) + Adds a E-line The E-line is enforced as soon as it is added.


+virtual bool DelGLine (std::string hostmask) - Deletes a Q-Line from all servers on the mesh.


-virtual bool DelZLine (std::string ipaddr) + Deletes a G-Line from all servers on the mesh.


+virtual bool DelQLine (std::string nickname) - Deletes a Z-Line from all servers on the mesh.


-virtual bool DelKLine (std::string hostmask) + Deletes a Q-Line from all servers on the mesh.


+virtual bool DelZLine (std::string ipaddr) - Deletes a local K-Line.


-virtual bool DelELine (std::string hostmask) + Deletes a Z-Line from all servers on the mesh.


+virtual bool DelKLine (std::string hostmask) - Deletes a local E-Line.


-virtual long CalcDuration (std::string duration) + Deletes a local K-Line.


+virtual bool DelELine (std::string hostmask) - Calculates a duration This method will take a string containing a formatted duration (e.g.


-virtual bool IsValidMask (std::string mask) + Deletes a local E-Line.


+virtual long CalcDuration (std::string duration) - Returns true if a nick!ident string is correctly formatted, false if otherwise.


-virtual void MeshSendAll (std::string text) + Calculates a duration This method will take a string containing a formatted duration (e.g.


+virtual bool IsValidMask (std::string mask) - Sends a line of text to all connected servers.


-virtual void MeshSendCommon (userrec *user, std::string text) + Returns true if a nick!ident string is correctly formatted, false if otherwise.


+virtual void MeshSendAll (std::string text) - This method sends a line of text to all servers who have users which share common channels with the user you provide.


-virtual void MeshSendAllAlive (std::string text) + Sends a line of text to all connected servers.


+virtual void MeshSendCommon (userrec *user, std::string text) - This function is equivalent to Server::MeshSendToAll except it will only route to servers which are directly routable.


-virtual void MeshSendUnicast (std::string destination, std::string text) + This method sends a line of text to all servers who have users which share common channels with the user you provide.


+virtual void MeshSendAllAlive (std::string text) - This function sends a line of text directly to a server.


-virtual void MeshSendAllExcept (std::string target, std::string text) + This function is equivalent to Server::MeshSendToAll except it will only route to servers which are directly routable.


+virtual void MeshSendUnicast (std::string destination, std::string text) - This function sends to all servers EXCEPT the one you specify.


-virtual bool MeshCheckChan (chanrec *c, std::string servername) + This function sends a line of text directly to a server.


+virtual void MeshSendAllExcept (std::string target, std::string text) - This function is used to check if any users on channel c are on server servername.


-virtual bool MeshCheckCommon (userrec *u, std::string servername) + This function sends to all servers EXCEPT the one you specify.


+virtual bool MeshCheckChan (chanrec *c, std::string servername) - This function is used to check if user u has any channels in common with users on servername.


-virtual ModuleFindModule (std::string name) + This function is used to check if any users on channel c are on server servername.


+virtual bool MeshCheckCommon (userrec *u, std::string servername) - This function finds a module by name.


+ This function is used to check if user u has any channels in common with users on servername.


+virtual ModuleFindModule (std::string name) + + This function finds a module by name.



Detailed Description

Allows server output and query functions This class contains methods which allow a module to query the state of the irc server, and produce output to users and other servers. @@ -239,10 +242,10 @@ Default constructor.

Creates a Server object.

-Definition at line 431 of file modules.cpp. +Definition at line 355 of file modules.cpp.

-

00432 {
-00433 }
+
00356 {
+00357 }
 
@@ -275,15 +278,15 @@ Default destructor.

Destroys a Server object.

-Definition at line 435 of file modules.cpp. +Definition at line 359 of file modules.cpp.

-

00436 {
-00437 }
+
00360 {
+00361 }
 

Member Function Documentation

-

+

@@ -342,17 +345,17 @@ This allows modules to add extra commands into the command table. You must place typedef void (handlerfunc) (char**, int, userrec*); ... void handle_kill(char **parameters, int pcnt, userrec *user)

When the command is typed, the parameters will be placed into the parameters array (similar to argv) and the parameter count will be placed into pcnt (similar to argv). There will never be any less parameters than the 'minparams' value you specified when creating the command. The *user parameter is the class of the user which caused the command to trigger, who will always have the flag you specified in 'flags' when creating the initial command. For example to create an oper only command create the commands with flags='o'. The source parameter is used for resource tracking, and should contain the name of your module (with file extension) e.g. "m_blarp.so". If you place the wrong identifier here, you can cause crashes if your module is unloaded.

-Definition at line 504 of file modules.cpp. +Definition at line 428 of file modules.cpp.

References createcommand().

-

00505 {
-00506         createcommand(cmd,f,flags,minparams,source);
-00507 }
+
00429 {
+00430         createcommand(cmd,f,flags,minparams,source);
+00431 }
 
-

+

@@ -401,19 +404,19 @@ References createcommand().

Adds a E-line The E-line is enforced as soon as it is added.

-The duration must be in seconds, however you can use the Server::CalcDuration method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. +The duration must be in seconds, however you can use the Server::CalcDuration method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name.

-Definition at line 750 of file modules.cpp. +Definition at line 679 of file modules.cpp.

References add_eline(), and duration().

-

00751 {
-00752         add_eline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
-00753 }
+
00680 {
+00681         add_eline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
+00682 }
 
-

+

@@ -448,20 +451,20 @@ This call is used to implement modes like +q and +a. The characteristics of thes (4) The mode and its parameter are NOT stored in the channels modes structure

It is down to the module handling the mode to maintain state and determine what 'items' (e.g. users, or a banlist) have the mode set on them, and process the modes at the correct times, e.g. during access checks on channels, etc. When the extended mode is triggered the OnExtendedMode method will be triggered as above. Note that the target you are given will be a channel, if for example your mode is set 'on a user' (in for example +a) you must use Server::Find to locate the user the mode is operating on. Your mode handler may return 1 to handle the mode AND tell the core to display the mode change, e.g. '+aaa one two three' in the case of the mode for 'two', or it may return -1 to 'eat' the mode change, so the above example would become '+aa one three' after processing.

-Definition at line 667 of file modules.cpp. +Definition at line 596 of file modules.cpp.

-References DoAddExtendedMode(), ModeMakeList(), and MT_CHANNEL. +References DoAddExtendedMode(), ModeMakeList(), and MT_CHANNEL.

-

00668 {
-00669         bool res = DoAddExtendedMode(modechar,MT_CHANNEL,false,1,1);
-00670         if (res)
-00671                 ModeMakeList(modechar);
-00672         return res;
-00673 }
+
00597 {
+00598         bool res = DoAddExtendedMode(modechar,MT_CHANNEL,false,1,1);
+00599         if (res)
+00600                 ModeMakeList(modechar);
+00601         return res;
+00602 }
 
-

+

@@ -518,40 +521,40 @@ Adds an extended mode letter which is parsed by a module.

This allows modules to add extra mode letters, e.g. +x for hostcloak. the "type" parameter is either MT_CHANNEL, MT_CLIENT, or MT_SERVER, to indicate wether the mode is a channel mode, a client mode, or a server mode. requires_oper is used with MT_CLIENT type modes only to indicate the mode can only be set or unset by an oper. If this is used for MT_CHANNEL type modes it is ignored. params_when_on is the number of modes to expect when the mode is turned on (for type MT_CHANNEL only), e.g. with mode +k, this would have a value of 1. the params_when_off value has a similar value to params_when_on, except it indicates the number of parameters to expect when the mode is disabled. Modes which act in a similar way to channel mode +l (e.g. require a parameter to enable, but not to disable) should use this parameter. The function returns false if the mode is unavailable, and will not attempt to allocate another character, as this will confuse users. This also means that as only one module can claim a specific mode character, the core does not need to keep track of which modules own which modes, which speeds up operation of the server. In this version, a mode can have at most one parameter, attempting to use more parameters will have undefined effects.

-Definition at line 639 of file modules.cpp. -

-References DEBUG, DoAddExtendedMode(), MT_CLIENT, and MT_SERVER. -

-

00640 {
-00641         if (((modechar >= 'A') && (modechar <= 'Z')) || ((modechar >= 'a') && (modechar <= 'z')))
-00642         {
-00643                 if (type == MT_SERVER)
-00644                 {
-00645                         log(DEBUG,"*** API ERROR *** Modes of type MT_SERVER are reserved for future expansion");
-00646                         return false;
-00647                 }
-00648                 if (((params_when_on>0) || (params_when_off>0)) && (type == MT_CLIENT))
-00649                 {
-00650                         log(DEBUG,"*** API ERROR *** Parameters on MT_CLIENT modes are not supported");
-00651                         return false;
-00652                 }
-00653                 if ((params_when_on>1) || (params_when_off>1))
-00654                 {
-00655                         log(DEBUG,"*** API ERROR *** More than one parameter for an MT_CHANNEL mode is not yet supported");
-00656                         return false;
-00657                 }
-00658                 return DoAddExtendedMode(modechar,type,requires_oper,params_when_on,params_when_off);
-00659         }
-00660         else
-00661         {
-00662                 log(DEBUG,"*** API ERROR *** Muppet modechar detected.");
-00663         }
-00664         return false;
-00665 }
+Definition at line 568 of file modules.cpp.
+

+References DEBUG, DoAddExtendedMode(), MT_CLIENT, and MT_SERVER. +

+

00569 {
+00570         if (((modechar >= 'A') && (modechar <= 'Z')) || ((modechar >= 'a') && (modechar <= 'z')))
+00571         {
+00572                 if (type == MT_SERVER)
+00573                 {
+00574                         log(DEBUG,"*** API ERROR *** Modes of type MT_SERVER are reserved for future expansion");
+00575                         return false;
+00576                 }
+00577                 if (((params_when_on>0) || (params_when_off>0)) && (type == MT_CLIENT))
+00578                 {
+00579                         log(DEBUG,"*** API ERROR *** Parameters on MT_CLIENT modes are not supported");
+00580                         return false;
+00581                 }
+00582                 if ((params_when_on>1) || (params_when_off>1))
+00583                 {
+00584                         log(DEBUG,"*** API ERROR *** More than one parameter for an MT_CHANNEL mode is not yet supported");
+00585                         return false;
+00586                 }
+00587                 return DoAddExtendedMode(modechar,type,requires_oper,params_when_on,params_when_off);
+00588         }
+00589         else
+00590         {
+00591                 log(DEBUG,"*** API ERROR *** Muppet modechar detected.");
+00592         }
+00593         return false;
+00594 }
 
-

+

@@ -600,19 +603,19 @@ References DEBUG, Adds a G-line The G-line is propogated to all of the servers in the mesh and enforced as soon as it is added.

-The duration must be in seconds, however you can use the Server::CalcDuration method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. +The duration must be in seconds, however you can use the Server::CalcDuration method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name.

-Definition at line 730 of file modules.cpp. +Definition at line 659 of file modules.cpp.

References add_gline(), and duration().

-

00731 {
-00732         add_gline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
-00733 }
+
00660 {
+00661         add_gline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
+00662 }
 
-

+

@@ -661,19 +664,19 @@ References add_gline(), and Server::CalcDuration method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. +The duration must be in seconds, however you can use the Server::CalcDuration method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name.

-Definition at line 745 of file modules.cpp. +Definition at line 674 of file modules.cpp.

References add_kline(), and duration().

-

00746 {
-00747         add_kline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
-00748 }
+
00675 {
+00676         add_kline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
+00677 }
 
-

+

@@ -722,19 +725,19 @@ References add_kline(), and Server::CalcDuration method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. +The duration must be in seconds, however you can use the Server::CalcDuration method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name.

-Definition at line 735 of file modules.cpp. +Definition at line 664 of file modules.cpp.

References add_qline(), and duration().

-

00736 {
-00737         add_qline(duration, source.c_str(), reason.c_str(), nickname.c_str());
-00738 }
+
00665 {
+00666         add_qline(duration, source.c_str(), reason.c_str(), nickname.c_str());
+00667 }
 
-

+

@@ -783,19 +786,19 @@ References add_qline(), and Server::CalcDuration method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name. +The duration must be in seconds, however you can use the Server::CalcDuration method to convert durations into the 1w2d3h3m6s format used by /GLINE etc. The source is an arbitary string used to indicate who or what sent the data, usually this is the nickname of a person, or a server name.

-Definition at line 740 of file modules.cpp. +Definition at line 669 of file modules.cpp.

References add_zline(), and duration().

-

00741 {
-00742         add_zline(duration, source.c_str(), reason.c_str(), ipaddr.c_str());
-00743 }
+
00670 {
+00671         add_zline(duration, source.c_str(), reason.c_str(), ipaddr.c_str());
+00672 }
 
-

+

@@ -825,17 +828,17 @@ Calculates a duration This method will take a string containing a formatted dura

"1w2d") and return its value as a total number of seconds. This is the same function used internally by /GLINE etc to set the ban times.

-Definition at line 780 of file modules.cpp. +Definition at line 709 of file modules.cpp.

References duration().

-

00781 {
-00782         return duration(delta.c_str());
-00783 }
+
00710 {
+00711         return duration(delta.c_str());
+00712 }
 
-

+

@@ -885,17 +888,17 @@ References duration(). Calls the handler for a command, either implemented by the core or by another module.

You can use this function to trigger other commands in the ircd, such as PRIVMSG, JOIN, KICK etc, or even as a method of callback. By defining command names that are untypeable for users on irc (e.g. those which contain a or
-) you may use them as callback identifiers. The first parameter to this method is the name of the command handler you wish to call, e.g. PRIVMSG. This will be a command handler previously registered by the core or wih AddCommand(). The second parameter is an array of parameters, and the third parameter is a count of parameters in the array. If you do not pass enough parameters to meet the minimum needed by the handler, the functiom will silently ignore it. The final parameter is the user executing the command handler, used for privilage checks, etc. +) you may use them as callback identifiers. The first parameter to this method is the name of the command handler you wish to call, e.g. PRIVMSG. This will be a command handler previously registered by the core or wih AddCommand(). The second parameter is an array of parameters, and the third parameter is a count of parameters in the array. If you do not pass enough parameters to meet the minimum needed by the handler, the functiom will silently ignore it. The final parameter is the user executing the command handler, used for privilage checks, etc.

-Definition at line 494 of file modules.cpp. +Definition at line 418 of file modules.cpp.

-

00495 {
-00496         call_handler(commandname.c_str(),parameters,pcnt,user);
-00497 }
+
00419 {
+00420         call_handler(commandname.c_str(),parameters,pcnt,user);
+00421 }
 
-

+

@@ -934,17 +937,17 @@ Change GECOS (fullname) of a user.

You should always call this method to change a user's GECOS rather than writing directly to the fullname member of userrec, as any change applied via this method will be propogated to any linked servers.

-Definition at line 587 of file modules.cpp. +Definition at line 511 of file modules.cpp.

References ChangeName().

-

00588 {
-00589         ChangeName(user,gecos.c_str());
-00590 }
+
00512 {
+00513         ChangeName(user,gecos.c_str());
+00514 }
 
-

+

@@ -983,17 +986,17 @@ Change displayed hostname of a user.

You should always call this method to change a user's host rather than writing directly to the dhost member of userrec, as any change applied via this method will be propogated to any linked servers.

-Definition at line 582 of file modules.cpp. +Definition at line 506 of file modules.cpp.

References ChangeDisplayedHost().

-

00583 {
-00584         ChangeDisplayedHost(user,host.c_str());
-00585 }
+
00507 {
+00508         ChangeDisplayedHost(user,host.c_str());
+00509 }
 
-

+

@@ -1032,11 +1035,11 @@ Forces a user nickchange.

This command works similarly to SVSNICK, and can be used to implement Q-lines etc. If you specify an invalid nickname, the nick change will be dropped and the target user will receive the error numeric for it.

-Definition at line 479 of file modules.cpp. +Definition at line 403 of file modules.cpp.

-

00480 {
-00481         force_nickchange(user,nickname.c_str());
-00482 }
+
00404 {
+00405         force_nickchange(user,nickname.c_str());
+00406 }
 
@@ -1079,13 +1082,13 @@ Attempts to look up a user's privilages on a channel.

This function will return a string containing either @, , +, or an empty string, representing the user's privilages upon the channel you specify.

-Definition at line 612 of file modules.cpp. +Definition at line 536 of file modules.cpp.

References cmode().

-

00613 {
-00614         return cmode(User,Chan);
-00615 }
+
00537 {
+00538         return cmode(User,Chan);
+00539 }
 
@@ -1128,13 +1131,13 @@ Returns true if two users share a common channel.

This method is used internally by the NICK and QUIT commands, and the Server::SendCommon method.

-Definition at line 560 of file modules.cpp. +Definition at line 484 of file modules.cpp.

References common_channels().

-

00561 {
-00562         return (common_channels(u1,u2) != 0);
-00563 }
+
00485 {
+00486         return (common_channels(u1,u2) != 0);
+00487 }
 
@@ -1168,15 +1171,15 @@ Returns a count of the number of users on a channel.

This will NEVER be 0, as if the chanrec exists, it will have at least one user in the channel.

-Definition at line 675 of file modules.cpp. +Definition at line 604 of file modules.cpp.

-

00676 {
-00677         return usercount(c);
-00678 }
+
00605 {
+00606         return usercount(c);
+00607 }
 
-

+

@@ -1206,17 +1209,17 @@ Deletes a local E-Line.

-Definition at line 775 of file modules.cpp. +Definition at line 704 of file modules.cpp.

References del_eline().

-

00776 {
-00777         del_eline(hostmask.c_str());
-00778 }
+
00705 {
+00706         del_eline(hostmask.c_str());
+00707 }
 
-

+

@@ -1246,17 +1249,17 @@ Deletes a G-Line from all servers on the mesh.

-Definition at line 755 of file modules.cpp. +Definition at line 684 of file modules.cpp.

References del_gline().

-

00756 {
-00757         del_gline(hostmask.c_str());
-00758 }
+
00685 {
+00686         del_gline(hostmask.c_str());
+00687 }
 
-

+

@@ -1286,17 +1289,17 @@ Deletes a local K-Line.

-Definition at line 770 of file modules.cpp. +Definition at line 699 of file modules.cpp.

References del_kline().

-

00771 {
-00772         del_kline(hostmask.c_str());
-00773 }
+
00700 {
+00701         del_kline(hostmask.c_str());
+00702 }
 
-

+

@@ -1326,17 +1329,17 @@ Deletes a Q-Line from all servers on the mesh.

-Definition at line 760 of file modules.cpp. +Definition at line 689 of file modules.cpp.

References del_qline().

-

00761 {
-00762         del_qline(nickname.c_str());
-00763 }
+
00690 {
+00691         del_qline(nickname.c_str());
+00692 }
 
-

+

@@ -1366,13 +1369,13 @@ Deletes a Z-Line from all servers on the mesh.

-Definition at line 765 of file modules.cpp. +Definition at line 694 of file modules.cpp.

References del_zline().

-

00766 {
-00767         del_zline(ipaddr.c_str());
-00768 }
+
00695 {
+00696         del_zline(ipaddr.c_str());
+00697 }
 
@@ -1406,11 +1409,11 @@ Attempts to look up a channel and return a pointer to it.

This function will return NULL if the channel does not exist.

-Definition at line 607 of file modules.cpp. +Definition at line 531 of file modules.cpp.

-

00608 {
-00609         return FindChan(channel.c_str());
-00610 }
+
00532 {
+00533         return FindChan(channel.c_str());
+00534 }
 
@@ -1444,17 +1447,17 @@ Attempts to look up a nick using the file descriptor associated with that nick.

This function will return NULL if the file descriptor is not associated with a valid user.

-Definition at line 602 of file modules.cpp. +Definition at line 526 of file modules.cpp.

-References fd_ref_table. +References fd_ref_table.

-

00603 {
-00604         return (socket < 65536 ? fd_ref_table[socket] : NULL);
-00605 }
+
00527 {
+00528         return (socket < 65536 ? fd_ref_table[socket] : NULL);
+00529 }
 
-

+

@@ -1484,20 +1487,20 @@ This function finds a module by name.

You must provide the filename of the module. If the module cannot be found (is not loaded) the function will return NULL.

-Definition at line 858 of file modules.cpp. +Definition at line 787 of file modules.cpp.

-References MODCOUNT, module_names, and modules. +References MODCOUNT, module_names, and modules.

-

00859 {
-00860         for (int i = 0; i <= MODCOUNT; i++)
-00861         {
-00862                 if (module_names[i] == name)
-00863                 {
-00864                         return modules[i];
-00865                 }
-00866         }
-00867         return NULL;
-00868 }
+
00788 {
+00789         for (int i = 0; i <= MODCOUNT; i++)
+00790         {
+00791                 if (module_names[i] == name)
+00792                 {
+00793                         return modules[i];
+00794                 }
+00795         }
+00796         return NULL;
+00797 }
 
@@ -1531,15 +1534,15 @@ Attempts to look up a nick and return a pointer to it.

This function will return NULL if the nick does not exist.

-Definition at line 597 of file modules.cpp. +Definition at line 521 of file modules.cpp.

-

00598 {
-00599         return Find(nick);
-00600 }
+
00522 {
+00523         return Find(nick);
+00524 }
 
-

+

@@ -1568,11 +1571,11 @@ Returns the information of the server as returned by the /ADMIN command.

See the Admin class for further information of the return value. The members Admin::Nick, Admin::Email and Admin::Name contain the information for the server where the module is loaded.

-Definition at line 632 of file modules.cpp. +Definition at line 561 of file modules.cpp.

-

00633 {
-00634         return Admin(getadminname(),getadminemail(),getadminnick());
-00635 }
+
00562 {
+00563         return Admin(getadminname(),getadminemail(),getadminnick());
+00564 }
 
@@ -1605,11 +1608,48 @@ Returns the network name, global to all linked servers.

-Definition at line 627 of file modules.cpp. +Definition at line 551 of file modules.cpp. +

+

00552 {
+00553         return getnetworkname();
+00554 }
+
+ + +

+ + + + +
+ + + + + + + + + +
std::string Server::GetServerDescription  )  [virtual]
+
+ + + +
+   + + +

+Returns the server description string of the local server. +

+ +

+Definition at line 556 of file modules.cpp.

-

00628 {
-00629         return getnetworkname();
-00630 }
+
00557 {
+00558         return getserverdesc();
+00559 }
 
@@ -1642,15 +1682,15 @@ Returns the server name of the server where the module is loaded.

-Definition at line 622 of file modules.cpp. +Definition at line 546 of file modules.cpp.

-

00623 {
-00624         return getservername();
-00625 }
+
00547 {
+00548         return getservername();
+00549 }
 
-

+

@@ -1680,21 +1720,21 @@ Fetches the userlist of a channel.

This function must be here and not a member of userrec or chanrec due to include constraints.

-Definition at line 467 of file modules.cpp. -

-References chanuserlist, chanrec::GetUsers(), and list. -

-

00468 {
-00469         chanuserlist userl;
-00470         userl.clear();
-00471         std::vector<char*> *list = chan->GetUsers();
-00472         for (std::vector<char*>::iterator i = list->begin(); i != list->end(); i++)
-00473         {
-00474                 char* o = *i;
-00475                 userl.push_back((userrec*)o);
-00476         }
-00477         return userl;
-00478 }
+Definition at line 391 of file modules.cpp.
+

+References chanuserlist, chanrec::GetUsers(), and list. +

+

00392 {
+00393         chanuserlist userl;
+00394         userl.clear();
+00395         std::vector<char*> *list = chan->GetUsers();
+00396         for (std::vector<char*>::iterator i = list->begin(); i != list->end(); i++)
+00397         {
+00398                 char* o = *i;
+00399                 userl.push_back((userrec*)o);
+00400         }
+00401         return userl;
+00402 }
 
@@ -1728,13 +1768,13 @@ Returns true if a nick is valid.

Nicks for unregistered connections will return false.

-Definition at line 592 of file modules.cpp. +Definition at line 516 of file modules.cpp.

References isnick().

-

00593 {
-00594         return (isnick(nick.c_str()) != 0);
-00595 }
+
00517 {
+00518         return (isnick(nick.c_str()) != 0);
+00519 }
 
@@ -1777,17 +1817,17 @@ Checks if a user is on a channel.

This function will return true or false to indicate if user 'User' is on channel 'Chan'.

-Definition at line 617 of file modules.cpp. +Definition at line 541 of file modules.cpp.

References has_channel().

-

00618 {
-00619         return has_channel(User,Chan);
-00620 }
+
00542 {
+00543         return has_channel(User,Chan);
+00544 }
 
-

+

@@ -1817,17 +1857,17 @@ Returns true if the servername you give is ulined.

ULined servers have extra privilages. They are allowed to change nicknames on remote servers, change modes of clients which are on remote servers and set modes of channels where there are no channel operators for that channel on the ulined server, amongst other things. Ulined server data is also broadcast across the mesh at all times as opposed to selectively messaged in the case of normal servers, as many ulined server types (such as services) do not support meshed links and must operate in this manner.

-Definition at line 489 of file modules.cpp. +Definition at line 413 of file modules.cpp.

References is_uline().

-

00490 {
-00491         return is_uline(server.c_str());
-00492 }
+
00414 {
+00415         return is_uline(server.c_str());
+00416 }
 
-

+

@@ -1857,39 +1897,39 @@ Returns true if a nick!ident string is correctly formatted, false if otherwise.

-Definition at line 785 of file modules.cpp. -

-

00786 {
-00787         const char* dest = mask.c_str();
-00788         if (strchr(dest,'!')==0)
-00789                 return false;
-00790         if (strchr(dest,'@')==0)
-00791                 return false;
-00792         for (int i = 0; i < strlen(dest); i++)
-00793                 if (dest[i] < 32)
-00794                         return false;
-00795         for (int i = 0; i < strlen(dest); i++)
-00796                 if (dest[i] > 126)
-00797                         return false;
-00798         int c = 0;
-00799         for (int i = 0; i < strlen(dest); i++)
-00800                 if (dest[i] == '!')
-00801                         c++;
-00802         if (c>1)
-00803                 return false;
-00804         c = 0;
-00805         for (int i = 0; i < strlen(dest); i++)
-00806                 if (dest[i] == '@')
-00807                         c++;
-00808         if (c>1)
-00809                 return false;
-00810 
-00811         return true;
-00812 }
+Definition at line 714 of file modules.cpp.
+

+

00715 {
+00716         const char* dest = mask.c_str();
+00717         if (strchr(dest,'!')==0)
+00718                 return false;
+00719         if (strchr(dest,'@')==0)
+00720                 return false;
+00721         for (int i = 0; i < strlen(dest); i++)
+00722                 if (dest[i] < 32)
+00723                         return false;
+00724         for (int i = 0; i < strlen(dest); i++)
+00725                 if (dest[i] > 126)
+00726                         return false;
+00727         int c = 0;
+00728         for (int i = 0; i < strlen(dest); i++)
+00729                 if (dest[i] == '!')
+00730                         c++;
+00731         if (c>1)
+00732                 return false;
+00733         c = 0;
+00734         for (int i = 0; i < strlen(dest); i++)
+00735                 if (dest[i] == '@')
+00736                         c++;
+00737         if (c>1)
+00738                 return false;
+00739 
+00740         return true;
+00741 }
 
-

+

@@ -1934,11 +1974,11 @@ Forces a user to join a channel.

This is similar to svsjoin and can be used to implement redirection, etc. On success, the return value is a valid pointer to a chanrec* of the channel the user was joined to. On failure, the result is NULL.

-Definition at line 457 of file modules.cpp. +Definition at line 381 of file modules.cpp.

-

00458 {
-00459         return add_channel(user,cname.c_str(),key.c_str(),false);
-00460 }
+
00382 {
+00383         return add_channel(user,cname.c_str(),key.c_str(),false);
+00384 }
 
@@ -1981,15 +2021,15 @@ Writes a log string.

This method writes a line of text to the log. If the level given is lower than the level given in the configuration, this command has no effect.

-Definition at line 499 of file modules.cpp. +Definition at line 423 of file modules.cpp.

-

00500 {
-00501         log(level,"%s",s.c_str());
-00502 }
+
00424 {
+00425         log(level,"%s",s.c_str());
+00426 }
 
-

+

@@ -2028,18 +2068,18 @@ Matches text against a glob pattern.

Uses the ircd's internal matching function to match string against a globbing pattern, e.g. *!*@*.com Returns true if the literal successfully matches the pattern, false if otherwise.

-Definition at line 444 of file modules.cpp. +Definition at line 368 of file modules.cpp.

-

00445 {
-00446         char literal[MAXBUF],pattern[MAXBUF];
-00447         strlcpy(literal,sliteral.c_str(),MAXBUF);
-00448         strlcpy(pattern,spattern.c_str(),MAXBUF);
-00449         return match(literal,pattern);
-00450 }
+
00369 {
+00370         char literal[MAXBUF],pattern[MAXBUF];
+00371         strlcpy(literal,sliteral.c_str(),MAXBUF);
+00372         strlcpy(pattern,spattern.c_str(),MAXBUF);
+00373         return match(literal,pattern);
+00374 }
 
-

+

@@ -2078,19 +2118,19 @@ This function is used to check if any users on channel c are on server servernam

This is used internally by PRIVMSG etc. You should not need to use it.

-Definition at line 840 of file modules.cpp. +Definition at line 769 of file modules.cpp.

-

00841 {
-00842         if (c)
-00843         {
-00844                 return ChanAnyOnThisServer(c,(char*)servername.c_str());
-00845         }
-00846         else return false;
-00847 }
+
00770 {
+00771         if (c)
+00772         {
+00773                 return ChanAnyOnThisServer(c,(char*)servername.c_str());
+00774         }
+00775         else return false;
+00776 }
 
-

+

@@ -2127,21 +2167,21 @@ Definition at line 840

This function is used to check if user u has any channels in common with users on servername.

-This is used internally by Server::MeshSendCommon. You should very rarely need to use it. +This is used internally by Server::MeshSendCommon. You should very rarely need to use it.

-Definition at line 849 of file modules.cpp. +Definition at line 778 of file modules.cpp.

-

00850 {
-00851         if (u)
-00852         {
-00853                 return CommonOnThisServer(u,(char*)servername.c_str());
-00854         }
-00855         else return false;
-00856 }
+
00779 {
+00780         if (u)
+00781         {
+00782                 return CommonOnThisServer(u,(char*)servername.c_str());
+00783         }
+00784         else return false;
+00785 }
 
-

+

@@ -2171,15 +2211,15 @@ Sends a line of text to all connected servers.

If a server is not directly reachable, the core deals with routing the message, and will also deal with failures transparently.

-Definition at line 814 of file modules.cpp. +Definition at line 743 of file modules.cpp.

-

00815 {
-00816         NetSendToAll((char*)text.c_str());
-00817 }
+
00744 {
+00745         NetSendToAll((char*)text.c_str());
+00746 }
 
-

+

@@ -2209,15 +2249,15 @@ This function is equivalent to Server::MeshSendToAll except it will only route t

-Definition at line 825 of file modules.cpp. +Definition at line 754 of file modules.cpp.

-

00826 {
-00827         NetSendToAllAlive((char*)text.c_str());
-00828 }
+
00755 {
+00756         NetSendToAllAlive((char*)text.c_str());
+00757 }
 
-

+

@@ -2256,15 +2296,15 @@ This function sends to all servers EXCEPT the one you specify.

You should usually use this function to send messages, specifying the SENDER of your message as 'target'. This will prevent message loops.

-Definition at line 835 of file modules.cpp. +Definition at line 764 of file modules.cpp.

-

00836 {
-00837         NetSendToAllExcept(target.c_str(),(char*)text.c_str());
-00838 }
+
00765 {
+00766         NetSendToAllExcept(target.c_str(),(char*)text.c_str());
+00767 }
 
-

+

@@ -2303,16 +2343,16 @@ This method sends a line of text to all servers who have users which share commo

For example, if user A is on server A, and they are on channels #one and #two, and user B is on server B, and also on channel #one, but user C is on server C and on neither #one or #two, this function will cause the text to only be sent to server B. However, if server B is only reachable via C, it will route it to C (you do not have to worry about this routing, it is done transparently, but its good to know how things work!)

-Definition at line 819 of file modules.cpp. +Definition at line 748 of file modules.cpp.

-

00820 {
-00821         if (user)
-00822                 NetSendToCommon(user,(char*)text.c_str());
-00823 }
+
00749 {
+00750         if (user)
+00751                 NetSendToCommon(user,(char*)text.c_str());
+00752 }
 
-

+

@@ -2351,15 +2391,15 @@ This function sends a line of text directly to a server.

If the server is not directly routable at this time, the server attempts to route text through the mesh.

-Definition at line 830 of file modules.cpp. +Definition at line 759 of file modules.cpp.

-

00831 {
-00832         NetSendToOne((char*)destination.c_str(),(char*)text.c_str());
-00833 }
+
00760 {
+00761         NetSendToOne((char*)destination.c_str(),(char*)text.c_str());
+00762 }
 
-

+

@@ -2404,15 +2444,15 @@ Forces a user to part a channel.

This is similar to svspart and can be used to implement redirection, etc. Although the return value of this function is a pointer to a channel record, the returned data is undefined and should not be read or written to. This behaviour may be changed in a future version.

-Definition at line 462 of file modules.cpp. +Definition at line 386 of file modules.cpp.

-

00463 {
-00464         return del_channel(user,cname.c_str(),reason.c_str(),false);
-00465 }
+
00387 {
+00388         return del_channel(user,cname.c_str(),reason.c_str(),false);
+00389 }
 
-

+

@@ -2457,42 +2497,42 @@ This user takes one user, and switches their file descriptor with another user,

The user in 'alive' is booted off the server with the given message. The user referred to by 'zombie' should have previously been locked with Server::ZombifyUser, otherwise stale sockets and file descriptor leaks can occur. After this call, the pointer to alive will be invalid, and the pointer to zombie will be equivalent in effect to the old pointer to alive.

-Definition at line 700 of file modules.cpp. -

-References ucrec::channel, userrec::chans, userrec::ClearBuffer(), connection::fd, FD_MAGIC_NUMBER, fd_ref_table, connection::host, userrec::ident, chanrec::name, userrec::nick, chanrec::setby, chanrec::topic, and chanrec::topicset. -

-

00701 {
-00702         zombie->fd = alive->fd;
-00703         alive->fd = FD_MAGIC_NUMBER;
-00704         alive->ClearBuffer();
-00705         Write(zombie->fd,":%s!%s@%s NICK %s",alive->nick,alive->ident,alive->host,zombie->nick);
-00706         kill_link(alive,message.c_str());
-00707         fd_ref_table[zombie->fd] = zombie;
-00708         for (int i = 0; i != MAXCHANS; i++)
-00709         {
-00710                 if (zombie->chans[i].channel != NULL)
-00711                 {
-00712                         if (zombie->chans[i].channel->name)
-00713                         {
-00714                                 chanrec* Ptr = zombie->chans[i].channel;
-00715                                 WriteFrom(zombie->fd,zombie,"JOIN %s",Ptr->name);
-00716                                 if (Ptr->topicset)
-00717                                 {
-00718                                         WriteServ(zombie->fd,"332 %s %s :%s", zombie->nick, Ptr->name, Ptr->topic);
-00719                                         WriteServ(zombie->fd,"333 %s %s %s %d", zombie->nick, Ptr->name, Ptr->setby, Ptr->topicset);
-00720                                 }
-00721                                 userlist(zombie,Ptr);
-00722                                 WriteServ(zombie->fd,"366 %s %s :End of /NAMES list.", zombie->nick, Ptr->name);
-00723 
-00724                         }
-00725                 }
-00726         }
-00727 
-00728 }
+Definition at line 629 of file modules.cpp.
+

+References ucrec::channel, userrec::chans, userrec::ClearBuffer(), connection::fd, FD_MAGIC_NUMBER, fd_ref_table, connection::host, userrec::ident, chanrec::name, userrec::nick, chanrec::setby, chanrec::topic, and chanrec::topicset. +

+

00630 {
+00631         zombie->fd = alive->fd;
+00632         alive->fd = FD_MAGIC_NUMBER;
+00633         alive->ClearBuffer();
+00634         Write(zombie->fd,":%s!%s@%s NICK %s",alive->nick,alive->ident,alive->host,zombie->nick);
+00635         kill_link(alive,message.c_str());
+00636         fd_ref_table[zombie->fd] = zombie;
+00637         for (int i = 0; i != MAXCHANS; i++)
+00638         {
+00639                 if (zombie->chans[i].channel != NULL)
+00640                 {
+00641                         if (zombie->chans[i].channel->name)
+00642                         {
+00643                                 chanrec* Ptr = zombie->chans[i].channel;
+00644                                 WriteFrom(zombie->fd,zombie,"JOIN %s",Ptr->name);
+00645                                 if (Ptr->topicset)
+00646                                 {
+00647                                         WriteServ(zombie->fd,"332 %s %s :%s", zombie->nick, Ptr->name, Ptr->topic);
+00648                                         WriteServ(zombie->fd,"333 %s %s %s %d", zombie->nick, Ptr->name, Ptr->setby, Ptr->topicset);
+00649                                 }
+00650                                 userlist(zombie,Ptr);
+00651                                 WriteServ(zombie->fd,"366 %s %s :End of /NAMES list.", zombie->nick, Ptr->name);
+00652 
+00653                         }
+00654                 }
+00655         }
+00656 
+00657 }
 
-

+

@@ -2533,11 +2573,11 @@ To the user, it will appear as if they typed /QUIT themselves, except for the fa WARNING!

Once you call this function, userrec* user will immediately become INVALID. You MUST NOT write to, or read from this pointer after calling the QuitUser method UNDER ANY CIRCUMSTANCES! The best course of action after calling this method is to immediately bail from your handler.

-Definition at line 484 of file modules.cpp. +Definition at line 408 of file modules.cpp.

-

00485 {
-00486         kill_link(user,reason.c_str());
-00487 }
+
00409 {
+00410         kill_link(user,reason.c_str());
+00411 }
 
@@ -2580,11 +2620,11 @@ Sends a line of text down a TCP/IP socket.

This method writes a line of text to an established socket, cutting it to 510 characters plus a carriage return and linefeed if required.

-Definition at line 514 of file modules.cpp. +Definition at line 438 of file modules.cpp.

-

00515 {
-00516         Write(Socket,"%s",s.c_str());
-00517 }
+
00439 {
+00440         Write(Socket,"%s",s.c_str());
+00441 }
 
@@ -2639,18 +2679,18 @@ Sends text from a user to a channel (mulicast).

This method writes a line of text to a channel, with the given user's nick/ident /host combination prepended, as used in PRIVMSG etc commands (see RFC 1459). If the IncludeSender flag is set, then the text is also sent back to the user from which it originated, as seen in MODE (see RFC 1459).

-Definition at line 548 of file modules.cpp. -

-

00549 {
-00550         if (IncludeSender)
-00551         {
-00552                 WriteChannel(Channel,User,"%s",s.c_str());
-00553         }
-00554         else
-00555         {
-00556                 ChanExceptSender(Channel,User,"%s",s.c_str());
-00557         }
-00558 }
+Definition at line 472 of file modules.cpp.
+

+

00473 {
+00474         if (IncludeSender)
+00475         {
+00476                 WriteChannel(Channel,User,"%s",s.c_str());
+00477         }
+00478         else
+00479         {
+00480                 ChanExceptSender(Channel,User,"%s",s.c_str());
+00481         }
+00482 }
 
@@ -2699,11 +2739,11 @@ Writes text to a channel, but from a server, including all.

This can be used to send server notices to a group of users.

-Definition at line 543 of file modules.cpp. +Definition at line 467 of file modules.cpp.

-

00544 {
-00545         WriteChannelWithServ((char*)ServName.c_str(), Channel, "%s", text.c_str());
-00546 }
+
00468 {
+00469         WriteChannelWithServ((char*)ServName.c_str(), Channel, "%s", text.c_str());
+00470 }
 
@@ -2752,18 +2792,18 @@ Sends text from a user to one or more channels (mulicast).

This method writes a line of text to all users which share a common channel with a given user, with the user's nick/ident/host combination prepended, as used in PRIVMSG etc commands (see RFC 1459). If the IncludeSender flag is set, then the text is also sent back to the user from which it originated, as seen in NICK (see RFC 1459). Otherwise, it is only sent to the other recipients, as seen in QUIT.

-Definition at line 565 of file modules.cpp. -

-

00566 {
-00567         if (IncludeSender)
-00568         {
-00569                 WriteCommon(User,"%s",text.c_str());
-00570         }
-00571         else
-00572         {
-00573                 WriteCommonExcept(User,"%s",text.c_str());
-00574         }
-00575 }
+Definition at line 489 of file modules.cpp.
+

+

00490 {
+00491         if (IncludeSender)
+00492         {
+00493                 WriteCommon(User,"%s",text.c_str());
+00494         }
+00495         else
+00496         {
+00497                 WriteCommonExcept(User,"%s",text.c_str());
+00498         }
+00499 }
 
@@ -2812,15 +2852,15 @@ Sends text from a user to a socket.

This method writes a line of text to an established socket, with the given user's nick/ident /host combination prepended, as used in PRIVSG etc commands (see RFC 1459)

-Definition at line 524 of file modules.cpp. +Definition at line 448 of file modules.cpp.

-

00525 {
-00526         WriteFrom(Socket,User,"%s",s.c_str());
-00527 }
+
00449 {
+00450         WriteFrom(Socket,User,"%s",s.c_str());
+00451 }
 
-

+

@@ -2872,13 +2912,13 @@ modes[2] = user->nick;

Srv->SendMode(modes,3,user);

The modes will originate from the server where the command was issued, however responses (e.g. numerics) will be sent to the user you provide as the third parameter. You must be sure to get the number of parameters correct in the pcnt parameter otherwise you could leave your server in an unstable state!

-Definition at line 509 of file modules.cpp. +Definition at line 433 of file modules.cpp.

References server_mode().

-

00510 {
-00511         server_mode(parameters,pcnt,user);
-00512 }
+
00434 {
+00435         server_mode(parameters,pcnt,user);
+00436 }
 
@@ -2912,11 +2952,11 @@ Sends text to all opers.

This method sends a server notice to all opers with the usermode +s.

-Definition at line 439 of file modules.cpp. +Definition at line 363 of file modules.cpp.

-

00440 {
-00441         WriteOpers("%s",s.c_str());
-00442 }
+
00364 {
+00365         WriteOpers("%s",s.c_str());
+00366 }
 
@@ -2959,11 +2999,11 @@ Sends text from the server to a socket.

This method writes a line of text to an established socket, with the servername prepended as used by numerics (see RFC 1459)

-Definition at line 519 of file modules.cpp. +Definition at line 443 of file modules.cpp.

-

00520 {
-00521         WriteServ(Socket,"%s",s.c_str());
-00522 }
+
00444 {
+00445         WriteServ(Socket,"%s",s.c_str());
+00446 }
 
@@ -3016,26 +3056,26 @@ The format will become:

:localserver TEXT

Which is useful for numerics and server notices to single users, etc.

-Definition at line 529 of file modules.cpp. -

-References connection::fd. -

-

00530 {
-00531         if (!Source)
-00532         {
-00533                 // if source is NULL, then the message originates from the local server
-00534                 Write(Dest->fd,":%s %s",this->GetServerName().c_str(),s.c_str());
-00535         }
-00536         else
-00537         {
-00538                 // otherwise it comes from the user specified
-00539                 WriteTo(Source,Dest,"%s",s.c_str());
-00540         }
-00541 }
+Definition at line 453 of file modules.cpp.
+

+References connection::fd. +

+

00454 {
+00455         if (!Source)
+00456         {
+00457                 // if source is NULL, then the message originates from the local server
+00458                 Write(Dest->fd,":%s %s",this->GetServerName().c_str(),s.c_str());
+00459         }
+00460         else
+00461         {
+00462                 // otherwise it comes from the user specified
+00463                 WriteTo(Source,Dest,"%s",s.c_str());
+00464         }
+00465 }
 
-

+

@@ -3082,11 +3122,11 @@ These can be RFC specified modes such as +i, or module provided modes, including Serv->SendToModeMask("xi", WM_OR, "m00");

Then the text 'm00' will be sent to all users with EITHER mode x or i. Conversely if you used WM_AND, the user must have both modes set to receive the message.

-Definition at line 452 of file modules.cpp. +Definition at line 376 of file modules.cpp.

-

00453 {
-00454         WriteMode(modes.c_str(),flags,"%s",text.c_str());
-00455 }
+
00377 {
+00378         WriteMode(modes.c_str(),flags,"%s",text.c_str());
+00379 }
 
@@ -3129,15 +3169,15 @@ Sends a WALLOPS message.

This method writes a WALLOPS message to all users with the +w flag, originating from the specified user.

-Definition at line 577 of file modules.cpp. +Definition at line 501 of file modules.cpp.

-

00578 {
-00579         WriteWallOps(User,false,"%s",text.c_str());
-00580 }
+
00502 {
+00503         WriteWallOps(User,false,"%s",text.c_str());
+00504 }
 
-

+

@@ -3176,33 +3216,33 @@ Remove a user's connection to the irc server, but leave their client in existenc

When you call this function, the user's file descriptor will be replaced with the value of FD_MAGIC_NUMBER and their old file descriptor will be closed. This idle client will remain until it is restored with a valid file descriptor, or is removed from IRC by an operator After this call, the pointer to user will be invalid.

-Definition at line 681 of file modules.cpp. -

-References userrec::ClearBuffer(), DEBUG, connection::fd, FD_MAGIC_NUMBER, connection::host, and userrec::ident. -

-

00682 {
-00683         unsigned int old_fd = user->fd;
-00684         user->fd = FD_MAGIC_NUMBER;
-00685         user->ClearBuffer();
-00686         Write(old_fd,"ERROR :Closing link (%s@%s) [%s]",user->ident,user->host,message.c_str());
-00687 #ifdef USE_KQUEUE
-00688         struct kevent ke;
-00689         EV_SET(&ke, old_fd, EVFILT_READ, EV_DELETE, 0, 0, NULL);
-00690         int i = kevent(kq, &ke, 1, 0, 0, NULL);
-00691         if (i == -1)
-00692         {
-00693                 log(DEBUG,"kqueue: Failed to remove user from queue!");
-00694         }
-00695 #endif
-00696         shutdown(old_fd,2);
-00697         close(old_fd);
-00698 }
+Definition at line 610 of file modules.cpp.
+

+References userrec::ClearBuffer(), DEBUG, connection::fd, FD_MAGIC_NUMBER, connection::host, and userrec::ident. +

+

00611 {
+00612         unsigned int old_fd = user->fd;
+00613         user->fd = FD_MAGIC_NUMBER;
+00614         user->ClearBuffer();
+00615         Write(old_fd,"ERROR :Closing link (%s@%s) [%s]",user->ident,user->host,message.c_str());
+00616 #ifdef USE_KQUEUE
+00617         struct kevent ke;
+00618         EV_SET(&ke, old_fd, EVFILT_READ, EV_DELETE, 0, 0, NULL);
+00619         int i = kevent(kq, &ke, 1, 0, 0, NULL);
+00620         if (i == -1)
+00621         {
+00622                 log(DEBUG,"kqueue: Failed to remove user from queue!");
+00623         }
+00624 #endif
+00625         shutdown(old_fd,2);
+00626         close(old_fd);
+00627 }
 


The documentation for this class was generated from the following files: -
Generated on Fri May 13 15:49:55 2005 for InspIRCd by +
Generated on Sun May 15 17:03:43 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classVersion-members.html b/docs/module-doc/classVersion-members.html index 14be1c20a..8bfb03d10 100644 --- a/docs/module-doc/classVersion-members.html +++ b/docs/module-doc/classVersion-members.html @@ -4,7 +4,7 @@ - +

Version Member List

This is the complete list of members for Version, including all inherited members. @@ -15,7 +15,7 @@ -
ageclassbase
BuildVersion
RevisionVersion
Version(int major, int minor, int revision, int build, int flags)Version
~classbase()classbase [inline]

Generated on Fri May 13 15:50:07 2005 for InspIRCd by +
Generated on Sun May 15 17:03:52 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classVersion.html b/docs/module-doc/classVersion.html index 3f83fc228..2a3373493 100644 --- a/docs/module-doc/classVersion.html +++ b/docs/module-doc/classVersion.html @@ -4,7 +4,7 @@ - +

Version Class Reference

Holds a module's Version information The four members (set by the constructor only) indicate details as to the version number of a module. More...

@@ -98,9 +98,9 @@ Definition at line 111 of

-Definition at line 310 of file modules.cpp. +Definition at line 234 of file modules.cpp.

-

00310 : Major(major), Minor(minor), Revision(revision), Build(build), Flags(flags) { };
+
00234 : Major(major), Minor(minor), Revision(revision), Build(build), Flags(flags) { };
 
@@ -227,7 +227,7 @@ Definition at line 114 of
The documentation for this class was generated from the following files: -
Generated on Fri May 13 15:50:07 2005 for InspIRCd by +
Generated on Sun May 15 17:03:52 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classWhoWasUser-members.html b/docs/module-doc/classWhoWasUser-members.html index 709b32406..31f07221d 100644 --- a/docs/module-doc/classWhoWasUser-members.html +++ b/docs/module-doc/classWhoWasUser-members.html @@ -4,7 +4,7 @@ - +

WhoWasUser Member List

This is the complete list of members for WhoWasUser, including all inherited members. @@ -13,7 +13,7 @@ -
dhostWhoWasUser
fullnameWhoWasUser
nickWhoWasUser
serverWhoWasUser
signonWhoWasUser

Generated on Fri May 13 15:50:07 2005 for InspIRCd by +
Generated on Sun May 15 17:03:53 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classWhoWasUser.html b/docs/module-doc/classWhoWasUser.html index 5958d81dd..cc427000f 100644 --- a/docs/module-doc/classWhoWasUser.html +++ b/docs/module-doc/classWhoWasUser.html @@ -4,7 +4,7 @@ - +

WhoWasUser Class Reference

A lightweight userrec used by WHOWAS. More...

@@ -34,7 +34,7 @@ A lightweight userrec used by WHOWAS.

-Definition at line 315 of file users.h.


Member Data Documentation

+Definition at line 318 of file users.h.

Member Data Documentation

@@ -56,7 +56,7 @@ Definition at line 315 of f

-Definition at line 320 of file users.h. +Definition at line 323 of file users.h.

@@ -80,7 +80,7 @@ Definition at line 320 of f

-Definition at line 322 of file users.h. +Definition at line 325 of file users.h.

@@ -104,7 +104,7 @@ Definition at line 322 of f

-Definition at line 321 of file users.h. +Definition at line 324 of file users.h.

@@ -128,7 +128,7 @@ Definition at line 321 of f

-Definition at line 319 of file users.h. +Definition at line 322 of file users.h.

@@ -152,7 +152,7 @@ Definition at line 319 of f

-Definition at line 318 of file users.h. +Definition at line 321 of file users.h.

@@ -176,7 +176,7 @@ Definition at line 318 of f

-Definition at line 323 of file users.h. +Definition at line 326 of file users.h.

@@ -200,12 +200,12 @@ Definition at line 323 of f

-Definition at line 324 of file users.h. +Definition at line 327 of file users.h.


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:50:07 2005 for InspIRCd by +
Generated on Sun May 15 17:03:53 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classXLine-members.html b/docs/module-doc/classXLine-members.html index f2cb45c69..0e58b98e8 100644 --- a/docs/module-doc/classXLine-members.html +++ b/docs/module-doc/classXLine-members.html @@ -4,7 +4,7 @@ - +

XLine Member List

This is the complete list of members for XLine, including all inherited members. @@ -14,7 +14,7 @@ -
ageclassbase
classbase()classbase [inline]
set_timeXLine
sourceXLine
~classbase()classbase [inline]

Generated on Fri May 13 15:50:08 2005 for InspIRCd by +
Generated on Sun May 15 17:03:54 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classXLine.html b/docs/module-doc/classXLine.html index ab642ac68..43585dca1 100644 --- a/docs/module-doc/classXLine.html +++ b/docs/module-doc/classXLine.html @@ -4,7 +4,7 @@ - +

XLine Class Reference

XLine is the base class for ban lines such as G lines and K lines. More...

@@ -180,7 +180,7 @@ Definition at line 48 of fi


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:50:08 2005 for InspIRCd by +
Generated on Sun May 15 17:03:54 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classZLine-members.html b/docs/module-doc/classZLine-members.html index 21836295a..e3e93500b 100644 --- a/docs/module-doc/classZLine-members.html +++ b/docs/module-doc/classZLine-members.html @@ -4,7 +4,7 @@ - +

ZLine Member List

This is the complete list of members for ZLine, including all inherited members. @@ -16,7 +16,7 @@ -
ageclassbase
classbase()classbase [inline]
set_timeXLine
sourceXLine
~classbase()classbase [inline]

Generated on Fri May 13 15:50:10 2005 for InspIRCd by +
Generated on Sun May 15 17:03:55 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classZLine.html b/docs/module-doc/classZLine.html index 67b73386c..cd558704a 100644 --- a/docs/module-doc/classZLine.html +++ b/docs/module-doc/classZLine.html @@ -4,7 +4,7 @@ - +

ZLine Class Reference

ZLine class. More...

@@ -90,7 +90,7 @@ Definition at line 103 of f


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:50:10 2005 for InspIRCd by +
Generated on Sun May 15 17:03:55 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classchanrec-members.html b/docs/module-doc/classchanrec-members.html index 2a25bf948..80ec39cf3 100644 --- a/docs/module-doc/classchanrec-members.html +++ b/docs/module-doc/classchanrec-members.html @@ -4,7 +4,7 @@ - +

chanrec Member List

This is the complete list of members for chanrec, including all inherited members. @@ -33,7 +33,7 @@ -
AddUser(char *castuser)chanrec
ageclassbase
topicsetchanrec
~chanrec()chanrec [inline, virtual]
~classbase()classbase [inline]

Generated on Fri May 13 15:49:22 2005 for InspIRCd by +
Generated on Sun May 15 17:03:01 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classchanrec.html b/docs/module-doc/classchanrec.html index f3cd20fae..1e44bd8e0 100644 --- a/docs/module-doc/classchanrec.html +++ b/docs/module-doc/classchanrec.html @@ -4,7 +4,7 @@ - +

chanrec Class Reference

Holds all relevent information for a channel. More...

@@ -124,20 +124,20 @@ Creates a channel record and initialises it with default values.

-Definition at line 113 of file channels.cpp. +Definition at line 108 of file channels.cpp.

References binarymodes, created, custom_modes, internal_userlist, key, limit, name, setby, topic, and topicset.

-

00114 {
-00115         strcpy(name,"");
-00116         strcpy(custom_modes,"");
-00117         strcpy(topic,"");
-00118         strcpy(setby,"");
-00119         strcpy(key,"");
-00120         created = topicset = limit = 0;
-00121         binarymodes = 0;
-00122         internal_userlist.clear();
-00123 }
+
00109 {
+00110         strcpy(name,"");
+00111         strcpy(custom_modes,"");
+00112         strcpy(topic,"");
+00113         strcpy(setby,"");
+00114         strcpy(key,"");
+00115         created = topicset = limit = 0;
+00116         binarymodes = 0;
+00117         internal_userlist.clear();
+00118 }
 
@@ -205,14 +205,14 @@ Add a user pointer to the internal reference list The data inserted into the ref

-Definition at line 207 of file channels.cpp. +Definition at line 202 of file channels.cpp.

References DEBUG, and internal_userlist.

-

00208 {
-00209         internal_userlist.push_back(castuser);
-00210         log(DEBUG,"Added casted user to channel's internal list");
-00211 }
+
00203 {
+00204         internal_userlist.push_back(castuser);
+00205         log(DEBUG,"Added casted user to channel's internal list");
+00206 }
 
@@ -246,22 +246,22 @@ Delete a user pointer to the internal reference list The data removed from the r

-Definition at line 213 of file channels.cpp. +Definition at line 208 of file channels.cpp.

References DEBUG, internal_userlist, and name.

-

00214 {
-00215         for (std::vector<char*>::iterator a = internal_userlist.begin(); a < internal_userlist.end(); a++)
-00216         {
-00217                 if (*a == castuser)
-00218                 {
-00219                         log(DEBUG,"Removed casted user from channel's internal list");
-00220                         internal_userlist.erase(a);
-00221                         return;
-00222                 }
-00223         }
-00224         log(DEBUG,"BUG BUG BUG! Attempt to remove an uncasted user from the internal list of %s!",name);
-00225 }
+
00209 {
+00210         for (std::vector<char*>::iterator a = internal_userlist.begin(); a < internal_userlist.end(); a++)
+00211         {
+00212                 if (*a == castuser)
+00213                 {
+00214                         log(DEBUG,"Removed casted user from channel's internal list");
+00215                         internal_userlist.erase(a);
+00216                         return;
+00217                 }
+00218         }
+00219         log(DEBUG,"BUG BUG BUG! Attempt to remove an uncasted user from the internal list of %s!",name);
+00220 }
 
@@ -295,23 +295,23 @@ Returns the parameter for a custom mode on a channel.

For example if "+L #foo" is set, and you pass this method 'L', it will return '#foo'. If the mode is not set on the channel, or the mode has no parameters associated with it, it will return an empty string.

-Definition at line 187 of file channels.cpp. -

-References custom_mode_params. -

-

00188 {
-00189         if (custom_mode_params.size())
-00190         {
-00191                 for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++)
-00192                 {
-00193                         if ((i->mode == mode) && (!strcasecmp(this->name,i->channel)))
-00194                         {
-00195                                 return i->parameter;
-00196                         }
-00197                 }
-00198         }
-00199         return "";
-00200 }
+Definition at line 182 of file channels.cpp.
+

+References custom_mode_params. +

+

00183 {
+00184         if (custom_mode_params.size())
+00185         {
+00186                 for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++)
+00187                 {
+00188                         if ((i->mode == mode) && (!strcasecmp(this->name,i->channel)))
+00189                         {
+00190                                 return i->parameter;
+00191                         }
+00192                 }
+00193         }
+00194         return "";
+00195 }
 
@@ -344,13 +344,13 @@ Obtain the channel "user counter" This returns the channel reference counter, wh

-Definition at line 202 of file channels.cpp. +Definition at line 197 of file channels.cpp.

References internal_userlist.

-

00203 {
-00204         return (this->internal_userlist.size());
-00205 }
+
00198 {
+00199         return (this->internal_userlist.size());
+00200 }
 
@@ -383,15 +383,15 @@ Obrain the internal reference list The internal reference list contains a list o

These are used for rapid comparison to determine channel membership for PRIVMSG, NOTICE, QUIT, PART etc. The resulting pointer to the vector should be considered readonly and only modified via AddUser and DelUser.

-Definition at line 227 of file channels.cpp. +Definition at line 222 of file channels.cpp.

References internal_userlist.

-Referenced by Server::GetUsers(). +Referenced by Server::GetUsers().

-

00228 {
-00229         return &internal_userlist;
-00230 }
+
00223 {
+00224         return &internal_userlist;
+00225 }
 
@@ -425,14 +425,14 @@ Returns true if a custom mode is set on a channel.

-Definition at line 181 of file channels.cpp. +Definition at line 176 of file channels.cpp.

References DEBUG.

-

00182 {
-00183         log(DEBUG,"Checking ISCustomModeSet: %c %s",mode,this->custom_modes);
-00184         return (strchr(this->custom_modes,mode) != 0);
-00185 }
+
00177 {
+00178         log(DEBUG,"Checking ISCustomModeSet: %c %s",mode,this->custom_modes);
+00179         return (strchr(this->custom_modes,mode) != 0);
+00180 }
 
@@ -475,32 +475,32 @@ Sets or unsets a custom mode in the channels info.

-Definition at line 125 of file channels.cpp. -

-References custom_modes, DEBUG, and SetCustomModeParam(). -

-

00126 {
-00127         if (mode_on) {
-00128                 static char m[3];
-00129                 m[0] = mode;
-00130                 m[1] = '\0';
-00131                 if (!strchr(this->custom_modes,mode))
-00132                 {
-00133                         strlcat(custom_modes,m,MAXMODES);
-00134                 }
-00135                 log(DEBUG,"Custom mode %c set",mode);
-00136         }
-00137         else {
+Definition at line 120 of file channels.cpp.
+

+References custom_modes, DEBUG, and SetCustomModeParam(). +

+

00121 {
+00122         if (mode_on) {
+00123                 static char m[3];
+00124                 m[0] = mode;
+00125                 m[1] = '\0';
+00126                 if (!strchr(this->custom_modes,mode))
+00127                 {
+00128                         strlcat(custom_modes,m,MAXMODES);
+00129                 }
+00130                 log(DEBUG,"Custom mode %c set",mode);
+00131         }
+00132         else {
+00133 
+00134                 std::string a = this->custom_modes;
+00135                 int pos = a.find(mode);
+00136                 a.erase(pos,1);
+00137                 strncpy(this->custom_modes,a.c_str(),MAXMODES);
 00138 
-00139                 std::string a = this->custom_modes;
-00140                 int pos = a.find(mode);
-00141                 a.erase(pos,1);
-00142                 strncpy(this->custom_modes,a.c_str(),MAXMODES);
-00143 
-00144                 log(DEBUG,"Custom mode %c removed: modelist='%s'",mode,this->custom_modes);
-00145                 this->SetCustomModeParam(mode,"",false);
-00146         }
-00147 }
+00139                 log(DEBUG,"Custom mode %c removed: modelist='%s'",mode,this->custom_modes);
+00140                 this->SetCustomModeParam(mode,"",false);
+00141         }
+00142 }
 
@@ -549,41 +549,41 @@ Sets or unsets the parameters for a custom mode in a channels info.

-Definition at line 150 of file channels.cpp. +Definition at line 145 of file channels.cpp.

-References ModeParameter::channel, custom_mode_params, DEBUG, ModeParameter::mode, and ModeParameter::parameter. +References ModeParameter::channel, custom_mode_params, DEBUG, ModeParameter::mode, and ModeParameter::parameter.

-Referenced by SetCustomMode(). +Referenced by SetCustomMode().

-

00151 {
-00152 
-00153         log(DEBUG,"SetCustomModeParam called");
-00154         ModeParameter M;
-00155         M.mode = mode;
-00156         strlcpy(M.channel,this->name,CHANMAX);
-00157         strlcpy(M.parameter,parameter,MAXBUF);
-00158         if (mode_on)
+
00146 {
+00147 
+00148         log(DEBUG,"SetCustomModeParam called");
+00149         ModeParameter M;
+00150         M.mode = mode;
+00151         strlcpy(M.channel,this->name,CHANMAX);
+00152         strlcpy(M.parameter,parameter,MAXBUF);
+00153         if (mode_on)
+00154         {
+00155                 log(DEBUG,"Custom mode parameter %c %s added",mode,parameter);
+00156                 custom_mode_params.push_back(M);
+00157         }
+00158         else
 00159         {
-00160                 log(DEBUG,"Custom mode parameter %c %s added",mode,parameter);
-00161                 custom_mode_params.push_back(M);
-00162         }
-00163         else
-00164         {
-00165                 if (custom_mode_params.size())
-00166                 {
-00167                         for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++)
-00168                         {
-00169                                 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel)))
-00170                                 {
-00171                                         log(DEBUG,"Custom mode parameter %c %s removed",mode,parameter);
-00172                                         custom_mode_params.erase(i);
-00173                                         return;
-00174                                 }
-00175                         }
-00176                 }
-00177                 log(DEBUG,"*** BUG *** Attempt to remove non-existent mode parameter!");
-00178         }
-00179 }
+00160                 if (custom_mode_params.size())
+00161                 {
+00162                         for (vector<ModeParameter>::iterator i = custom_mode_params.begin(); i < custom_mode_params.end(); i++)
+00163                         {
+00164                                 if ((i->mode == mode) && (!strcasecmp(this->name,i->channel)))
+00165                                 {
+00166                                         log(DEBUG,"Custom mode parameter %c %s removed",mode,parameter);
+00167                                         custom_mode_params.erase(i);
+00168                                         return;
+00169                                 }
+00170                         }
+00171                 }
+00172                 log(DEBUG,"*** BUG *** Attempt to remove non-existent mode parameter!");
+00173         }
+00174 }
 
@@ -639,7 +639,7 @@ Contains a bitmask of the CM_* builtin (RFC) binary mode symbols.

Definition at line 145 of file channels.h.

-Referenced by chanrec(). +Referenced by chanrec().

@@ -667,7 +667,7 @@ Creation time.

Definition at line 123 of file channels.h.

-Referenced by chanrec(). +Referenced by chanrec().

@@ -695,7 +695,7 @@ Plugins may use this field in any way they see fit.

Definition at line 110 of file channels.h.

-Referenced by chanrec(), and SetCustomMode(). +Referenced by chanrec(), and SetCustomMode().

@@ -723,7 +723,7 @@ User list (casted to char*'s to stop forward declaration stuff) (chicken and egg

Definition at line 115 of file channels.h.

-Referenced by AddUser(), chanrec(), DelUser(), GetUserCounter(), and GetUsers(). +Referenced by AddUser(), chanrec(), DelUser(), GetUserCounter(), and GetUsers().

@@ -751,7 +751,7 @@ If this value is an empty string, there is no channel key in place.

Definition at line 141 of file channels.h.

-Referenced by chanrec(). +Referenced by chanrec().

@@ -779,7 +779,7 @@ If this value is zero, there is no limit in place.

Definition at line 136 of file channels.h.

-Referenced by chanrec(). +Referenced by chanrec().

@@ -807,7 +807,7 @@ The channels name.

Definition at line 106 of file channels.h.

-Referenced by chanrec(), DelUser(), and Server::PseudoToUser(). +Referenced by chanrec(), DelUser(), and Server::PseudoToUser().

@@ -835,7 +835,7 @@ If this member is an empty string, no topic was ever set.

Definition at line 131 of file channels.h.

-Referenced by chanrec(), and Server::PseudoToUser(). +Referenced by chanrec(), and Server::PseudoToUser().

@@ -863,7 +863,7 @@ If this is an empty string, no channel topic is set.

Definition at line 120 of file channels.h.

-Referenced by chanrec(), and Server::PseudoToUser(). +Referenced by chanrec(), and Server::PseudoToUser().

@@ -891,12 +891,12 @@ If no topic was ever set, this will be equal to 127 of file channels.h.

-Referenced by chanrec(), and Server::PseudoToUser(). +Referenced by chanrec(), and Server::PseudoToUser().


The documentation for this class was generated from the following files: -
Generated on Fri May 13 15:49:22 2005 for InspIRCd by +
Generated on Sun May 15 17:03:01 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classclassbase-members.html b/docs/module-doc/classclassbase-members.html index 1dfdbdbd5..1b414f3e3 100644 --- a/docs/module-doc/classclassbase-members.html +++ b/docs/module-doc/classclassbase-members.html @@ -4,12 +4,12 @@ - +

classbase Member List

This is the complete list of members for classbase, including all inherited members. -
ageclassbase
classbase()classbase [inline]
~classbase()classbase [inline]

Generated on Fri May 13 15:49:23 2005 for InspIRCd by +
Generated on Sun May 15 17:03:04 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classclassbase.html b/docs/module-doc/classclassbase.html index 6eda601a3..6d425626f 100644 --- a/docs/module-doc/classclassbase.html +++ b/docs/module-doc/classclassbase.html @@ -4,7 +4,7 @@ - +

classbase Class Reference

The base class for all inspircd classes. More...

@@ -150,7 +150,7 @@ Referenced by classbase().


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:23 2005 for InspIRCd by +
Generated on Sun May 15 17:03:04 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classcommand__t-members.html b/docs/module-doc/classcommand__t-members.html index 76cd68860..b5961a903 100644 --- a/docs/module-doc/classcommand__t-members.html +++ b/docs/module-doc/classcommand__t-members.html @@ -4,7 +4,7 @@ - +

command_t Member List

This is the complete list of members for command_t, including all inherited members. @@ -19,7 +19,7 @@ -
ageclassbase
classbase()classbase [inline]
total_bytescommand_t
use_countcommand_t
~classbase()classbase [inline]

Generated on Fri May 13 15:49:25 2005 for InspIRCd by +
Generated on Sun May 15 17:03:07 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classcommand__t.html b/docs/module-doc/classcommand__t.html index ddb05c0f6..2b436c462 100644 --- a/docs/module-doc/classcommand__t.html +++ b/docs/module-doc/classcommand__t.html @@ -4,7 +4,7 @@ - +

command_t Class Reference

A structure that defines a command. More...

@@ -235,7 +235,7 @@ Definition at line 43 of


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:25 2005 for InspIRCd by +
Generated on Sun May 15 17:03:07 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classconnection-members.html b/docs/module-doc/classconnection-members.html index e2b8b6d94..88b889780 100644 --- a/docs/module-doc/classconnection-members.html +++ b/docs/module-doc/classconnection-members.html @@ -4,7 +4,7 @@ - +

connection Member List

This is the complete list of members for connection, including all inherited members. @@ -29,14 +29,14 @@ - + -
AddIncoming(int fd, char *targethost, int sourceport)connection
ageclassbase
MeshCookie(char *targethost, int port, unsigned long cookie, char *servername)connection
npingconnection
portconnection
RecvPacket(std::deque< std::string > &messages, char *host)connection
RecvPacket(std::deque< std::string > &messages, char *host, std::deque< std::string > &sums)connection
registeredconnection
SendPacket(char *message, const char *host)connection
Shrink(std::string key)Extensible
signonconnection
TerminateLink(char *targethost)connection
~classbase()classbase [inline]

Generated on Fri May 13 15:49:30 2005 for InspIRCd by +
Generated on Sun May 15 17:03:15 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classconnection.html b/docs/module-doc/classconnection.html index f98b623a9..934d2b485 100644 --- a/docs/module-doc/classconnection.html +++ b/docs/module-doc/classconnection.html @@ -4,7 +4,7 @@ - +

connection Class Reference

Please note: classes serverrec and userrec both inherit from class connection. More...

@@ -42,7 +42,7 @@ Inheritance diagram for connection:

bool SendPacket (char *message, const char *host)  Send a message to a server by name, if the server is unavailable directly route the packet via another server If the server still cannot be reached after attempting to route the message remotely, returns false.

-bool RecvPacket (std::deque< std::string > &messages, char *host) +bool RecvPacket (std::deque< std::string > &messages, char *host, std::deque< std::string > &sums)  Returns the next available packet and returns true if data is available.


ircd_connectorFindHost (std::string host) @@ -103,7 +103,7 @@ Please note: classes serverrec and userrec both inherit from class connection.

-Definition at line 210 of file connection.h.


Constructor & Destructor Documentation

+Definition at line 212 of file connection.h.

Constructor & Destructor Documentation

@@ -377,7 +377,13 @@ Begin an outbound mesh link to another ircd on a network you are already an auth - + + + + + + + @@ -497,9 +503,9 @@ Stats counter for bytes inbound.

-Definition at line 227 of file connection.h. +Definition at line 229 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().

char *  host host,
std::deque< std::string > &  sums

@@ -525,9 +531,9 @@ Stats counter for bytes outbound.

-Definition at line 231 of file connection.h. +Definition at line 233 of file connection.h.

-Referenced by userrec::FlushWriteBuf(), and userrec::userrec(). +Referenced by userrec::FlushWriteBuf(), and userrec::userrec().

@@ -553,9 +559,9 @@ Stats counter for commands inbound.

-Definition at line 235 of file connection.h. +Definition at line 237 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().

@@ -581,9 +587,9 @@ Stats counter for commands outbound.

-Definition at line 239 of file connection.h. +Definition at line 241 of file connection.h.

-Referenced by userrec::FlushWriteBuf(), and userrec::userrec(). +Referenced by userrec::FlushWriteBuf(), and userrec::userrec().

@@ -609,7 +615,7 @@ With a serverrec, this is a list of all established server connections.

With a userrec this is unused.

-Definition at line 274 of file connection.h. +Definition at line 276 of file connection.h.

@@ -635,9 +641,9 @@ File descriptor of the connection.

-Definition at line 215 of file connection.h. +Definition at line 217 of file connection.h.

-Referenced by ConfigReader::DumpErrors(), Server::PseudoToUser(), Server::SendTo(), serverrec::serverrec(), userrec::userrec(), and Server::UserToPseudo(). +Referenced by ConfigReader::DumpErrors(), Server::PseudoToUser(), Server::SendTo(), serverrec::serverrec(), userrec::userrec(), and Server::UserToPseudo().

@@ -663,9 +669,9 @@ True if server/user has authenticated, false if otherwise.

-Definition at line 243 of file connection.h. +Definition at line 245 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().

@@ -691,9 +697,9 @@ Hostname of connection.

Not used if this is a serverrec

-Definition at line 219 of file connection.h. +Definition at line 221 of file connection.h.

-Referenced by userrec::GetFullRealHost(), Server::PseudoToUser(), userrec::userrec(), and Server::UserToPseudo(). +Referenced by userrec::GetFullRealHost(), Server::PseudoToUser(), userrec::userrec(), and Server::UserToPseudo().

@@ -719,9 +725,9 @@ Time that the connection last sent data, used to calculate idle time.

-Definition at line 265 of file connection.h. +Definition at line 267 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().

@@ -747,9 +753,9 @@ IP of connection.

-Definition at line 223 of file connection.h. +Definition at line 225 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().

@@ -775,9 +781,9 @@ Time the connection was last pinged.

-Definition at line 257 of file connection.h. +Definition at line 259 of file connection.h.

-Referenced by serverrec::serverrec(), and userrec::userrec(). +Referenced by serverrec::serverrec(), and userrec::userrec().

@@ -803,9 +809,9 @@ Used by PING checks with clients.

-Definition at line 269 of file connection.h. +Definition at line 271 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().

@@ -831,9 +837,9 @@ Port number For a userrec, this is the port they connected to the network on.

For a serverrec this is the current listening port of the serverrec object.

-Definition at line 249 of file connection.h. +Definition at line 251 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().

@@ -859,9 +865,9 @@ Used by userrec to indicate the registration status of the connection.

-Definition at line 253 of file connection.h. +Definition at line 255 of file connection.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().

@@ -887,14 +893,14 @@ Time the connection was created, set in the constructor.

-Definition at line 261 of file connection.h. +Definition at line 263 of file connection.h.

-Referenced by serverrec::serverrec(), and userrec::userrec(). +Referenced by serverrec::serverrec(), and userrec::userrec().


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:30 2005 for InspIRCd by +
Generated on Sun May 15 17:03:15 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classes.html b/docs/module-doc/classes.html index 76a458194..0a2857acb 100644 --- a/docs/module-doc/classes.html +++ b/docs/module-doc/classes.html @@ -4,29 +4,29 @@ - +

InspIRCd Compound Index

  A  
-
DNS   
  H  
-
ModuleFactory   StrHashComp   
Admin   dns_ip4list   HostItem   ModuleMessage   
  U  
+
DNS   HostItem   ModuleFactory   StrHashComp   
Admin   dns_ip4list   
  I  
+
ModuleMessage   
  U  
  B  
  E  
-
  I  
-
  N  
-
ucrec   
BanItem   ELine   InAddr_HashComp   nspace::hash< in_addr > (nspace)   userrec   
  C  
-
Event   Invited   nspace::hash< string > (nspace)   
  V  
-
chanrec   ExemptItem   InviteItem   
  Q  
-
Version   
classbase   Extensible   ircd_connector   QLine   
  W  
-
command_t   ExtMode   
  K  
+
InAddr_HashComp   
  N  
+
ucrec   
BanItem   ELine   Invited   nspace::hash< in_addr > (nspace)   userrec   
  C  
+
Event   InviteItem   nspace::hash< string > (nspace)   
  V  
+
chanrec   ExemptItem   irc_char_traits (irc)   
  Q  
+
Version   
char_traits (std)   Extensible   ircd_connector   QLine   
  W  
+
classbase   ExtMode   
  K  
  R  
-
WhoWasUser   
ConfigReader   
  F  
+
WhoWasUser   
command_t   
  F  
KLine   Request   
  X  
-
ConnectClass   FileReader   
  M  
+
ConfigReader   FileReader   
  M  
  S  
-
XLine   
connection   
  G  
+
XLine   
ConnectClass   
  G  
ModeParameter   Server   
  Z  
-
  D  
-
GLine   Module   serverrec   ZLine   

Generated on Fri May 13 15:49:18 2005 for InspIRCd by +connection   GLine   Module   serverrec   ZLine   
  D  
+
  H  
+
Generated on Sun May 15 17:02:54 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classircd__connector-members.html b/docs/module-doc/classircd__connector-members.html index 5ba71d6f8..fc18a6a4d 100644 --- a/docs/module-doc/classircd__connector-members.html +++ b/docs/module-doc/classircd__connector-members.html @@ -4,7 +4,7 @@ - +

ircd_connector Member List

This is the complete list of members for ircd_connector, including all inherited members. @@ -43,7 +43,7 @@ -
AddBuffer(std::string a)ircd_connector
addrircd_connector [private]
stateircd_connector [private]
versionircd_connector [private]
~classbase()classbase [inline]

Generated on Fri May 13 15:49:44 2005 for InspIRCd by +
Generated on Sun May 15 17:03:32 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classircd__connector.html b/docs/module-doc/classircd__connector.html index fd911333d..1180bca0c 100644 --- a/docs/module-doc/classircd__connector.html +++ b/docs/module-doc/classircd__connector.html @@ -4,7 +4,7 @@ - +

ircd_connector Class Reference

Each connection has one or more of these each represents ONE outbound connection to another ircd so each inbound has multiple outbounds. More...

@@ -127,7 +127,7 @@ A listening socket that accepts server type connections is represented by one cl

-Definition at line 54 of file connection.h.


Member Function Documentation

+Definition at line 56 of file connection.h.

Member Function Documentation

@@ -819,7 +819,7 @@ Sockaddr of the outbound ip and port.

-Definition at line 59 of file connection.h. +Definition at line 61 of file connection.h.

@@ -845,7 +845,7 @@ Definition at line 59

-Definition at line 71 of file connection.h. +Definition at line 73 of file connection.h.

@@ -871,7 +871,7 @@ File descriptor of the connection.

-Definition at line 63 of file connection.h. +Definition at line 65 of file connection.h.

@@ -897,7 +897,7 @@ When MakeOutboundConnection is called, these public members are filled with the

-Definition at line 99 of file connection.h. +Definition at line 101 of file connection.h.

@@ -924,7 +924,7 @@ IRCD Buffer for input characters, holds as many lines as are pending - Note that

-Definition at line 92 of file connection.h. +Definition at line 94 of file connection.h.

@@ -950,7 +950,7 @@ When MakeOutboundConnection is called, these public members are filled with the

-Definition at line 105 of file connection.h. +Definition at line 107 of file connection.h.

@@ -976,7 +976,7 @@ Definition at line 105

-Definition at line 111 of file connection.h. +Definition at line 113 of file connection.h.

@@ -1002,7 +1002,7 @@ Definition at line 111

-Definition at line 67 of file connection.h. +Definition at line 69 of file connection.h.

@@ -1028,7 +1028,7 @@ State.

STATE_NOAUTH_INBOUND, STATE_NOAUTH_OUTBOUND STATE_SYNC, STATE_DISCONNECTED, STATE_CONNECTED

-Definition at line 76 of file connection.h. +Definition at line 78 of file connection.h.

@@ -1054,12 +1054,12 @@ This string holds the ircd's version response.

-Definition at line 84 of file connection.h. +Definition at line 86 of file connection.h.


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:44 2005 for InspIRCd by +
Generated on Sun May 15 17:03:32 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classserverrec-members.html b/docs/module-doc/classserverrec-members.html index e865d7232..04b74971e 100644 --- a/docs/module-doc/classserverrec-members.html +++ b/docs/module-doc/classserverrec-members.html @@ -4,7 +4,7 @@ - +

serverrec Member List

This is the complete list of members for serverrec, including all inherited members. @@ -36,7 +36,7 @@ - + @@ -50,7 +50,7 @@ -
AddIncoming(int fd, char *targethost, int sourceport)connection
ageclassbase
opercountserverrec
pingtimeserverrec
portconnection
RecvPacket(std::deque< std::string > &messages, char *host)connection
RecvPacket(std::deque< std::string > &messages, char *host, std::deque< std::string > &sums)connection
registeredconnection
SendPacket(char *message, const char *host)connection
serverrec()serverrec
versionserverrec
~classbase()classbase [inline]
~serverrec()serverrec

Generated on Fri May 13 15:49:57 2005 for InspIRCd by +
Generated on Sun May 15 17:03:46 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classserverrec.html b/docs/module-doc/classserverrec.html index e8e7390e7..89a4c1f18 100644 --- a/docs/module-doc/classserverrec.html +++ b/docs/module-doc/classserverrec.html @@ -4,7 +4,7 @@ - +

serverrec Class Reference

A class that defines the local server or a remote server. More...

@@ -101,22 +101,22 @@ Constructor.

-Definition at line 26 of file servers.cpp. +Definition at line 27 of file servers.cpp.

-References connection::fd, hops_away, jupiter, connection::lastping, name, nickserv, opercount, pingtime, connection::signon, sync_soon, TIME, usercount, usercount_i, and version. +References connection::fd, hops_away, jupiter, connection::lastping, name, nickserv, opercount, pingtime, connection::signon, sync_soon, TIME, usercount, usercount_i, and version.

-

00027 {
-00028         strlcpy(name,"",256);
-00029         pingtime = 0;
-00030         lastping = TIME;
-00031         usercount_i = usercount = opercount = version = 0;
-00032         hops_away = 1;
-00033         signon = TIME;
-00034         jupiter = false;
-00035         fd = 0;
-00036         sync_soon = false;
-00037         strlcpy(nickserv,"",NICKMAX);
-00038 }
+
00028 {
+00029         strlcpy(name,"",256);
+00030         pingtime = 0;
+00031         lastping = TIME;
+00032         usercount_i = usercount = opercount = version = 0;
+00033         hops_away = 1;
+00034         signon = TIME;
+00035         jupiter = false;
+00036         fd = 0;
+00037         sync_soon = false;
+00038         strlcpy(nickserv,"",NICKMAX);
+00039 }
 
@@ -165,22 +165,22 @@ Constructor which initialises some of the main variables.

-Definition at line 45 of file servers.cpp. +Definition at line 46 of file servers.cpp.

-References connection::fd, hops_away, jupiter, connection::lastping, name, nickserv, opercount, connection::signon, sync_soon, TIME, usercount, usercount_i, and version. +References connection::fd, hops_away, jupiter, connection::lastping, name, nickserv, opercount, connection::signon, sync_soon, TIME, usercount, usercount_i, and version.

-

00046 {
-00047         strlcpy(name,n,256);
-00048         lastping = TIME;
-00049         usercount_i = usercount = opercount = 0;
-00050         version = ver;
-00051         hops_away = 1;
-00052         signon = TIME;
-00053         jupiter = jupe;
-00054         fd = 0;
-00055         sync_soon = false;
-00056         strlcpy(nickserv,"",NICKMAX);
-00057 }
+
00047 {
+00048         strlcpy(name,n,256);
+00049         lastping = TIME;
+00050         usercount_i = usercount = opercount = 0;
+00051         version = ver;
+00052         hops_away = 1;
+00053         signon = TIME;
+00054         jupiter = jupe;
+00055         fd = 0;
+00056         sync_soon = false;
+00057         strlcpy(nickserv,"",NICKMAX);
+00058 }
 
@@ -213,10 +213,10 @@ Destructor.

-Definition at line 41 of file servers.cpp. +Definition at line 42 of file servers.cpp.

-

00042 {
-00043 }
+
00043 {
+00044 }
 
@@ -272,7 +272,7 @@ number of hops away (for quick access)

Definition at line 51 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -300,7 +300,7 @@ is a JUPE server (faked to enforce a server ban)

Definition at line 57 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -328,7 +328,7 @@ server name

Definition at line 36 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -356,7 +356,7 @@ Holds nickserv's name on U:lined (services) servers (this is a kludge for ircser

Definition at line 65 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -384,7 +384,7 @@ opers on server

Definition at line 48 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -412,7 +412,7 @@ last ping response (ms)

Definition at line 39 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -438,7 +438,7 @@ Referenced by serverrec() Definition at line 67 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -466,7 +466,7 @@ non-invisible users on server

Definition at line 45 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -494,7 +494,7 @@ invisible users on server

Definition at line 42 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().

@@ -522,12 +522,12 @@ ircd version

Definition at line 54 of file servers.h.

-Referenced by serverrec(). +Referenced by serverrec().


The documentation for this class was generated from the following files: -
Generated on Fri May 13 15:49:57 2005 for InspIRCd by +
Generated on Sun May 15 17:03:46 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classstd_1_1char__traits.html b/docs/module-doc/classstd_1_1char__traits.html new file mode 100644 index 000000000..4838507b0 --- /dev/null +++ b/docs/module-doc/classstd_1_1char__traits.html @@ -0,0 +1,22 @@ + + +InspIRCd: char_traits class Reference + + + + +

char_traits Class Reference

Inheritance diagram for char_traits:

Inheritance graph
+ + + +
[legend]
+ +
+
The documentation for this class was generated from the following file: +
Generated on Sun May 15 17:03:02 2005 for InspIRCd by + +doxygen +1.3.3
+ + diff --git a/docs/module-doc/classstd_1_1char__traits__inherit__graph.gif b/docs/module-doc/classstd_1_1char__traits__inherit__graph.gif new file mode 100644 index 0000000000000000000000000000000000000000..f8ae3419b4ecdc72e62231b4278294e58e4b7830 GIT binary patch literal 1074 zcmV-21kL+LNk%w1VZs1(0OJ4v|Ns900092~{~sS8pP!%K-`_t!KVM&8zrVkKe}5Sn zZ~y=R000000000000000A^8LW00062EC2ui0Kx!t000F35XecZy*TU5yZ>M)j$~<` zXsWJk>%MR-&vb3yc&_h!@BhG{a7Zi~kH}77$!t2G(5Q4utvZuNt9HxnMzKY&cuc;6 zhvl?ddq%I{@Mc>WufOL(yS|JEash7xY)pb;eLsJ11zwAWhdqgFfL)VbkC0LW1ONpF z0RRUDpiBk`oCiw)35`z^sjC5{r>UtDO9v92RhK+d1gN2(2?4lF1;CS_g;15s0msD2 zOwGWoQoK7;)}MuyaUjV0O{e@;n3!e z9D)P}21sjX5TQbH-fnGUCh&$YPr<~cO1Oz0vu^&=I4pc^X5iRXJ2)T-};g>sG5> zUwj1{w#8VfWw9wp%T~qOws1)(m>ah)h`Dd=>eYZZ@7})?`uYX@S1{qjf(IY2n|Sfw z#EKoWg&bLOSjv{+Ql^_Z?dHmzvw{v?b~Nd(rcYB%tvV^|)<0jvt|)u81CP@h%cW7{rYb457*!3K7SMb{r)G{X=jb4K!IO<@QHvqET{y73MvTUKoU-9 zgM%DkXdzS;Zm3j;OqHOa2_urgQ-%|qh(d`UdcYzPFNUCyj4Q;b6^KaKh~tACpo3xw zvV@?cD;g{qKmrOu(~m7gG6@Khvn+{$lKuohfFPRyfKC9KxB?|pw0yZ`mw?!k3IX@{ zBLO-=Qa~jjS6Vs2m{}e<W|O!YRrDn_O9>E%Ja8=$#e-3V@(bF1lcsXu47; z21ZT_sgX^}$tas@R-mY$M>;yerG%=8r=Ekln5u(_t~zQ5tpdW+hz{C_X`i)9kY}f% zX3*+0PF8Sh2E(XoETzE?S?03L;-*SLuAC%rfFMm~Fl@Bb4!fW(0rl1;19CZ@tZ)+Ubwz3LESJru2*J z1Pm|At^^S?3T?O0*vr&B&(e!ZvZ9b$fsdXx{7|(Re_XJx2PbT;tGRe0CA7;rsEd>r z++1aoSK>o61|MVCbFs{Rj6fk-a-cJ_4i0_o3CgbQp$kz*Jv9kcV`9dNPU)5P)m7~X sc8y|>ox;~ - +

ucrec Member List

This is the complete list of members for ucrec, including all inherited members. @@ -13,7 +13,7 @@ -
ageclassbase
channelucrec
ucrec()ucrec [inline]
~classbase()classbase [inline]
~ucrec()ucrec [inline, virtual]

Generated on Fri May 13 15:49:58 2005 for InspIRCd by +
Generated on Sun May 15 17:03:47 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classucrec.html b/docs/module-doc/classucrec.html index 01f313584..cb42f131f 100644 --- a/docs/module-doc/classucrec.html +++ b/docs/module-doc/classucrec.html @@ -4,7 +4,7 @@ - +

ucrec Class Reference

Holds a user's modes on a channel This class associates a users privilages with a channel by creating a pointer link between a userrec and chanrec class. More...

@@ -134,7 +134,7 @@ If the record is not in use, this value will be NULL.

Definition at line 233 of file channels.h.

-Referenced by Server::PseudoToUser(), and userrec::userrec(). +Referenced by Server::PseudoToUser(), and userrec::userrec().

@@ -162,12 +162,12 @@ UCMODE_FOUNDER values. If this value is zero, the user has no privilages upon th

Definition at line 228 of file channels.h.

-Referenced by userrec::userrec(). +Referenced by userrec::userrec().


The documentation for this class was generated from the following file: -
Generated on Fri May 13 15:49:58 2005 for InspIRCd by +
Generated on Sun May 15 17:03:47 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classuserrec-members.html b/docs/module-doc/classuserrec-members.html index 9e20d561e..200def63f 100644 --- a/docs/module-doc/classuserrec-members.html +++ b/docs/module-doc/classuserrec-members.html @@ -4,7 +4,7 @@ - +

userrec Member List

This is the complete list of members for userrec, including all inherited members. @@ -35,6 +35,7 @@ + @@ -55,7 +56,7 @@ - + @@ -76,7 +77,7 @@ -
AddBuffer(std::string a)userrec
AddIncoming(int fd, char *targethost, int sourceport)connection
GetExt(std::string key)Extensible
GetFullHost()userrec [virtual]
GetFullRealHost()userrec [virtual]
GetInviteList()userrec
GetWriteError()userrec
haspassedconnection
HasPermission(char *command)userrec
passworduserrec
pingmaxuserrec
portconnection
RecvPacket(std::deque< std::string > &messages, char *host)connection
RecvPacket(std::deque< std::string > &messages, char *host, std::deque< std::string > &sums)connection
recvquserrec
recvqmaxuserrec
registeredconnection
WriteErroruserrec
~classbase()classbase [inline]
~userrec()userrec [inline, virtual]

Generated on Fri May 13 15:50:05 2005 for InspIRCd by +
Generated on Sun May 15 17:03:51 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/classuserrec.html b/docs/module-doc/classuserrec.html index 8e875c5b3..74ebbc256 100644 --- a/docs/module-doc/classuserrec.html +++ b/docs/module-doc/classuserrec.html @@ -4,7 +4,7 @@ - +

userrec Class Reference

Holds all information about a user This class stores all information about a user connected to the irc server. More...

@@ -70,6 +70,9 @@ Inheritance diagram for userrec:

void FlushWriteBuf ()  Flushes as much of the user's buffer to the file descriptor as possible.

+InvitedListGetInviteList () + + Returns the list of channels this user has been invited to but has not yet joined.



Public Attributes

char nick [NICKMAX] @@ -176,39 +179,39 @@ Definition at line 108 of f

-Definition at line 28 of file users.cpp. -

-References awaymsg, connection::bytes_in, connection::bytes_out, ucrec::channel, chans, connection::cmds_in, connection::cmds_out, dhost, dns_done, connection::fd, flood, fullname, connection::haspassed, connection::host, ident, connection::idle_lastmsg, invites, connection::ip, connection::lastping, lines_in, modes, nick, connection::nping, oper, connection::port, recvq, connection::registered, reset_due, result, sendq, server, connection::signon, TIME, timeout, and ucrec::uc_modes. -

-

00029 {
-00030         // the PROPER way to do it, AVOID bzero at *ALL* costs
-00031         strcpy(nick,"");
-00032         strcpy(ip,"127.0.0.1");
-00033         timeout = 0;
-00034         strcpy(ident,"");
-00035         strcpy(host,"");
-00036         strcpy(dhost,"");
-00037         strcpy(fullname,"");
-00038         strcpy(modes,"");
-00039         strcpy(server,"");
-00040         strcpy(awaymsg,"");
-00041         strcpy(oper,"");
-00042         reset_due = TIME;
-00043         lines_in = 0;
-00044         fd = lastping = signon = idle_lastmsg = nping = registered = 0;
-00045         flood = port = bytes_in = bytes_out = cmds_in = cmds_out = 0;
-00046         haspassed = false;
-00047         dns_done = false;
-00048         recvq = "";
-00049         sendq = "";
-00050         strcpy(result,"");
-00051         for (int i = 0; i < MAXCHANS; i++)
-00052         {
-00053                 this->chans[i].channel = NULL;
-00054                 this->chans[i].uc_modes = 0;
-00055         }
-00056         invites.clear();
-00057 }
+Definition at line 29 of file users.cpp.
+

+References awaymsg, connection::bytes_in, connection::bytes_out, ucrec::channel, chans, connection::cmds_in, connection::cmds_out, dhost, dns_done, connection::fd, flood, fullname, connection::haspassed, connection::host, ident, connection::idle_lastmsg, invites, connection::ip, connection::lastping, lines_in, modes, nick, connection::nping, oper, connection::port, recvq, connection::registered, reset_due, result, sendq, server, connection::signon, TIME, timeout, and ucrec::uc_modes. +

+

00030 {
+00031         // the PROPER way to do it, AVOID bzero at *ALL* costs
+00032         strcpy(nick,"");
+00033         strcpy(ip,"127.0.0.1");
+00034         timeout = 0;
+00035         strcpy(ident,"");
+00036         strcpy(host,"");
+00037         strcpy(dhost,"");
+00038         strcpy(fullname,"");
+00039         strcpy(modes,"");
+00040         strcpy(server,"");
+00041         strcpy(awaymsg,"");
+00042         strcpy(oper,"");
+00043         reset_due = TIME;
+00044         lines_in = 0;
+00045         fd = lastping = signon = idle_lastmsg = nping = registered = 0;
+00046         flood = port = bytes_in = bytes_out = cmds_in = cmds_out = 0;
+00047         haspassed = false;
+00048         dns_done = false;
+00049         recvq = "";
+00050         sendq = "";
+00051         strcpy(result,"");
+00052         for (int i = 0; i < MAXCHANS; i++)
+00053         {
+00054                 this->chans[i].channel = NULL;
+00055                 this->chans[i].uc_modes = 0;
+00056         }
+00057         invites.clear();
+00058 }
 
@@ -276,34 +279,34 @@ This method adds data to the buffer of the user.

The buffer can grow to any size within limits of the available memory, managed by the size of a std::string, however if any individual line in the buffer grows over 600 bytes in length (which is 88 chars over the RFC-specified limit per line) then the method will return false and the text will not be inserted.

-Definition at line 169 of file users.cpp. -

-References recvq, recvqmax, and SetWriteError(). -

-

00170 {
-00171         std::string b = "";
-00172         for (int i = 0; i < a.length(); i++)
-00173                 if ((a[i] != '\r') && (a[i] != '\0') && (a[i] != 7))
-00174                         b = b + a[i];
-00175         std::stringstream stream(recvq);
-00176         stream << b;
-00177         recvq = stream.str();
-00178         int i = 0;
-00179         // count the size of the first line in the buffer.
-00180         while (i < recvq.length())
-00181         {
-00182                 if (recvq[i++] == '\n')
-00183                         break;
-00184         }
-00185         if (recvq.length() > this->recvqmax)
-00186         {
-00187                 this->SetWriteError("RecvQ exceeded");
-00188                 WriteOpers("*** User %s RecvQ of %d exceeds connect class maximum of %d",this->nick,recvq.length(),this->recvqmax);
-00189         }
-00190         // return false if we've had more than 600 characters WITHOUT
-00191         // a carriage return (this is BAD, drop the socket)
-00192         return (i < 600);
-00193 }
+Definition at line 175 of file users.cpp.
+

+References recvq, recvqmax, and SetWriteError(). +

+

00176 {
+00177         std::string b = "";
+00178         for (int i = 0; i < a.length(); i++)
+00179                 if ((a[i] != '\r') && (a[i] != '\0') && (a[i] != 7))
+00180                         b = b + a[i];
+00181         std::stringstream stream(recvq);
+00182         stream << b;
+00183         recvq = stream.str();
+00184         int i = 0;
+00185         // count the size of the first line in the buffer.
+00186         while (i < recvq.length())
+00187         {
+00188                 if (recvq[i++] == '\n')
+00189                         break;
+00190         }
+00191         if (recvq.length() > this->recvqmax)
+00192         {
+00193                 this->SetWriteError("RecvQ exceeded");
+00194                 WriteOpers("*** User %s RecvQ of %d exceeds connect class maximum of %d",this->nick,recvq.length(),this->recvqmax);
+00195         }
+00196         // return false if we've had more than 600 characters WITHOUT
+00197         // a carriage return (this is BAD, drop the socket)
+00198         return (i < 600);
+00199 }
 
@@ -337,23 +340,23 @@ Adds to the user's write buffer.

You may add any amount of text up to this users sendq value, if you exceed the sendq value, SetWriteError() will be called to set the users error string to "SendQ exceeded", and further buffer adds will be dropped.

-Definition at line 225 of file users.cpp. -

-References GetWriteError(), sendq, sendqmax, and SetWriteError(). -

-

00226 {
-00227         if (this->GetWriteError() != "")
-00228                 return;
-00229         if (sendq.length() + data.length() > this->sendqmax)
-00230         {
-00231                 WriteOpers("*** User %s SendQ of %d exceeds connect class maximum of %d",this->nick,sendq.length() + data.length(),this->sendqmax);
-00232                 this->SetWriteError("SendQ exceeded");
-00233                 return;
-00234         }
-00235         std::stringstream stream;
-00236         stream << sendq << data;
-00237         sendq = stream.str();
-00238 }
+Definition at line 231 of file users.cpp.
+

+References GetWriteError(), sendq, sendqmax, and SetWriteError(). +

+

00232 {
+00233         if (this->GetWriteError() != "")
+00234                 return;
+00235         if (sendq.length() + data.length() > this->sendqmax)
+00236         {
+00237                 WriteOpers("*** User %s SendQ of %d exceeds connect class maximum of %d",this->nick,sendq.length() + data.length(),this->sendqmax);
+00238                 this->SetWriteError("SendQ exceeded");
+00239                 return;
+00240         }
+00241         std::stringstream stream;
+00242         stream << sendq << data;
+00243         sendq = stream.str();
+00244 }
 
@@ -386,16 +389,16 @@ This method returns true if the buffer contains at least one carriage return cha

one complete line may be read)

-Definition at line 195 of file users.cpp. +Definition at line 201 of file users.cpp.

References recvq.

-

00196 {
-00197         for (int i = 0; i < recvq.length(); i++)
-00198                 if (recvq[i] == '\n')
-00199                         return true;
-00200         return false;
-00201 }
+
00202 {
+00203         for (int i = 0; i < recvq.length(); i++)
+00204                 if (recvq[i] == '\n')
+00205                         return true;
+00206         return false;
+00207 }
 
@@ -428,15 +431,15 @@ This function clears the entire buffer by setting it to an empty string.

-Definition at line 203 of file users.cpp. +Definition at line 209 of file users.cpp.

References recvq.

-Referenced by Server::PseudoToUser(), and Server::UserToPseudo(). +Referenced by Server::PseudoToUser(), and Server::UserToPseudo().

-

00204 {
-00205         recvq = "";
-00206 }
+
00210 {
+00211         recvq = "";
+00212 }
 
@@ -469,30 +472,30 @@ Flushes as much of the user's buffer to the file descriptor as possible.

This function may not always flush the entire buffer, rather instead as much of it as it possibly can. If the send() call fails to send the entire buffer, the buffer position is advanced forwards and the rest of the data sent at the next call to this method.

-Definition at line 241 of file users.cpp. -

-References connection::bytes_out, connection::cmds_out, sendq, and SetWriteError(). -

-

00242 {
-00243         if (sendq.length())
-00244         {
-00245                 char* tb = (char*)this->sendq.c_str();
-00246                 int n_sent = write(this->fd,tb,this->sendq.length());
-00247                 if (n_sent == -1)
-00248                 {
-00249                         this->SetWriteError(strerror(errno));
-00250                 }
-00251                 else
-00252                 {
-00253                         // advance the queue
-00254                         tb += n_sent;
-00255                         this->sendq = tb;
-00256                         // update the user's stats counters
-00257                         this->bytes_out += n_sent;
-00258                         this->cmds_out++;
-00259                 }
-00260         }
-00261 }
+Definition at line 247 of file users.cpp.
+

+References connection::bytes_out, connection::cmds_out, sendq, and SetWriteError(). +

+

00248 {
+00249         if (sendq.length())
+00250         {
+00251                 char* tb = (char*)this->sendq.c_str();
+00252                 int n_sent = write(this->fd,tb,this->sendq.length());
+00253                 if (n_sent == -1)
+00254                 {
+00255                         this->SetWriteError(strerror(errno));
+00256                 }
+00257                 else
+00258                 {
+00259                         // advance the queue
+00260                         tb += n_sent;
+00261                         this->sendq = tb;
+00262                         // update the user's stats counters
+00263                         this->bytes_out += n_sent;
+00264                         this->cmds_out++;
+00265                 }
+00266         }
+00267 }
 
@@ -525,25 +528,25 @@ This method returns the first available string at the tail end of the buffer and

This means it is a one way operation in a similar way to strtok(), and multiple calls return multiple lines if they are available. The results of this function if there are no lines to be read are unknown, always use BufferIsReady() to check if it is ok to read the buffer before calling GetBuffer().

-Definition at line 208 of file users.cpp. +Definition at line 214 of file users.cpp.

References recvq.

-

00209 {
-00210         if (recvq == "")
-00211                 return "";
-00212         char* line = (char*)recvq.c_str();
-00213         std::string ret = "";
-00214         while ((*line != '\n') && (strlen(line)))
-00215         {
-00216                 ret = ret + *line;
-00217                 line++;
-00218         }
-00219         if ((*line == '\n') || (*line == '\r'))
-00220                 line++;
-00221         recvq = line;
-00222         return ret;
-00223 }
+
00215 {
+00216         if (recvq == "")
+00217                 return "";
+00218         char* line = (char*)recvq.c_str();
+00219         std::string ret = "";
+00220         while ((*line != '\n') && (strlen(line)))
+00221         {
+00222                 ret = ret + *line;
+00223                 line++;
+00224         }
+00225         if ((*line == '\n') || (*line == '\r'))
+00226                 line++;
+00227         recvq = line;
+00228         return ret;
+00229 }
 
@@ -576,14 +579,14 @@ Returns the full displayed host of the user This member function returns the hos

-Definition at line 61 of file users.cpp. +Definition at line 62 of file users.cpp.

References dhost, ident, nick, and result.

-

00062 {
-00063         snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,dhost);
-00064         return result;
-00065 }
+
00063 {
+00064         snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,dhost);
+00065         return result;
+00066 }
 
@@ -616,14 +619,53 @@ Returns the full real host of the user This member function returns the hostname

If any form of hostname cloaking is in operation, e.g. through a module, then this method will ignore it and return the true hostname.

-Definition at line 68 of file users.cpp. +Definition at line 69 of file users.cpp. +

+References connection::host, ident, nick, and result. +

+

00070 {
+00071         snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,host);
+00072         return result;
+00073 }
+
+ + +

+ + + + +
+ + + + + + + + + +
InvitedList * userrec::GetInviteList  ) 
+
+ + + +
+   + + +

+Returns the list of channels this user has been invited to but has not yet joined. +

+ +

+Definition at line 89 of file users.cpp.

-References connection::host, ident, nick, and result. +References InvitedList, and invites.

-

00069 {
-00070         snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,host);
-00071         return result;
-00072 }
+
00090 {
+00091         return &invites;
+00092 }
 
@@ -656,15 +698,15 @@ Returns the write error which last occured on this connection or an empty string

-Definition at line 271 of file users.cpp. +Definition at line 277 of file users.cpp.

References WriteError.

-Referenced by AddWriteBuf(). +Referenced by AddWriteBuf().

-

00272 {
-00273         return this->WriteError;
-00274 }
+
00278 {
+00279         return this->WriteError;
+00280 }
 
@@ -698,59 +740,59 @@ Returns true or false for if a user can execute a privilaged oper command.

This is done by looking up their oper type from userrec::oper, then referencing this to their oper classes and checking the commands they can execute.

-Definition at line 117 of file users.cpp. -

-References config_f, and DEBUG. -

-

00118 {
-00119         char TypeName[MAXBUF],Classes[MAXBUF],ClassName[MAXBUF],CommandList[MAXBUF];
-00120         char* mycmd;
-00121         char* savept;
-00122         char* savept2;
-00123         
-00124         // are they even an oper at all?
-00125         if (strchr(this->modes,'o'))
-00126         {
-00127                 log(DEBUG,"*** HasPermission: %s is an oper",this->nick);
-00128                 for (int j =0; j < ConfValueEnum("type",&config_f); j++)
-00129                 {
-00130                         ConfValue("type","name",j,TypeName,&config_f);
-00131                         if (!strcmp(TypeName,this->oper))
-00132                         {
-00133                                 log(DEBUG,"*** HasPermission: %s is an oper of type '%s'",this->nick,this->oper);
-00134                                 ConfValue("type","classes",j,Classes,&config_f);
-00135                                 char* myclass = strtok_r(Classes," ",&savept);
-00136                                 while (myclass)
-00137                                 {
-00138                                         log(DEBUG,"*** HasPermission: checking classtype '%s'",myclass);
-00139                                         for (int k =0; k < ConfValueEnum("class",&config_f); k++)
-00140                                         {
-00141                                                 ConfValue("class","name",k,ClassName,&config_f);
-00142                                                 if (!strcmp(ClassName,myclass))
-00143                                                 {
-00144                                                         ConfValue("class","commands",k,CommandList,&config_f);
-00145                                                         log(DEBUG,"*** HasPermission: found class named %s with commands: '%s'",ClassName,CommandList);
-00146                                                         
-00147                                                         
-00148                                                         mycmd = strtok_r(CommandList," ",&savept2);
-00149                                                         while (mycmd)
-00150                                                         {
-00151                                                                 if (!strcasecmp(mycmd,command))
-00152                                                                 {
-00153                                                                         log(DEBUG,"*** Command %s found, returning true",command);
-00154                                                                         return true;
-00155                                                                 }
-00156                                                                 mycmd = strtok_r(NULL," ",&savept2);
-00157                                                         }
-00158                                                 }
-00159                                         }
-00160                                         myclass = strtok_r(NULL," ",&savept);
-00161                                 }
-00162                         }
-00163                 }
-00164         }
-00165         return false;
-00166 }
+Definition at line 123 of file users.cpp.
+

+References config_f, and DEBUG. +

+

00124 {
+00125         char TypeName[MAXBUF],Classes[MAXBUF],ClassName[MAXBUF],CommandList[MAXBUF];
+00126         char* mycmd;
+00127         char* savept;
+00128         char* savept2;
+00129         
+00130         // are they even an oper at all?
+00131         if (strchr(this->modes,'o'))
+00132         {
+00133                 log(DEBUG,"*** HasPermission: %s is an oper",this->nick);
+00134                 for (int j =0; j < ConfValueEnum("type",&config_f); j++)
+00135                 {
+00136                         ConfValue("type","name",j,TypeName,&config_f);
+00137                         if (!strcmp(TypeName,this->oper))
+00138                         {
+00139                                 log(DEBUG,"*** HasPermission: %s is an oper of type '%s'",this->nick,this->oper);
+00140                                 ConfValue("type","classes",j,Classes,&config_f);
+00141                                 char* myclass = strtok_r(Classes," ",&savept);
+00142                                 while (myclass)
+00143                                 {
+00144                                         log(DEBUG,"*** HasPermission: checking classtype '%s'",myclass);
+00145                                         for (int k =0; k < ConfValueEnum("class",&config_f); k++)
+00146                                         {
+00147                                                 ConfValue("class","name",k,ClassName,&config_f);
+00148                                                 if (!strcmp(ClassName,myclass))
+00149                                                 {
+00150                                                         ConfValue("class","commands",k,CommandList,&config_f);
+00151                                                         log(DEBUG,"*** HasPermission: found class named %s with commands: '%s'",ClassName,CommandList);
+00152                                                         
+00153                                                         
+00154                                                         mycmd = strtok_r(CommandList," ",&savept2);
+00155                                                         while (mycmd)
+00156                                                         {
+00157                                                                 if (!strcasecmp(mycmd,command))
+00158                                                                 {
+00159                                                                         log(DEBUG,"*** Command %s found, returning true",command);
+00160                                                                         return true;
+00161                                                                 }
+00162                                                                 mycmd = strtok_r(NULL," ",&savept2);
+00163                                                         }
+00164                                                 }
+00165                                         }
+00166                                         myclass = strtok_r(NULL," ",&savept);
+00167                                 }
+00168                         }
+00169                 }
+00170         }
+00171         return false;
+00172 }
 
@@ -784,15 +826,15 @@ Adds a channel to a users invite list (invites them to a channel).

-Definition at line 88 of file users.cpp. +Definition at line 94 of file users.cpp.

References Invited::channel, and invites.

-

00089 {
-00090         Invited i;
-00091         strlcpy(i.channel,channel,CHANMAX);
-00092         invites.push_back(i);
-00093 }
+
00095 {
+00096         Invited i;
+00097         strlcpy(i.channel,channel,CHANMAX);
+00098         invites.push_back(i);
+00099 }
 
@@ -826,22 +868,22 @@ Returns true if a user is invited to a channel.

-Definition at line 74 of file users.cpp. +Definition at line 75 of file users.cpp.

References invites.

-

00075 {
-00076         for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++)
-00077         {
-00078                 if (i->channel) {
-00079                         if (!strcasecmp(i->channel,channel))
-00080                         {
-00081                                 return true;
-00082                         }
-00083                 }
-00084         }
-00085         return false;
-00086 }
+
00076 {
+00077         for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++)
+00078         {
+00079                 if (i->channel) {
+00080                         if (!strcasecmp(i->channel,channel))
+00081                         {
+00082                                 return true;
+00083                         }
+00084                 }
+00085         }
+00086         return false;
+00087 }
 
@@ -875,30 +917,30 @@ Removes a channel from a users invite list.

This member function is called on successfully joining an invite only channel to which the user has previously been invited, to clear the invitation.

-Definition at line 95 of file users.cpp. +Definition at line 101 of file users.cpp.

References DEBUG, and invites.

-

00096 {
-00097         log(DEBUG,"Removing invites");
-00098         if (channel)
-00099         {
-00100                 if (invites.size())
-00101                 {
-00102                         for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++)
-00103                         {
-00104                                 if (i->channel)
-00105                                 {
-00106                                         if (!strcasecmp(i->channel,channel))
-00107                                         {
-00108                                                 invites.erase(i);
-00109                                                 return;
-00110                                         }
-00111                                 }
-00112                         }
-00113                 }
-00114         }
-00115 }
+
00102 {
+00103         log(DEBUG,"Removing invites");
+00104         if (channel)
+00105         {
+00106                 if (invites.size())
+00107                 {
+00108                         for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++)
+00109                         {
+00110                                 if (i->channel)
+00111                                 {
+00112                                         if (!strcasecmp(i->channel,channel))
+00113                                         {
+00114                                                 invites.erase(i);
+00115                                                 return;
+00116                                         }
+00117                                 }
+00118                         }
+00119                 }
+00120         }
+00121 }
 
@@ -932,18 +974,18 @@ Sets the write error for a connection.

This is done because the actual disconnect of a client may occur at an inopportune time such as half way through /LIST output. The WriteErrors of clients are checked at a more ideal time (in the mainloop) and errored clients purged.

-Definition at line 263 of file users.cpp. +Definition at line 269 of file users.cpp.

References DEBUG, and WriteError.

-Referenced by AddBuffer(), AddWriteBuf(), and FlushWriteBuf(). +Referenced by AddBuffer(), AddWriteBuf(), and FlushWriteBuf().

-

00264 {
-00265         log(DEBUG,"Setting error string for %s to '%s'",this->nick,error.c_str());
-00266         // don't try to set the error twice, its already set take the first string.
-00267         if (this->WriteError == "")
-00268                 this->WriteError = error;
-00269 }
+
00270 {
+00271         log(DEBUG,"Setting error string for %s to '%s'",this->nick,error.c_str());
+00272         // don't try to set the error twice, its already set take the first string.
+00273         if (this->WriteError == "")
+00274                 this->WriteError = error;
+00275 }
 
@@ -973,7 +1015,7 @@ If this string is empty, the user is not marked as away.

Definition at line 151 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -999,7 +1041,7 @@ Referenced by userrec().

Definition at line 142 of file users.h.

-Referenced by Server::PseudoToUser(), and userrec(). +Referenced by Server::PseudoToUser(), and userrec().

@@ -1027,7 +1069,7 @@ This usually matches the value of u

Definition at line 130 of file users.h.

-Referenced by GetFullHost(), and userrec(). +Referenced by GetFullHost(), and userrec().

@@ -1055,7 +1097,7 @@ True when DNS lookups are completed.

Definition at line 179 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1083,7 +1125,7 @@ Number of lines the user can place into the buffer (up to the global NetBufferSi

Definition at line 162 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1111,7 +1153,7 @@ The users full name.

Definition at line 134 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1139,7 +1181,7 @@ The users ident reply.

Definition at line 125 of file users.h.

-Referenced by GetFullHost(), GetFullRealHost(), Server::PseudoToUser(), userrec(), and Server::UserToPseudo(). +Referenced by GetFullHost(), GetFullRealHost(), Server::PseudoToUser(), userrec(), and Server::UserToPseudo().

@@ -1167,7 +1209,7 @@ A list of channels the user has a pending invite to.

Definition at line 114 of file users.h.

-Referenced by InviteTo(), IsInvited(), RemoveInvite(), and userrec(). +Referenced by GetInviteList(), InviteTo(), IsInvited(), RemoveInvite(), and userrec().

@@ -1195,7 +1237,7 @@ Flood counters.

Definition at line 204 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1223,7 +1265,7 @@ This may contain any of the following RFC characters: o, w, s, i Your module may

Definition at line 140 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1251,7 +1293,7 @@ An invalid nickname indicates an unregistered connection prior to the NICK comma

Definition at line 121 of file users.h.

-Referenced by ConfigReader::DumpErrors(), GetFullHost(), GetFullRealHost(), Server::PseudoToUser(), and userrec(). +Referenced by ConfigReader::DumpErrors(), GetFullHost(), GetFullRealHost(), Server::PseudoToUser(), and userrec().

@@ -1279,7 +1321,7 @@ This is used to check permissions in operclasses, so that we can say 'yay' or 'n

Definition at line 175 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1359,7 +1401,7 @@ Lines from the IRCd awaiting processing are stored here. Upgraded april 2005, ol

Definition at line 195 of file users.h.

-Referenced by AddBuffer(), BufferIsReady(), ClearBuffer(), GetBuffer(), and userrec(). +Referenced by AddBuffer(), BufferIsReady(), ClearBuffer(), GetBuffer(), and userrec().

@@ -1387,7 +1429,7 @@ Maximum size this user's recvq can become.

Definition at line 218 of file users.h.

-Referenced by AddBuffer(). +Referenced by AddBuffer().

@@ -1413,7 +1455,7 @@ Referenced by AddBuffer()

Definition at line 205 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1441,7 +1483,7 @@ You may use this to increase the speed of use of this class.

Definition at line 156 of file users.h.

-Referenced by GetFullHost(), GetFullRealHost(), and userrec(). +Referenced by GetFullHost(), GetFullRealHost(), and userrec().

@@ -1469,7 +1511,7 @@ Lines waiting to be sent are stored here until their buffer is flushed.

Definition at line 200 of file users.h.

-Referenced by AddWriteBuf(), FlushWriteBuf(), and userrec(). +Referenced by AddWriteBuf(), FlushWriteBuf(), and userrec().

@@ -1497,7 +1539,7 @@ Maximum size this user's sendq can become.

Definition at line 214 of file users.h.

-Referenced by AddWriteBuf(). +Referenced by AddWriteBuf().

@@ -1525,7 +1567,7 @@ The server the user is connected to.

Definition at line 146 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1577,7 +1619,7 @@ Number of seconds this user is given to send USER/NICK If they do not send their

Definition at line 168 of file users.h.

-Referenced by userrec(). +Referenced by userrec().

@@ -1603,12 +1645,12 @@ Referenced by userrec().

Definition at line 210 of file users.h.

-Referenced by GetWriteError(), and SetWriteError(). +Referenced by GetWriteError(), and SetWriteError().


The documentation for this class was generated from the following files: -
Generated on Fri May 13 15:50:05 2005 for InspIRCd by +
Generated on Sun May 15 17:03:51 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/commands_8h-source.html b/docs/module-doc/commands_8h-source.html index 7ccf10133..ff5528155 100644 --- a/docs/module-doc/commands_8h-source.html +++ b/docs/module-doc/commands_8h-source.html @@ -4,7 +4,7 @@ - +

commands.h

Go to the documentation of this file.
00001 /*       +------------------------------------+
 00002  *       | Inspire Internet Relay Chat Daemon |
 00003  *       +------------------------------------+
@@ -87,38 +87,38 @@
 00082 void handle_loadmodule(char **parameters, int pcnt, userrec *user);
 00083 void handle_unloadmodule(char **parameters, int pcnt, userrec *user);
 00084 
-00087 void handle_link_packet(char* tcp_msg, char* tcp_host, serverrec *serv);
-00088 void process_restricted_commands(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host,char* ipaddr,int port);
+00087 void handle_link_packet(char* tcp_msg, char* tcp_host, serverrec *serv, char* tcp_sum);
+00088 void process_restricted_commands(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host,char* ipaddr,int port, char* tcp_sum);
 00089 
-00092 void handle_amp(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00093 void handle_dollar(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00094 void handle_J(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00095 void handle_R(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00096 void handle_plus(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00097 void handle_b(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00098 void handle_a(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00099 void handle_F(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00100 void handle_N(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00101 void handle_AT(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00102 void handle_k(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00103 void handle_n(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00104 void handle_Q(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00105 void handle_K(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00106 void handle_L(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00107 void handle_m(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00108 void handle_M(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00109 void handle_T(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00110 void handle_t(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00111 void handle_i(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00112 void handle_P(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
-00113 void handle_V(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host);
+00092 void handle_amp(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00093 void handle_dollar(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00094 void handle_J(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00095 void handle_R(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00096 void handle_plus(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00097 void handle_b(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00098 void handle_a(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00099 void handle_F(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00100 void handle_N(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00101 void handle_AT(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00102 void handle_k(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00103 void handle_n(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00104 void handle_Q(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00105 void handle_K(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00106 void handle_L(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00107 void handle_m(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00108 void handle_M(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00109 void handle_T(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00110 void handle_t(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00111 void handle_i(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00112 void handle_P(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
+00113 void handle_V(char token,char* params,serverrec* source,serverrec* reply, char* tcp_host, char* tcp_sum);
 00114 
 00117 bool is_uline(const char* server);
 00118 
 00121 long duration(const char* str);
 00122 
 00123 #endif
-

Generated on Fri May 13 15:48:40 2005 for InspIRCd by +

Generated on Sun May 15 17:02:05 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/commands_8h.html b/docs/module-doc/commands_8h.html index 90380939e..cc7600fdf 100644 --- a/docs/module-doc/commands_8h.html +++ b/docs/module-doc/commands_8h.html @@ -4,7 +4,7 @@ - +

commands.h File Reference

#include <typeinfo>
#include <iostream>
#include <string>
@@ -132,55 +132,55 @@ This graph shows which files directly or indirectly include this file:

void handle_unloadmodule (char **parameters, int pcnt, userrec *user) -void handle_link_packet (char *tcp_msg, char *tcp_host, serverrec *serv) +void handle_link_packet (char *tcp_msg, char *tcp_host, serverrec *serv, char *tcp_sum)  Special functions for processing server to server traffic.

-void process_restricted_commands (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *ipaddr, int port) +void process_restricted_commands (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *ipaddr, int port, char *tcp_sum) -void handle_amp (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_amp (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum)  These are the handlers for server commands (tokens).


-void handle_dollar (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_dollar (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_J (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_J (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_R (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_R (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_plus (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_plus (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_b (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_b (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_a (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_a (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_F (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_F (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_N (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_N (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_AT (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_AT (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_k (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_k (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_n (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_n (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_Q (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_Q (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_K (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_K (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_L (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_L (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_m (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_m (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_M (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_M (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_T (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_T (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_t (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_t (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_i (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_i (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_P (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_P (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) -void handle_V (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host) +void handle_V (char token, char *params, serverrec *source, serverrec *reply, char *tcp_host, char *tcp_sum) bool is_uline (const char *server) @@ -220,7 +220,7 @@ Other useful functions.

-Referenced by Server::AddELine(), Server::AddGLine(), Server::AddKLine(), Server::AddQLine(), Server::AddZLine(), and Server::CalcDuration(). +Referenced by Server::AddELine(), Server::AddGLine(), Server::AddKLine(), Server::AddQLine(), Server::AddZLine(), and Server::CalcDuration().

@@ -256,7 +256,13 @@ Referenced by Server::AddEL char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -356,7 +362,13 @@ Referenced by Server::AddEL char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -414,7 +426,13 @@ These are the handlers for server commands (tokens). char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -514,7 +532,13 @@ These are the handlers for server commands (tokens). char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -658,7 +682,13 @@ These are the handlers for server commands (tokens). char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -758,7 +788,13 @@ These are the handlers for server commands (tokens). char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -858,7 +894,13 @@ These are the handlers for server commands (tokens). char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -1046,7 +1088,13 @@ These are the handlers for server commands (tokens). char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -1148,7 +1196,13 @@ These are the handlers for user commands. char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -1204,7 +1258,13 @@ These are the handlers for user commands. char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -1392,7 +1452,13 @@ These are the handlers for user commands. char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -1436,7 +1502,13 @@ These are the handlers for user commands. serverrec *  - serv + serv, + + + + + char *  + tcp_sum @@ -1670,7 +1742,13 @@ Special functions for processing server to server traffic. char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -1726,7 +1804,13 @@ Special functions for processing server to server traffic. char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -1914,7 +1998,13 @@ Special functions for processing server to server traffic. char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -1970,7 +2060,13 @@ Special functions for processing server to server traffic. char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -2202,7 +2298,13 @@ Special functions for processing server to server traffic. char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -2390,7 +2492,13 @@ Special functions for processing server to server traffic. char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -2534,7 +2642,13 @@ Special functions for processing server to server traffic. char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -2678,7 +2792,13 @@ Special functions for processing server to server traffic. char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -3042,7 +3162,13 @@ Special functions for processing server to server traffic. char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -3098,7 +3224,13 @@ Special functions for processing server to server traffic. char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -3462,7 +3594,13 @@ Special functions for processing server to server traffic. char *  - tcp_host + tcp_host, + + + + + char *  + tcp_sum @@ -3735,7 +3873,7 @@ Functions for u:lined servers.

-Referenced by Server::IsUlined(). +Referenced by Server::IsUlined().

@@ -3783,7 +3921,13 @@ Referenced by Server::IsUli int  - port + port, + + + + + char *  + tcp_sum @@ -3806,7 +3950,7 @@ Referenced by Server::IsUli -


Generated on Fri May 13 15:48:54 2005 for InspIRCd by +
Generated on Sun May 15 17:02:22 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/connection_8h-source.html b/docs/module-doc/connection_8h-source.html index a808f43f7..e56f1b61b 100644 --- a/docs/module-doc/connection_8h-source.html +++ b/docs/module-doc/connection_8h-source.html @@ -4,7 +4,7 @@ - +

connection.h

Go to the documentation of this file.
00001 /*       +------------------------------------+
 00002  *       | Inspire Internet Relay Chat Daemon |
 00003  *       +------------------------------------+
@@ -46,133 +46,135 @@
 00039 #define STATE_NOAUTH_OUTBOUND   4
 00040 #define STATE_SERVICES          5
 00041 
-00054 class ircd_connector : public Extensible
-00055 {
-00056  private:
-00059         sockaddr_in addr;
-00060         
-00063         int fd;
-00064         
-00067         std::string servername;
-00068         
-00071         std::string description;
-00072         
-00076         char state;
-00077         
-00080         bool SetHostAddress(char* host, int port);
-00081 
-00084         std::string version;
-00085 
-00086  public:
+00042 std::string CreateSum();
+00043 
+00056 class ircd_connector : public Extensible
+00057 {
+00058  private:
+00061         sockaddr_in addr;
+00062         
+00065         int fd;
+00066         
+00069         std::string servername;
+00070         
+00073         std::string description;
+00074         
+00078         char state;
+00079         
+00082         bool SetHostAddress(char* host, int port);
+00083 
+00086         std::string version;
 00087 
-00092         std::string ircdbuffer;
-00093 
-00094  
-00099         char host[MAXBUF];
-00100 
-00105         int port;
-00106         
-00111         std::vector<std::string> routes;
-00112         
-00113 
-00116         bool MakeOutboundConnection(char* newhost, int newport);
-00117         
-00120         std::string GetServerName();
-00121         
-00124         void SetServerName(std::string serv);
-00125         
-00128         int GetDescriptor();
-00129         
-00132         void SetDescriptor(int fd);
-00133         
-00136         int GetState();
-00137         
-00140         void SetState(int state);
-00141         
-00144         char* GetServerIP();
-00145         
-00148         std::string GetDescription();
-00149         
-00152         void SetDescription(std::string desc);
-00153         
-00159         int GetServerPort();
-00160         
-00163         void SetServerPort(int p);
-00164         
-00167         bool SetHostAndPort(char* newhost, int newport);
-00168         
-00172         void CloseConnection();
-00173 
-00179         void AddBuffer(std::string a);
-00180 
-00185         bool BufferIsComplete();
-00186 
-00189         void ClearBuffer();
-00190 
-00195         std::string GetBuffer();
-00196 
-00199         void SetVersionString(std::string newversion);
-00200 
-00204         std::string GetVersionString();
-00205 };
-00206 
-00207 
-00210 class connection : public Extensible
-00211 {
-00212  public:
-00215         int fd;
-00216         
-00219         char host[160];
-00220         
-00223         char ip[16];
-00224         
-00227         long bytes_in;
-00228 
-00231         long bytes_out;
-00232 
-00235         long cmds_in;
-00236 
-00239         long cmds_out;
-00240 
-00243         bool haspassed;
-00244 
-00249         int port;
-00250         
-00253         char registered;
-00254         
-00257         time_t lastping;
-00258         
-00261         time_t signon;
-00262         
-00265         time_t idle_lastmsg;
-00266         
-00269         time_t nping;
-00270         
-00274         std::vector<ircd_connector> connectors;
-00275         
-00278         connection();
-00279         
-00282         bool CreateListener(char* host, int p);
-00283         
-00286         bool BeginLink(char* targethost, int port, char* password, char* servername, int myport);
-00287         
-00290         bool MeshCookie(char* targethost, int port, unsigned long cookie, char* servername);
-00291         
-00294         void TerminateLink(char* targethost);
-00295         
-00299         bool SendPacket(char *message, const char* host);
-00300         
-00305         bool RecvPacket(std::deque<std::string> &messages, char* host);
-00306         
-00309         ircd_connector* FindHost(std::string host);
-00310         
-00314         bool AddIncoming(int fd,char* targethost, int sourceport);
-00315         
-00316 };
-00317 
-00318 
-00319 #endif
-

Generated on Fri May 13 15:48:41 2005 for InspIRCd by +00088 public: +00089 +00094 std::string ircdbuffer; +00095 +00096 +00101 char host[MAXBUF]; +00102 +00107 int port; +00108 +00113 std::vector<std::string> routes; +00114 +00115 +00118 bool MakeOutboundConnection(char* newhost, int newport); +00119 +00122 std::string GetServerName(); +00123 +00126 void SetServerName(std::string serv); +00127 +00130 int GetDescriptor(); +00131 +00134 void SetDescriptor(int fd); +00135 +00138 int GetState(); +00139 +00142 void SetState(int state); +00143 +00146 char* GetServerIP(); +00147 +00150 std::string GetDescription(); +00151 +00154 void SetDescription(std::string desc); +00155 +00161 int GetServerPort(); +00162 +00165 void SetServerPort(int p); +00166 +00169 bool SetHostAndPort(char* newhost, int newport); +00170 +00174 void CloseConnection(); +00175 +00181 void AddBuffer(std::string a); +00182 +00187 bool BufferIsComplete(); +00188 +00191 void ClearBuffer(); +00192 +00197 std::string GetBuffer(); +00198 +00201 void SetVersionString(std::string newversion); +00202 +00206 std::string GetVersionString(); +00207 }; +00208 +00209 +00212 class connection : public Extensible +00213 { +00214 public: +00217 int fd; +00218 +00221 char host[160]; +00222 +00225 char ip[16]; +00226 +00229 long bytes_in; +00230 +00233 long bytes_out; +00234 +00237 long cmds_in; +00238 +00241 long cmds_out; +00242 +00245 bool haspassed; +00246 +00251 int port; +00252 +00255 char registered; +00256 +00259 time_t lastping; +00260 +00263 time_t signon; +00264 +00267 time_t idle_lastmsg; +00268 +00271 time_t nping; +00272 +00276 std::vector<ircd_connector> connectors; +00277 +00280 connection(); +00281 +00284 bool CreateListener(char* host, int p); +00285 +00288 bool BeginLink(char* targethost, int port, char* password, char* servername, int myport); +00289 +00292 bool MeshCookie(char* targethost, int port, unsigned long cookie, char* servername); +00293 +00296 void TerminateLink(char* targethost); +00297 +00301 bool SendPacket(char *message, const char* host); +00302 +00307 bool RecvPacket(std::deque<std::string> &messages, char* host, std::deque<std::string> &sums); +00308 +00311 ircd_connector* FindHost(std::string host); +00312 +00316 bool AddIncoming(int fd,char* targethost, int sourceport); +00317 +00318 }; +00319 +00320 +00321 #endif +

Generated on Sun May 15 17:02:05 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/connection_8h.html b/docs/module-doc/connection_8h.html index d5d15482d..cfe88c4d2 100644 --- a/docs/module-doc/connection_8h.html +++ b/docs/module-doc/connection_8h.html @@ -4,7 +4,7 @@ - +

connection.h File Reference

#include "inspircd_config.h"
#include "base.h"
#include <string>
@@ -58,6 +58,9 @@ This graph shows which files directly or indirectly include this file:

#define STATE_SERVICES   5 +

Functions

+std::string CreateSum () +

Define Documentation

@@ -204,7 +207,36 @@ Definition at line 40 Definition at line 37 of file connection.h. -


Generated on Fri May 13 15:48:56 2005 for InspIRCd by +

Function Documentation

+

+ + + + +
+ + + + + + + + + +
std::string CreateSum  ) 
+
+ + + + + +
+   + + +

+

+


Generated on Sun May 15 17:02:25 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/ctables_8h-source.html b/docs/module-doc/ctables_8h-source.html index 11bbda8b7..81613b796 100644 --- a/docs/module-doc/ctables_8h-source.html +++ b/docs/module-doc/ctables_8h-source.html @@ -4,7 +4,7 @@ - +

ctables.h

Go to the documentation of this file.
00001 /*       +------------------------------------+
 00002  *       | Inspire Internet Relay Chat Daemon |
 00003  *       +------------------------------------+
@@ -42,7 +42,7 @@
 00051 
 00052 #endif
 00053 
-

Generated on Fri May 13 15:48:41 2005 for InspIRCd by +

Generated on Sun May 15 17:02:05 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/ctables_8h.html b/docs/module-doc/ctables_8h.html index aec2689e8..23bda01ee 100644 --- a/docs/module-doc/ctables_8h.html +++ b/docs/module-doc/ctables_8h.html @@ -4,7 +4,7 @@ - +

ctables.h File Reference

#include "inspircd_config.h"
#include "inspircd.h"
#include "base.h"
@@ -31,7 +31,7 @@ This graph shows which files directly or indirectly include this file:

 A structure that defines a command. More...

-
Generated on Fri May 13 15:48:57 2005 for InspIRCd by +
Generated on Sun May 15 17:02:26 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/dns_8h-source.html b/docs/module-doc/dns_8h-source.html index 6089e9f1e..a572e51d4 100644 --- a/docs/module-doc/dns_8h-source.html +++ b/docs/module-doc/dns_8h-source.html @@ -4,7 +4,7 @@ - +

dns.h

Go to the documentation of this file.
00001 /*
 00002 dns.h - dns library declarations based on firedns Copyright (C) 2002 Ian Gulliver
 00003 
@@ -70,7 +70,7 @@
 00093 };
 00094 
 00095 #endif
-

Generated on Fri May 13 15:48:41 2005 for InspIRCd by +

Generated on Sun May 15 17:02:05 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/dns_8h.html b/docs/module-doc/dns_8h.html index a3b2a8eb6..08c0757ca 100644 --- a/docs/module-doc/dns_8h.html +++ b/docs/module-doc/dns_8h.html @@ -4,7 +4,7 @@ - +

dns.h File Reference

#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
@@ -23,7 +23,7 @@ Include dependency graph for dns.h:

struct  dns_ip4list -
Generated on Fri May 13 15:48:58 2005 for InspIRCd by +
Generated on Sun May 15 17:02:27 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/files.html b/docs/module-doc/files.html index 90f37662f..4cde2d477 100644 --- a/docs/module-doc/files.html +++ b/docs/module-doc/files.html @@ -4,7 +4,7 @@ - +

InspIRCd File List

Here is a list of all files with brief descriptions: @@ -13,6 +13,7 @@ + @@ -23,7 +24,7 @@
base.h [code]
channels.cpp [code]
connection.h [code]
ctables.h [code]
dns.h [code]
hashcomp.h [code]
message.h [code]
mode.h [code]
modules.cpp [code]
users.h [code]
xline.h [code]
-
Generated on Fri May 13 15:48:40 2005 for InspIRCd by +
Generated on Sun May 15 17:02:04 2005 for InspIRCd by doxygen 1.3.3
diff --git a/docs/module-doc/functions.html b/docs/module-doc/functions.html index 7adda59a1..2199f5c4f 100644 --- a/docs/module-doc/functions.html +++ b/docs/module-doc/functions.html @@ -4,7 +4,7 @@ - +
a | b | c | d | e | f | g | h | i | j | k | l | m | n | o | p | q | r | s | t | u | v | w | ~
@@ -15,18 +15,18 @@ Here is a list of all class members with links to the classes they belong to:

@@ -46,11 +46,11 @@ Here is a list of all class members with links to the classes they belong to:

- j -

- k -

    @@ -209,21 +214,22 @@ Here is a list of all class members with links to the classes they belong to:

    userrec
  • list : ExtMode
  • LoadFile() : FileReader
  • Log() -: Server
+: Server
  • lt() +: irc::irc_char_traits

    - m -

    +: Server

    - q -

    +: Server

    - r -

    +: Server

    - v -

    +: ConfigReader
  • version +: serverrec, ircd_connector
  • Version() +: Version

    - w -

    • WriteError @@ -426,7 +433,7 @@ Here is a list of all class members with links to the classes they belong to:

      serverrec
    • ~ucrec() : ucrec
    • ~userrec() : userrec
    -
    Generated on Fri May 13 15:49:18 2005 for InspIRCd by +
    Generated on Sun May 15 17:02:54 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/functions_func.html b/docs/module-doc/functions_func.html index c900b096c..7c5c98f9d 100644 --- a/docs/module-doc/functions_func.html +++ b/docs/module-doc/functions_func.html @@ -4,9 +4,9 @@ - + -
    a | b | c | d | e | f | g | h | i | j | l | m | o | p | q | r | s | t | u | v | ~
    +
    a | b | c | d | e | f | g | h | i | j | l | m | n | o | p | q | r | s | t | u | v | ~

    @@ -15,17 +15,17 @@

    - b -

    - m -

    +

    - n - +

    - o -

    - q -

    +: Server

    - r -

    +: Server

    - v -

    -
    Generated on Fri May 13 15:49:18 2005 for InspIRCd by +
    Generated on Sun May 15 17:02:54 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/functions_vars.html b/docs/module-doc/functions_vars.html index 5e1bc5103..51f896dd8 100644 --- a/docs/module-doc/functions_vars.html +++ b/docs/module-doc/functions_vars.html @@ -4,7 +4,7 @@ - +
    a | b | c | d | e | f | h | i | j | k | l | m | n | o | p | r | s | t | u | v | w
    @@ -187,7 +187,7 @@ -
    Generated on Fri May 13 15:49:18 2005 for InspIRCd by +
    Generated on Sun May 15 17:02:54 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/globals.html b/docs/module-doc/globals.html index d70ea24d2..9bc221055 100644 --- a/docs/module-doc/globals.html +++ b/docs/module-doc/globals.html @@ -4,7 +4,7 @@ - +
    a | b | c | d | e | f | g | h | i | l | m | n | p | q | r | s | t | u | v | w | z
    @@ -32,85 +32,86 @@ Here is a list of all file members with links to the files they belong to:

    xline.h
  • add_qline() : xline.h
  • add_zline() : xline.h
  • address_cache -: modules.cpp
  • AdminEmail -: modules.cpp, channels.cpp
  • AdminName -: modules.cpp, channels.cpp
  • AdminNick -: modules.cpp, channels.cpp
  • allowed_umode() +: modules.cpp
  • AdminEmail +: modules.cpp, channels.cpp
  • AdminName +: modules.cpp, channels.cpp
  • AdminNick +: modules.cpp, channels.cpp
  • allowed_umode() : mode.h
  • apply_lines() : xline.h
  • auth_cookies -: modules.cpp, channels.cpp +: modules.cpp, channels.cpp

    - b -

    +: modules.cpp, channels.cpp

    - c -

    - d -

    - e -

    +: modules.cpp
  • ExtModeListIter +: modules.cpp

    - f -

    @@ -182,9 +183,9 @@ Here is a list of all file members with links to the files they belong to:

    commands.h
  • handle_squit() : commands.h
  • handle_stats() : commands.h
  • handle_summon() -: commands.h
  • handle_t() -: commands.h
  • handle_T() -: commands.h
  • handle_time() +: commands.h
  • handle_T() +: commands.h
  • handle_t() +: commands.h
  • handle_time() : commands.h
  • handle_topic() : commands.h
  • handle_trace() : commands.h
  • handle_unloadmodule() @@ -205,7 +206,7 @@ Here is a list of all file members with links to the files they belong to:

    InvitedList : users.h
  • InviteList : channels.h
  • IP -: modules.cpp
  • ircd_module +: modules.cpp
  • ircd_module : modules.h
  • is_uline() : commands.h
  • isident() : message.h
  • isnick() @@ -215,9 +216,9 @@ Here is a list of all file members with links to the files they belong to:

    LINK_ACTIVE : servers.h
  • LINK_INACTIVE : servers.h
  • list -: modules.cpp, channels.cpp
  • log_file -: modules.cpp, channels.cpp
  • LogLevel -: modules.cpp, channels.cpp +: modules.cpp, channels.cpp
  • log_file +: modules.cpp, channels.cpp
  • LogLevel +: modules.cpp, channels.cpp

    - m -

    - n -

    +: hashcomp.h, channels.cpp

    - p -

    @@ -271,20 +272,20 @@ Here is a list of all file members with links to the files they belong to:

    +: modules.cpp, channels.cpp
  • rules +: modules.cpp, channels.cpp
  • RULES +: modules.cpp

    - s -

    +: users.cpp, servers.cpp, modules.cpp, channels.cpp

    - u -

    +: modules.cpp

    - v -

    - z -

    -
    Generated on Fri May 13 15:50:10 2005 for InspIRCd by +
    Generated on Sun May 15 17:03:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/globals_defs.html b/docs/module-doc/globals_defs.html index 855ebc923..ea7ddb035 100644 --- a/docs/module-doc/globals_defs.html +++ b/docs/module-doc/globals_defs.html @@ -4,7 +4,7 @@ - +
    a | c | d | f | l | m | n | s | u | v
    @@ -67,7 +67,7 @@
  • +: hashcomp.h, channels.cpp

    - s -

    -
    Generated on Fri May 13 15:50:10 2005 for InspIRCd by +
    Generated on Sun May 15 17:03:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/globals_func.html b/docs/module-doc/globals_func.html index 7c41a5414..dcde05ba6 100644 --- a/docs/module-doc/globals_func.html +++ b/docs/module-doc/globals_func.html @@ -4,7 +4,7 @@ - +
    a | b | c | d | e | f | g | h | i | m | n | p | q | r | s | t | z
    @@ -37,7 +37,8 @@ : message.h
  • cmode() : message.h
  • common_channels() : message.h
  • createcommand() -: modules.h
  • cstatus() +: modules.h
  • CreateSum() +: connection.h
  • cstatus() : message.h

    - d -

    - e -

    - g -

    +: modules.cpp
  • ModeDefinedOff() +: modules.cpp
  • ModeDefinedOn() +: modules.cpp
  • ModeDefinedOper() +: modules.cpp
  • ModeIsListMode() +: modules.cpp
  • ModeMakeList() +: modules.cpp
  • modules() +: modules.cpp, channels.cpp

    - n -

    • NonBlocking() @@ -211,7 +212,7 @@
    • zline_make_global() : xline.h
    • zline_set_creation_time() : xline.h
    -
    Generated on Fri May 13 15:50:10 2005 for InspIRCd by +
    Generated on Sun May 15 17:03:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/globals_type.html b/docs/module-doc/globals_type.html index 160c26206..0ef9ca1e3 100644 --- a/docs/module-doc/globals_type.html +++ b/docs/module-doc/globals_type.html @@ -4,30 +4,30 @@ - +

    -
    Generated on Fri May 13 15:50:10 2005 for InspIRCd by +: modules.cpp +
    Generated on Sun May 15 17:03:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/globals_vars.html b/docs/module-doc/globals_vars.html index 6d9ebd687..1a31c56d6 100644 --- a/docs/module-doc/globals_vars.html +++ b/docs/module-doc/globals_vars.html @@ -4,7 +4,7 @@ - +
    a | b | c | d | e | f | i | l | m | n | p | r | s | t | w
    @@ -14,96 +14,96 @@

    - a -

    +: modules.cpp, channels.cpp
  • AdminName +: modules.cpp, channels.cpp
  • AdminNick +: modules.cpp, channels.cpp
  • auth_cookies +: modules.cpp, channels.cpp

    - b -

    +: modules.cpp, channels.cpp

    - c -

    - d -

    +: modules.cpp, channels.cpp
  • defaultRoute +: modules.cpp, channels.cpp
  • DieDelay +: modules.cpp, channels.cpp
  • diepass +: modules.cpp, channels.cpp
  • DieValue +: modules.cpp, channels.cpp

    - e -

    +: modules.cpp

    - f -

    +: modules.cpp, channels.cpp
  • fd_reap +: modules.cpp, channels.cpp
  • fd_ref_table +: modules.cpp

    - i -

    +: modules.cpp

    - l -

    +: modules.cpp, channels.cpp
  • log_file +: modules.cpp, channels.cpp
  • LogLevel +: modules.cpp, channels.cpp

    - m -

    +: modules.cpp, channels.cpp
  • me +: modules.cpp, channels.cpp
  • MODCOUNT +: modules.cpp, channels.cpp
  • module_names +: modules.cpp, channels.cpp
  • modules +: modules.cpp, channels.cpp
  • motd +: modules.cpp, channels.cpp
  • MOTD +: modules.cpp

    - n -

    +: modules.cpp, channels.cpp
  • NetBufferSize +: modules.cpp, channels.cpp
  • Network +: modules.cpp, channels.cpp

    - p -

    +: modules.cpp, channels.cpp
  • ports +: modules.cpp, channels.cpp
  • PrefixQuit +: modules.cpp, channels.cpp

    - r -

    +: modules.cpp, channels.cpp
  • rules +: modules.cpp, channels.cpp
  • RULES +: modules.cpp

    - s -

    +: modules.cpp, channels.cpp
  • ServerName +: modules.cpp, channels.cpp
  • SERVERportCount +: modules.cpp, channels.cpp
  • startup_time +: modules.cpp, channels.cpp

    - t -

    +: users.cpp, servers.cpp, modules.cpp, channels.cpp

    - w -

    -
    Generated on Fri May 13 15:50:10 2005 for InspIRCd by +: modules.cpp
  • WHOWAS_MAX +: modules.cpp, channels.cpp
  • WHOWAS_STALE +: modules.cpp, channels.cpp +
    Generated on Sun May 15 17:03:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/graph_legend.html b/docs/module-doc/graph_legend.html index abdd1fabc..0892dff1d 100644 --- a/docs/module-doc/graph_legend.html +++ b/docs/module-doc/graph_legend.html @@ -4,7 +4,7 @@ - +

    Graph Legend

    This page explains how to interpret the graphs that are generated by doxygen.

    Consider the following example:

    /*! Invisible class because of truncation */
     class Invisible { };
    @@ -67,7 +67,7 @@ A purple dashed arrow is used if a class is contained or used by another class.
     
  • A yellow dashed arrow denotes a relation between a template instance and the template class it was instantiated from. The arrow is labeled with the template parameters of the instance.
  • -
    Generated on Fri May 13 15:50:10 2005 for InspIRCd by +
    Generated on Sun May 15 17:03:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/hashcomp_8h-source.html b/docs/module-doc/hashcomp_8h-source.html new file mode 100644 index 000000000..9314d0209 --- /dev/null +++ b/docs/module-doc/hashcomp_8h-source.html @@ -0,0 +1,97 @@ + + +InspIRCd: hashcomp.h Source File + + + + +

    hashcomp.h

    Go to the documentation of this file.
    00001 /*       +------------------------------------+
    +00002  *       | Inspire Internet Relay Chat Daemon |
    +00003  *       +------------------------------------+
    +00004  *
    +00005  *  Inspire is copyright (C) 2002-2005 ChatSpike-Dev.
    +00006  *                       E-mail:
    +00007  *                <brain@chatspike.net>
    +00008  *                <Craig@chatspike.net>
    +00009  *
    +00010  * Written by Craig Edwards, Craig McLure, and others.
    +00011  * This program is free but copyrighted software; see
    +00012  *            the file COPYING for details.
    +00013  *
    +00014  * ---------------------------------------------------
    +00015  */
    +00016 
    +00017 #ifndef _HASHCOMP_H_
    +00018 #define _HASHCOMP_H_
    +00019 
    +00020 #include "inspircd_config.h"
    +00021 
    +00022 #ifdef GCC3
    +00023 #include <ext/hash_map>
    +00024 #else
    +00025 #include <hash_map>
    +00026 #endif
    +00027 
    +00028 #ifdef GCC3
    +00029 #define nspace __gnu_cxx
    +00030 #else
    +00031 #define nspace std
    +00032 #endif
    +00033 
    +00034 using namespace std;
    +00035 
    +00036 namespace nspace
    +00037 {
    +00038 #ifdef GCC34
    +00039         template<> struct hash<in_addr>
    +00040 #else
    +00041         template<> struct nspace::hash<in_addr>
    +00042 #endif
    +00043         {
    +00044                 size_t operator()(const struct in_addr &a) const;
    +00045         };
    +00046 #ifdef GCC34
    +00047         template<> struct hash<string>
    +00048 #else
    +00049         template<> struct nspace::hash<string>
    +00050 #endif
    +00051         {
    +00052                 size_t operator()(const string &s) const;
    +00053         };
    +00054 }
    +00055 
    +00060 struct StrHashComp
    +00061 {
    +00064         bool operator()(const string& s1, const string& s2) const;
    +00065 };
    +00066 
    +00071 struct InAddr_HashComp
    +00072 {
    +00075         bool operator()(const in_addr &s1, const in_addr &s2) const;
    +00076 };
    +00077 
    +00080 namespace irc
    +00081 {
    +00086         struct irc_char_traits : std::char_traits<char> {
    +00087 
    +00090                 static bool eq(char c1st, char c2nd);
    +00091 
    +00094                 static bool ne(char c1st, char c2nd);
    +00095 
    +00098                 static bool lt(char c1st, char c2nd);
    +00099 
    +00102                 static int compare(const char* str1, const char* str2, size_t n);
    +00103 
    +00106                 static const char* find(const char* s1, int  n, char c);
    +00107         };
    +00108 
    +00111         typedef basic_string<char, irc_char_traits, allocator<char> > string;
    +00112 }
    +00113 
    +00114 #endif
    +

    Generated on Sun May 15 17:02:05 2005 for InspIRCd by + +doxygen +1.3.3
    + + diff --git a/docs/module-doc/hashcomp_8h.html b/docs/module-doc/hashcomp_8h.html new file mode 100644 index 000000000..ceb1dacd0 --- /dev/null +++ b/docs/module-doc/hashcomp_8h.html @@ -0,0 +1,69 @@ + + +InspIRCd: hashcomp.h File Reference + + + + +

    hashcomp.h File Reference

    #include "inspircd_config.h"
    +#include <ext/hash_map>
    + +

    +Include dependency graph for hashcomp.h:

    Include dependency graph
    + +

    +This graph shows which files directly or indirectly include this file:

    Included by dependency graph
    + + + + +

    +Go to the source code of this file. + + + + + + + + + + + + + + + + +

    Namespaces

    namespace  irc
    namespace  nspace

    Compounds

    struct  InAddr_HashComp
     This class returns true if two in_addr structs match. More...

    struct  StrHashComp
     This class returns true if two strings match. More...


    Defines

    #define nspace   __gnu_cxx
    +


    Define Documentation

    +

    + + + + +
    + + +
    #define nspace   __gnu_cxx +
    +
    + + + + + +
    +   + + +

    + +

    +Definition at line 29 of file hashcomp.h.

    +


    Generated on Sun May 15 17:02:28 2005 for InspIRCd by + +doxygen +1.3.3
    + + diff --git a/docs/module-doc/hashcomp_8h__dep__incl.gif b/docs/module-doc/hashcomp_8h__dep__incl.gif new file mode 100644 index 0000000000000000000000000000000000000000..5595a48da2e620d5277b46ddedb02b1de871cf48 GIT binary patch literal 912 zcmV;B18@9CNk%w1VR8U;0OJ4v|Ns900092~|6gBU-{0SVe}5kzA3r}ozrVkqpPv~S zZ~y=R000000000000000A^8LW00062EC2ui0CE6y000F35XecZy*TU5yZ>M)j$~<` zXsWJk>%MR-&vb3yYM}3Y@BhG{a7ZiyKLMN)l=L*0P|cGwjan&H>2-@ma=+P3_^TXW z%w!w7vM!<9W$){qmcZ>Wdi@S~CkzG%2nGQO5(EbU2Ly))1_@7*cmRlsj1rImffWP; znh17~i=mcIau@*v0DlFmO#_ArssID6o)eON5(A8~xUmKmu&cp+s=mgnvs9;Nm$}6N z#RiN7xw_cJ1kncvpcc`%m&F0&rst@*>e$%VxlKJ2l>y)DU6a=ve0uCn(bLs(S(_Bj z!k-ES`&1*h5FIly_Fl!BRf|?6L$|Q;T6JK;BUk>yKpjkmER`~c`m{{KR%w(3N025! zdIYbLrb_?@=`i%9(xyHI6yXZm5v9sHA+qqX_Yf%)3rklvb!s#!yQx&wG|O6JA6Fb+ zziKrqHqX|wW}O&W%XWu?ws4K0ouFWDn!0ws;LW>bFJCKu|3V2YSP9|6Hx47Np?L9( z#*Sk^j{IUW2aJRk_+gb7MW z;e`h_7(^d&afo3&a9QYshi#Ggp$;Y%AtHz!p2#9wD@M4HCyId5i4L>OLklA`el*V} zIwipiBBRhKWKM*{GoxG@9ubr(I@}1Qkf~Uc#FHG#Qsqvbz=9$qykNP5D_+JUrixAe zAPR~j>L5rWVu&DJYvSa=0j?c|xkE zq=BZ{CZh-x;E0L5Ksu)nc6vH#5`<85X`~DSy5Xb%z%*x}GDS!Psj4mpn4-0oR@Ym7MyBNL;FNN~X3*mnF=Bw|%{Pw$B1OPkwznkX( literal 0 HcmV?d00001 diff --git a/docs/module-doc/hashcomp_8h__incl.gif b/docs/module-doc/hashcomp_8h__incl.gif new file mode 100644 index 0000000000000000000000000000000000000000..be85b903ee00ba675b745948b1519ba2444a2f77 GIT binary patch literal 1512 zcmVM)j$~<` zXsWJk>%MR-&vb3yc&_h!@BhG{a7Zi~kI1BQ$t)tC(5Q4uty-_xtai(dp1R<$cpUB^ zn$5FGjn=U>@Afe+qRVM^Oa30*d;EMZfD(g&JB4tDHid|aH;ovOjwFneLy~%yGL@P@ zm=&L$W}_MbC#E2%EeQbw5~`&kp%b$d1hxhMu&I}%L%S*g2_e86wE)Kwxf2Bix+KLs zoWC#8u^`9E&l3k{)*IhB(-^422Er1o0S4Zz2e+@U1t_T92CN$O_Y(O6ynB`4 z+^_%$C!or=512W09I|Z)I1oTLWCwI51VCWf!(sjy*MU^Wj-bH|=GY-PN$7w`f&$@1 z^hHh{0DiiL71ZS_fvb2q;R?{1Yk)I*8iw9nrqriRoUl+SMOq<%Gn~f0Y#4CMDaTv} z;HmOz^(Lx)W(h8RYOU4MtE$jK?fG-2U6ilHN;q&auQG)||56Cc@!PV&6FlnO29%z| z#aY*Epm%t{fx4=c>Vgc|Vqd?EEd+pEtQ@?OCj7?SY}+(01FH_2hg>e+;{`4BA}c(>pwJYORunV^jF-72j3!K*ur6t;5!p0 zFS>RHi5gH(u#CB-@4W>Ou&1!|`fC3c<^H#ycO7AO*J{uKAeSj_c_kYK1DvswQ2WF$q%h1MF90RDyyi5L_K&qWBJh?I){6=Xn=gq#CWjqT02)R*N1 ziDGtO3LXbn|>PTfuiCOYN?*yiRvP!u9^s`uD;-BtfLx3#;v$gp+K&@ ze!(jjyZ$O{7O^T|EUhINs{pch{wTXFvmQ7LtsKrCJ1qv)K6`Bw*=oCOx7)VSt+mjO z>utD8n0qd&>Y^)dyRNFcuDeN?i>$r$qA_l{;O47uwby3r@4ME{%dP~{4*c%~2A8TW zxe7CJZo`~T9I+x4Pnz+?&91sJ#~q9MF~}ijIx@*6|9LXXDQmJa%hYNNbH$>(Jaf#J z*nBh281L+G&p!Xmht5F{-Ez^N61{`cNEOgVazveFW82TTKMkS!*2x*Ij$< z1K44Uy>!{%{y;X`X5+9n+ehEam0O-T2bpVLjiaE4F8b)Cmu~v$rh7gE>a4f!`s=8xE(7ee z*KT|2vcquu?!4QcyY9UQFFfwQw=n$i$RAp~@uO?>y7S444t?y)vq1XvtYaVjq0d+E zX7jXbzkNd8d!NGfCfXwqKI;DzkSXaSgx32d`3OG&`3$5!{K$xTX#A%$Uoe^%Bv&BB z9|nY9E68Jt0&2u33;dBihLR9gaK(X-vY1=ok@VO8H1<=Rz zxMIWS-&%$_Gd5Xw^4aFiS{r7D|;%0jL3mC9=+IABRjS*DVfu(ahYak)xe`tp~+45l!L ONz7sz^O*UH0029j<<9y5 literal 0 HcmV?d00001 diff --git a/docs/module-doc/hierarchy.html b/docs/module-doc/hierarchy.html index e8a66964c..28093b0d5 100644 --- a/docs/module-doc/hierarchy.html +++ b/docs/module-doc/hierarchy.html @@ -4,10 +4,14 @@ - +

    InspIRCd Class Hierarchy

    Go to the graphical class hierarchy

    This inheritance list is sorted roughly, but not completely, alphabetically:

      +
    • char_traits +
    • classbase
      • Admin @@ -61,7 +65,7 @@ This inheritance list is sorted roughly, but not completely, alphabetically: -
        Generated on Fri May 13 15:49:18 2005 for InspIRCd by +
        Generated on Sun May 15 17:02:54 2005 for InspIRCd by doxygen 1.3.3
        diff --git a/docs/module-doc/inherit__graph__0.gif b/docs/module-doc/inherit__graph__0.gif index a434ea0a7484bd8588e88faf6f0e26f1f64e18d3..397bfc922475d1fc31c776afc5abef0e5f12e37b 100644 GIT binary patch delta 661 zcmV;G0&4xNWBCONM@dFFIbjq5DgcoRKm-&4DgcpAHGk9+s9LYstai)odcWEqcuX#v z&uH@}Fa@!F?{+fIq02RPUH(4YWBhy+fHs4HJ%xgXcw&l0h!c-@kuj5vHItQ7nJ$}_ zlxuD(10HdsBb_XRr~s=}qNEe1BAB5m1tPbn8wv_Ct%NGMAi^QEpedWEfV{lEOuvw` zB*qv61b+bq2CN4K0S6NX2-x4O3B-a`5&`A_;p6J+=>P{+*>x7o`OX<{>$ld}w6Tf? zuiU?D_NpNi=&c($cLm59{FBa~1c>DNrK1?HJJjSFlOWu;e!dngdlsw5pms|oAkeL@*q8$b7lvC( zT!6k9(n_98xw1Z+DWj3PAjt!co-iqmlRH3ZiIl}qS*4OMVp)rpL&mryj9}h? vNg8OTiKZB8w&~`Za9UC3oOIS{=bd=wspp=2_UY%JfCeh)poA8RK?DFha8)jV delta 12711 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 hBRI-2TF<*M)j$~<` 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 delta 268 zcmV+n0rUQ>W3U1)M@dFFIblKoDgfgE0RR900002~|Noz#pFcl8e}8}9-`~H#zh7Tp zA0Hn8005CL90x)GDgXck-H}lie=ruzbZy^wuHRn}gFa92*BNq*L<&-wEcTkmCzL5v z)&`RRHcLSy0*OL(ESn6pk^q4+M2G=~!h5sK)Vb!Mc0M#35>8|nNO}MS25A#vB6ovS zcs>URi4q412?zs-ft-$Pln4g^NCyQ3Xiwrcb1)Wj{s+s00p)ZN`RlKvK2#T zTSi|KZisP{zRRmucoMpBr(kols#CyH*q*=Jx6Iz(*5SR~-i@o|+1KId>+0fGJM;AQ SH1PQO`uqI-{{JH)0027?a&*K1 diff --git a/docs/module-doc/inherit__graph__2.gif b/docs/module-doc/inherit__graph__2.gif index 2242327363eb8aed4458bb01129d088ff176cda1..992d6ed85bc74f939aaacafa7d25b8e73e87273b 100644 GIT binary patch delta 265 zcmV+k0rvil1F!-sM@dFFIblKoDgfgE0RR900002~|Noz#pFcl8e}8}9-`~H#zh7Tp zA0Ho)D<20!04e|g1l^HQ7Jo1n%yezvc&^`H5Q9EX@Yfk~j6@1jnJo62$0w92RMrNQ z05(fOBm#*-bu608NbdLaMlmG>`5=wxdsj?MAXIn;J z6K;rclfKKVS9lV-aHn8%v#L|TQrMoq+qcZ#-`3&1-QJC>+WA^-q8OIdV6 delta 359 zcmV-t0hs=<0*wPJM@dFFIbmb~DgfgE0RR900002~|Nr0L-#AR!n#ZE3Opf)P3DA?*&TSy0JubMBCI)u_whp~B@TBRa&Tk=1O*0c1_c2I5{Ur? z2^oq31a1=qYGreeI+AfZdrcb$2mpX{r-^fpi;1c9J*Hf>) z*7_KxsO#5=W_4jBi`F}P5(2V{gJ~bE3WpX3O2DYm!vF{@T@VL=q7Fwp{?Ju}qJ&V% zlhktfID^Bam>Mo$YA6vY^9#+IE@I+*p>t;oLPdfK9ZGbF&!b3_DqYI7sne%Wqf&?f F06R7zoBRL( diff --git a/docs/module-doc/inherit__graph__3.gif b/docs/module-doc/inherit__graph__3.gif index 54f78b321fdc42b4b3c10f6516f94c087c54f4e8..2242327363eb8aed4458bb01129d088ff176cda1 100644 GIT binary patch delta 347 zcmV-h0i^!01dRhLM@dFFIbmb~DgfgE0RR900002~|Nr0L-#AR!n#ZE3Opf) zP3DA?*&TSy0JubMBCI)u_whp~B@TBRa&Tk=1O*0c1_c2I5{Ur?2^oq31a1=qYGree zI+AfZdrcb$2mpX{r-^fpi;1c9J*Hf>)*7_KxsO#5=W_4jB zi`F}P5(2V{gJ~bE3WpX3O2DYm!vF{@T@VL=q7Fwp{?Ju}qJ&V%lhktfID^Bam>Mo$ tY7r^(3(cA$E@I+*p>t;oLPdfK9ZGbF&!b3_DqYI7sne%Wqf&?f06Qd{m!SXv delta 511 zcmV4LHc4`&|1Oottm_m|$ z8wLRh31)1agOn8si4q40Ig4O;0|Wt^5(Nnd0R|I=msP%h162V91fFset%sY!hmWrY1qX^V1qn~KWX8-zRL2XHglUIT_gdCRQF*VDU~VT z5ttd^*(sQRFyjR3g^QL1Yc*3=!8pNI7L7uaGK@v;Ca3}2S_;Hykz&S_FK>D*aG+|@ zlQ-K*7~tySJ*7D-PSmoLtzTV+F=Dou7Pk_=Zc`rm|MFZ!I}pWI(4$MAPCa__>)5kv-_E_e_wV4ti*FqP06PyA B=5+u7 diff --git a/docs/module-doc/inherit__graph__4.gif b/docs/module-doc/inherit__graph__4.gif index d85abdb1bbd48fc730cf832649ec69d57536808b..54f78b321fdc42b4b3c10f6516f94c087c54f4e8 100644 GIT binary patch delta 469 zcmV;`0V@9M1h51LM@dFFIboNP2SWjukxM9lKwMx*EE&!+#+1kC(Alz1yEko0{7tXSCGEN4kO|)bUw;#21_%KJ1v-Cu9EN-sepGg9 z76t?Z0EL)Bl6@Nn0SO6aY@LIY6$yzF2M9TfV0Z%r0h*s)& zvv`U5YYFy^0yJutzhMOjiZcZXPqt*n%tchk3zURunTElcR0;qB1m2Gv;u(oyV#Hk} z0f|)iVH_!yDc=#88Q|F|m@wl6>V=DcmIP}xQ&zz^!B!THLX$F#MeZi30o+;&#AuOX z#*{B_dMt3DYSEK7+esMU>f$}6IV(=ovXtY|TWfXkiU%)|Je*mDcD;)aDNIY4y4eb7 zZs1#zp$fNbiwx(`RrgjQ_%&hjzm1J0BC67D$fm;pl&$M!2pigA1+IZ`S?7vCpv;(C zyB@)s2NF83wZ@jsn1nUF`M@dFFIbphy2SWk6kxM9lz@TtQEE+k1q;kn@I-k&}bV{vSuUIT7 zaO`@yAFy{k6nD(zbPv5@tKTsX=oh?wztUIyK!AB7f*x*#VOwd46pSv1kBVfD z5_ks)Gmsew2ZWLs0Rse~5(7yDouL5;1{0S71OpNV39y|21_-OI0AjwPqyVq6rKh)l zp`)^{2%HvR$iW!H%DJ&()uxpN1QnOfiQu3G0NK5=qP+>^>Jr4|3Fq7Z39SR{;^biN z&+*#%65eh(^H&bTJ_!lN)tZoS9zR~)m(7xZX>Ra2nrmK`LV)CrBc(bMT2gv-KpOiZN(#(EdZLhX4c$F z;cK{;ERP-xpw6DgwF~EUs!NX?ro>}^($aTM>s^4C_1fJD8BD{-^AvifkoPcq61YbX zj3N~PXJ~Q+2;l5#i#OoWQpbwY3PyGkWmYKy&oF$q1O(PtNB?X>=Lt%D##pbOz55{7 zp1g-?QYNhU^CY&TUq3=U`}bhM!=L{>KK=Xk5#!$<{7jbr00tT;;D7`Q$lrkoCaBsX=oh?wztUIyK!AB7f*x*#VOwd46pSv1kBVfD5_ks) zGmsew2ZWLs0Rse~5(7yDouL5;1{0S71OpNV39y|21_-OI0AjwPqyVq6rKh){qq44l z2%HvR$iW!H%DJ&()uxpN1QnOfiQu3G0NK5=qP+>^>Jr4|3Fq7Z39SR{;^biN&+*#% z65eh(^H&bTJ_!lN)tZoS9zR~)m(7xZX>Ra2nrmK`LV)CrBc(bMT2gv-KpOiZN(#(EdZLhX4c$F;cK{; zERP-xpw6DgwF~EUs!NX?ro>}^($aTM>s^4C_1fJD8BD{-^AvifkoPbWxJM6nj3N~P zXJ~Q+2;l5#i#OoWQpbwY3PyGkWmYKy&oF$q1O(PtNB?X>=Lt%D##pbOz55{7p1g-? zQYNhU^CY&TUq3=U`}bhM!=L{>KK=Xk5#!$<{7jbr00tT;;D7`Q$lrkoCaBiW7DR2wyG; z2O)40IRK`qqCi#t`n4)7NW9$ zNPPv30A9nqwXJN&vyYZ#1puObuAa~d-QyC!-T(>U&k2MBKXUAe4xwz@~zQHqx>c zpp>Ku1_~tjr1DOZGB0V#q`C5lu$%;cE!6S}EvHJ5MQd6JiW6lZqoEp!q~#DnfddA- zP=uH*sa33I!X+Ks%VUOcNRQ?uKq%`4rUsqHSqn}}fN}36VT~mrK_;>7x>d@6v?VO9 zb!)1j6fyBsve9xT;KtWNMh_A7Snq1Bsw4GVre&89C$5I zX=Ihu(4oj&B9fjG6YF&C{dy|mHlMzHIQ8qw=VIS3y(#za+Pi}v l&wD)hLs!zPU(de1dno4P%b!obzWw|7^XuQwzyFE|06Rmj=pX<9 diff --git a/docs/module-doc/inherit__graph__6.gif b/docs/module-doc/inherit__graph__6.gif index e3f1b5b058e6de1763247773b154d204a49f591d..516567cb0cfeef1b5bfcc7a09c175fec83086aed 100644 GIT binary patch delta 538 zcmV+#0_FYZ1I`31M@dFFIbo~-DgfgE0RR900002~|Noz#pC2C|e}8}9-`~H#zdt`e zUteF5D<1)@kxM0ieDD9jpm0d61dhn0a>;BupU|juO08O#oj`Fb)N;JsFb}LDi_bPQ zMvZR6*cP~Zu98#i^gIbK;RpQ}fEosCIDUdYh<7Lie_3vd6Ltp(UoHp-A%`0Q0|cEC z14jgzodF1h5|jZ10}=)ateF4?2&buFxt^c^tF57e9*4r;QUQ ze*h35>yzr45px!v8E_Z~;i7~K8TPrCK_RwW{1*ctl!&Lmrh#@9kd4<`u&{RAq2$-z+xn0#f66lqo#(|Yk?Bsw4GVre%Vcr8$AWR=v=p~ze! zlAaP1>vZk?dxmM5!sUwaUHro?RLSEupT2xJ_3O&#V&5*kDfjQ%yMrIkdp!6)+46|B46zJ49#xG5`Po delta 434 zcmV;j0ZsnS1m^=QM@dFFIbnJLDgfgE0RR900002~|NmcKUmqVIe}8}9-`~H#zn`C< zKR-W_D<1)RkxM0icHsZOpm0bm8jr}N()S7Qo*<`33ax6W9ISOq(O$XWZZk~wX3XR# z`m&Y`2mwMtV!&wI7PKJ|pX2ai83TR>1#<*;6@Y;i1_THIdyqGa5^Y$H0BCnn7lRWA z34dc5a*9lv1&Er85}|RE00=$=2bu_Qu>^G%djSc&0l2k)2e}i%zr0zb7{vqw2*JnE zmO>JbvQ)ydhyio6#~9GE1D55u-`eNp9hIyb2L*hP+KiTY6A1~nmeThZs{pJD;P0I# zUI90_b63nD7EX~0yrJSNfUSDhl*#({4x__xmF<`TY~|75zXSyi81RDYqZ>c6LWWBE!>S&2=|5DpmgiT6|qpSmA-zV01nJ!Fku~r509#g77|}yUmqVIe}8}9-`~H#zn`C1#<*; z6@Y;i1_THIdyqGa5^Y$H0BCnn7lRWA34dc5a*9lv1&Er85}|RE00=$=2bu_Qu>^G% zdjSc&0l2k)2e}i%zr0zb7{vqw2*JnEmO>JbvQ)ydhyio6#~9GE1D55u-`eNp9hIyb z2L*hP+KiTY6A1~nmeThZs{pJD;P0I#UI90_b63nD7EX~0yrJSNfUSDhl*#({4x__x zmF<`TY~|75zXSyi81RDYqZ>c6LWWBE!>S&2=|5DpmgiT z6|qpSmA-zV01nJ!Fku~r509#8-7Qxt+Fm|++Q2@?YdeE}Ui60>!GwsoBW1BL)_$fa3Q%%Hr!z+48RW?~r!r3H$R-m#5vhjQVE-QVVl$;(oE zxu&l0bq8+eb_Ky+A9o0f+yMLoaKKQ2U`|Ad8W@nFvRJEFLA(^PlrRajCi>~Of!L>8 zuNs}a!vpfxECYz7^zz|s5Jq1CoB?sg0hT-r2M&0DI;3;n#h*NP66`t300IJC;z<-J z^o>UguxtW?(?|jwWg`i$qd--U!J`MHv?JHaO)rbJ%rUXIOlVYXX7(Z7mvv>eOL7ld z9WcOvlu$kl$JS&APPf*RW&Do=v;9?c2C-L;wIgViUmp diff --git a/docs/module-doc/inherit__graph__8.gif b/docs/module-doc/inherit__graph__8.gif new file mode 100644 index 0000000000000000000000000000000000000000..a7d4324c47760e39eaf9b423d9d54f8b742349f8 GIT binary patch literal 513 zcmV+c0{;C+Nk%w1VR`^60OJ4v|Ns900092~{~sS8-{0S#pPzq!e_vl;zrVjfKR*Bf z00000000000000000000A^8LW00062EC2ui0D1r_000F35XecZy*TU5yZ>M)j$~<` zXsWJk>%MR-&vb3yc&_hv;Qzp&a7Zi~kI1Al0Ali<9%mFv-AFsvs&QdjJFp0SRsrvvsz0odE-e0C32qSyIfP zyuQF(2BKzS83&~Wijdy1jc|u@;fLMd=8DP7QhT|kuJCmSZs&Fd!CoJC2#VYQ`~z^n zP=H`gM2Q+0kfE|zt5`w26tR>r3A85q>9>K{r(3TYoxH;X^42T^h@|xL;cO5_Ujdu} zam4|aJPZd8csitW-o>9hcM|M5$^ZfaUE)a;DD;g-3$Sbgg40L>9AzU3uA@LzkHMn{ zq_iW~$xSbdwahWGw@heMZD#f%-IsM`wM%jjS{*RJfRs=^4CO-h5b&Orwr=ukg@%gM z##$ajb_{oNn#z`SNY1=tGv^$hKli{ax`xyxs8g$6&APPf*RW&Do=v;9?c2C-L;wIg D1(Vw3 literal 0 HcmV?d00001 diff --git a/docs/module-doc/inherits.html b/docs/module-doc/inherits.html index 9c4f67ede..bf56418f2 100644 --- a/docs/module-doc/inherits.html +++ b/docs/module-doc/inherits.html @@ -4,11 +4,16 @@ - +

        InspIRCd Graphical Class Hierarchy

        Go to the textual class hierarchy

        - + - - - - - - -
        +
        + + + +
        @@ -44,36 +49,36 @@
        +
        +
        +
        +
        +
        +
        +
        -


        Generated on Fri May 13 15:50:13 2005 for InspIRCd by +
        Generated on Sun May 15 17:04:00 2005 for InspIRCd by doxygen 1.3.3
        diff --git a/docs/module-doc/main.html b/docs/module-doc/main.html index ad2088d71..a137dee20 100644 --- a/docs/module-doc/main.html +++ b/docs/module-doc/main.html @@ -4,10 +4,10 @@ - +

        InspIRCd Documentation

        -

        1.0Betareleases


        Generated on Fri May 13 15:48:40 2005 for InspIRCd by +

        1.0Betareleases


        Generated on Sun May 15 17:02:04 2005 for InspIRCd by doxygen 1.3.3
        diff --git a/docs/module-doc/message_8h-source.html b/docs/module-doc/message_8h-source.html index 3626a3fa0..958c56b71 100644 --- a/docs/module-doc/message_8h-source.html +++ b/docs/module-doc/message_8h-source.html @@ -4,7 +4,7 @@ - +

        message.h

        Go to the documentation of this file.
        00001 /*       +------------------------------------+
         00002  *       | Inspire Internet Relay Chat Daemon |
         00003  *       +------------------------------------+
        @@ -57,7 +57,7 @@
         00050 void send_network_quit(const char* nick, const char* reason);
         00051 
         00052 #endif
        -

        Generated on Fri May 13 15:48:41 2005 for InspIRCd by +

    Generated on Sun May 15 17:02:05 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/message_8h.html b/docs/module-doc/message_8h.html index 687a00ed8..98336179d 100644 --- a/docs/module-doc/message_8h.html +++ b/docs/module-doc/message_8h.html @@ -4,7 +4,7 @@ - +

    message.h File Reference

    #include <typeinfo>
    #include <iostream>
    #include <string>
    @@ -169,7 +169,7 @@ This graph shows which files directly or indirectly include this file:

    -Referenced by Server::ChangeHost(). +Referenced by Server::ChangeHost().

    @@ -209,7 +209,7 @@ Referenced by Server::Chang

    -Referenced by Server::ChangeGECOS(). +Referenced by Server::ChangeGECOS().

    @@ -354,7 +354,7 @@ Referenced by Server::Chang

    -Referenced by Server::ChanMode(). +Referenced by Server::ChanMode().

    @@ -394,7 +394,7 @@ Referenced by Server::ChanM

    -Referenced by Server::CommonChannels(). +Referenced by Server::CommonChannels().

    @@ -472,7 +472,7 @@ Referenced by Server::Commo

    -Referenced by Server::IsOnChannel(). +Referenced by Server::IsOnChannel().

    @@ -570,7 +570,7 @@ Referenced by Server::IsOnC

    -Referenced by Server::IsNick(). +Referenced by Server::IsNick().

    @@ -756,7 +756,7 @@ Referenced by Server::IsNic -


    Generated on Fri May 13 15:48:59 2005 for InspIRCd by +
    Generated on Sun May 15 17:02:30 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/mode_8h-source.html b/docs/module-doc/mode_8h-source.html index b8bc7b719..3afbfc976 100644 --- a/docs/module-doc/mode_8h-source.html +++ b/docs/module-doc/mode_8h-source.html @@ -4,7 +4,7 @@ - +

    mode.h

    Go to the documentation of this file.
    00001 /*       +------------------------------------+
     00002  *       | Inspire Internet Relay Chat Daemon |
     00003  *       +------------------------------------+
    @@ -53,7 +53,7 @@
     00046 
     00047 
     00048 #endif
    -

    Generated on Fri May 13 15:48:41 2005 for InspIRCd by +

  • Generated on Sun May 15 17:02:05 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/mode_8h.html b/docs/module-doc/mode_8h.html index 2edbe429f..48eafe999 100644 --- a/docs/module-doc/mode_8h.html +++ b/docs/module-doc/mode_8h.html @@ -4,7 +4,7 @@ - +

    mode.h File Reference

    #include <typeinfo>
    #include <iostream>
    #include <string>
    @@ -802,7 +802,7 @@ This graph shows which files directly or indirectly include this file:

    -
    Generated on Fri May 13 15:49:01 2005 for InspIRCd by +
    Generated on Sun May 15 17:02:32 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/modules_8cpp-source.html b/docs/module-doc/modules_8cpp-source.html index 024038f7d..5f6dfb3be 100644 --- a/docs/module-doc/modules_8cpp-source.html +++ b/docs/module-doc/modules_8cpp-source.html @@ -4,7 +4,7 @@ - +

    modules.cpp

    Go to the documentation of this file.
    00001 /*       +------------------------------------+
     00002  *       | Inspire Internet Relay Chat Daemon |
     00003  *       +------------------------------------+
    @@ -26,1055 +26,984 @@
     00019 #include "inspircd_util.h"
     00020 #include "inspircd_config.h"
     00021 #include <unistd.h>
    -00022 #include <fcntl.h>
    -00023 #include <sys/errno.h>
    -00024 #include <sys/ioctl.h>
    -00025 #include <sys/utsname.h>
    -00026 #ifdef USE_KQUEUE
    -00027 #include <sys/types.h>
    -00028 #include <sys/event.h>
    -00029 #include <sys/time.h>
    -00030 #endif
    -00031 #include <cstdio>
    -00032 #include <time.h>
    -00033 #include <string>
    -00034 #ifdef GCC3
    -00035 #include <ext/hash_map>
    -00036 #else
    -00037 #include <hash_map>
    -00038 #endif
    -00039 #include <map>
    -00040 #include <sstream>
    -00041 #include <vector>
    -00042 #include <errno.h>
    -00043 #include <deque>
    -00044 #include <errno.h>
    -00045 #include <unistd.h>
    -00046 #include <sched.h>
    -00047 #include "connection.h"
    -00048 #include "users.h"
    -00049 #include "servers.h"
    -00050 #include "ctables.h"
    -00051 #include "globals.h"
    -00052 #include "modules.h"
    -00053 #include "dynamic.h"
    -00054 #include "wildcard.h"
    -00055 #include "message.h"
    -00056 #include "mode.h"
    -00057 #include "xline.h"
    -00058 #include "commands.h"
    -00059 #include "inspstring.h"
    -00060 
    -00061 #ifdef GCC3
    -00062 #define nspace __gnu_cxx
    -00063 #else
    -00064 #define nspace std
    -00065 #endif
    -00066 
    -00067 using namespace std;
    -00068 
    -00069 #ifdef USE_KQUEUE
    -00070 extern int kq;
    -00071 #endif
    -00072 
    -00073 extern int MODCOUNT;
    -00074 extern std::vector<Module*> modules;
    -00075 extern std::vector<ircd_module*> factory;
    -00076 
    -00077 extern time_t TIME;
    -00078 
    -00079 extern int LogLevel;
    -00080 extern char ServerName[MAXBUF];
    -00081 extern char Network[MAXBUF];
    -00082 extern char ServerDesc[MAXBUF];
    -00083 extern char AdminName[MAXBUF];
    -00084 extern char AdminEmail[MAXBUF];
    -00085 extern char AdminNick[MAXBUF];
    -00086 extern char diepass[MAXBUF];
    -00087 extern char restartpass[MAXBUF];
    -00088 extern char motd[MAXBUF];
    -00089 extern char rules[MAXBUF];
    -00090 extern char list[MAXBUF];
    -00091 extern char PrefixQuit[MAXBUF];
    -00092 extern char DieValue[MAXBUF];
    +00022 #include <sys/errno.h>
    +00023 #ifdef USE_KQUEUE
    +00024 #include <sys/types.h>
    +00025 #include <sys/event.h>
    +00026 #include <sys/time.h>
    +00027 #endif
    +00028 #include <time.h>
    +00029 #include <string>
    +00030 #ifdef GCC3
    +00031 #include <ext/hash_map>
    +00032 #else
    +00033 #include <hash_map>
    +00034 #endif
    +00035 #include <map>
    +00036 #include <sstream>
    +00037 #include <vector>
    +00038 #include <deque>
    +00039 #include "connection.h"
    +00040 #include "users.h"
    +00041 #include "servers.h"
    +00042 #include "ctables.h"
    +00043 #include "globals.h"
    +00044 #include "modules.h"
    +00045 #include "dynamic.h"
    +00046 #include "wildcard.h"
    +00047 #include "message.h"
    +00048 #include "mode.h"
    +00049 #include "xline.h"
    +00050 #include "commands.h"
    +00051 #include "inspstring.h"
    +00052 #include "helperfuncs.h"
    +00053 #include "hashcomp.h"
    +00054 
    +00055 using namespace std;
    +00056 
    +00057 #ifdef USE_KQUEUE
    +00058 extern int kq;
    +00059 #endif
    +00060 
    +00061 extern int MODCOUNT;
    +00062 extern std::vector<Module*> modules;
    +00063 extern std::vector<ircd_module*> factory;
    +00064 
    +00065 extern time_t TIME;
    +00066 
    +00067 extern int LogLevel;
    +00068 extern char ServerName[MAXBUF];
    +00069 extern char Network[MAXBUF];
    +00070 extern char ServerDesc[MAXBUF];
    +00071 extern char AdminName[MAXBUF];
    +00072 extern char AdminEmail[MAXBUF];
    +00073 extern char AdminNick[MAXBUF];
    +00074 extern char diepass[MAXBUF];
    +00075 extern char restartpass[MAXBUF];
    +00076 extern char motd[MAXBUF];
    +00077 extern char rules[MAXBUF];
    +00078 extern char list[MAXBUF];
    +00079 extern char PrefixQuit[MAXBUF];
    +00080 extern char DieValue[MAXBUF];
    +00081 
    +00082 extern int debugging;
    +00083 extern int WHOWAS_STALE;
    +00084 extern int WHOWAS_MAX;
    +00085 extern int DieDelay;
    +00086 extern time_t startup_time;
    +00087 extern int NetBufferSize;
    +00088 extern int MaxWhoResults;
    +00089 extern time_t nb_start;
    +00090 
    +00091 extern std::vector<int> fd_reap;
    +00092 extern std::vector<std::string> module_names;
     00093 
    -00094 extern int debugging;
    -00095 extern int WHOWAS_STALE;
    -00096 extern int WHOWAS_MAX;
    -00097 extern int DieDelay;
    -00098 extern time_t startup_time;
    -00099 extern int NetBufferSize;
    -00100 extern int MaxWhoResults;
    -00101 extern time_t nb_start;
    +00094 extern int boundPortCount;
    +00095 extern int portCount;
    +00096 extern int SERVERportCount;
    +00097 extern int ports[MAXSOCKS];
    +00098 extern int defaultRoute;
    +00099 
    +00100 extern std::vector<long> auth_cookies;
    +00101 extern std::stringstream config_f;
     00102 
    -00103 extern std::vector<int> fd_reap;
    -00104 extern std::vector<std::string> module_names;
    -00105 
    -00106 extern int boundPortCount;
    -00107 extern int portCount;
    -00108 extern int SERVERportCount;
    -00109 extern int ports[MAXSOCKS];
    -00110 extern int defaultRoute;
    -00111 
    -00112 extern std::vector<long> auth_cookies;
    -00113 extern std::stringstream config_f;
    +00103 extern serverrec* me[32];
    +00104 
    +00105 extern FILE *log_file;
    +00106 
    +00107 extern userrec* fd_ref_table[65536];
    +00108 
    +00109 typedef nspace::hash_map<std::string, userrec*, nspace::hash<string>, StrHashComp> user_hash;
    +00110 typedef nspace::hash_map<std::string, chanrec*, nspace::hash<string>, StrHashComp> chan_hash;
    +00111 typedef nspace::hash_map<in_addr,string*, nspace::hash<in_addr>, InAddr_HashComp> address_cache;
    +00112 typedef nspace::hash_map<std::string, WhoWasUser*, nspace::hash<string>, StrHashComp> whowas_hash;
    +00113 typedef std::deque<command_t> command_table;
     00114 
    -00115 extern serverrec* me[32];
    -00116 
    -00117 extern FILE *log_file;
    -00118 
    -00119 extern userrec* fd_ref_table[65536];
    -00120 
    -00121 namespace nspace
    -00122 {
    -00123 #ifdef GCC34
    -00124         template<> struct hash<in_addr>
    -00125 #else
    -00126         template<> struct nspace::hash<in_addr>
    -00127 #endif
    -00128         {
    -00129                 size_t operator()(const struct in_addr &a) const
    -00130                 {
    -00131                         size_t q;
    -00132                         memcpy(&q,&a,sizeof(size_t));
    -00133                         return q;
    -00134                 }
    -00135         };
    -00136 #ifdef GCC34
    -00137         template<> struct hash<string>
    -00138 #else
    -00139         template<> struct nspace::hash<string>
    -00140 #endif
    -00141         {
    -00142                 size_t operator()(const string &s) const
    -00143                 {
    -00144                         char a[MAXBUF];
    -00145                         static struct hash<const char *> strhash;
    -00146                         strlcpy(a,s.c_str(),MAXBUF);
    -00147                         strlower(a);
    -00148                         return strhash(a);
    -00149                 }
    -00150         };
    -00151 }
    -00152 
    -00153 struct StrHashComp
    -00154 {
    -00155 
    -00156         bool operator()(const string& s1, const string& s2) const
    -00157         {
    -00158                 char a[MAXBUF],b[MAXBUF];
    -00159                 strlcpy(a,s1.c_str(),MAXBUF);
    -00160                 strlcpy(b,s2.c_str(),MAXBUF);
    -00161                 strlower(a);
    -00162                 strlower(b);
    -00163                 return (strcasecmp(a,b) == 0);
    -00164         }
    -00165 
    -00166 };
    -00167 
    -00168 struct InAddr_HashComp
    -00169 {
    -00170 
    -00171         bool operator()(const in_addr &s1, const in_addr &s2) const
    -00172         {
    -00173                 size_t q;
    -00174                 size_t p;
    -00175                 
    -00176                 memcpy(&q,&s1,sizeof(size_t));
    -00177                 memcpy(&p,&s2,sizeof(size_t));
    -00178                 
    -00179                 return (q == p);
    -00180         }
    +00115 
    +00116 extern user_hash clientlist;
    +00117 extern chan_hash chanlist;
    +00118 extern whowas_hash whowas;
    +00119 extern command_table cmdlist;
    +00120 extern file_cache MOTD;
    +00121 extern file_cache RULES;
    +00122 extern address_cache IP;
    +00123 
    +00124 
    +00125 // class type for holding an extended mode character - internal to core
    +00126 
    +00127 class ExtMode : public classbase
    +00128 {
    +00129 public:
    +00130         char modechar;
    +00131         int type;
    +00132         int params_when_on;
    +00133         int params_when_off;
    +00134         bool needsoper;
    +00135         bool list;
    +00136         ExtMode(char mc, int ty, bool oper, int p_on, int p_off) : modechar(mc), type(ty), needsoper(oper), params_when_on(p_on), params_when_off(p_off) { };
    +00137 };                                     
    +00138 
    +00139 typedef std::vector<ExtMode> ExtModeList;
    +00140 typedef ExtModeList::iterator ExtModeListIter;
    +00141 
    +00142 
    +00143 ExtModeList EMode;
    +00144 
    +00145 // returns true if an extended mode character is in use
    +00146 bool ModeDefined(char modechar, int type)
    +00147 {
    +00148         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00149         {
    +00150                 if ((i->modechar == modechar) && (i->type == type))
    +00151                 {
    +00152                         return true;
    +00153                 }
    +00154         }
    +00155         return false;
    +00156 }
    +00157 
    +00158 bool ModeIsListMode(char modechar, int type)
    +00159 {
    +00160         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00161         {
    +00162                 if ((i->modechar == modechar) && (i->type == type) && (i->list == true))
    +00163                 {
    +00164                         return true;
    +00165                 }
    +00166         }
    +00167         return false;
    +00168 }
    +00169 
    +00170 bool ModeDefinedOper(char modechar, int type)
    +00171 {
    +00172         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00173         {
    +00174                 if ((i->modechar == modechar) && (i->type == type) && (i->needsoper == true))
    +00175                 {
    +00176                         return true;
    +00177                 }
    +00178         }
    +00179         return false;
    +00180 }
     00181 
    -00182 };
    -00183 
    -00184 
    -00185 typedef nspace::hash_map<std::string, userrec*, nspace::hash<string>, StrHashComp> user_hash;
    -00186 typedef nspace::hash_map<std::string, chanrec*, nspace::hash<string>, StrHashComp> chan_hash;
    -00187 typedef nspace::hash_map<in_addr,string*, nspace::hash<in_addr>, InAddr_HashComp> address_cache;
    -00188 typedef nspace::hash_map<std::string, WhoWasUser*, nspace::hash<string>, StrHashComp> whowas_hash;
    -00189 typedef std::deque<command_t> command_table;
    -00190 
    -00191 
    -00192 extern user_hash clientlist;
    -00193 extern chan_hash chanlist;
    -00194 extern whowas_hash whowas;
    -00195 extern command_table cmdlist;
    -00196 extern file_cache MOTD;
    -00197 extern file_cache RULES;
    -00198 extern address_cache IP;
    -00199 
    -00200 
    -00201 // class type for holding an extended mode character - internal to core
    -00202 
    -00203 class ExtMode : public classbase
    -00204 {
    -00205 public:
    -00206         char modechar;
    -00207         int type;
    -00208         int params_when_on;
    -00209         int params_when_off;
    -00210         bool needsoper;
    -00211         bool list;
    -00212         ExtMode(char mc, int ty, bool oper, int p_on, int p_off) : modechar(mc), type(ty), needsoper(oper), params_when_on(p_on), params_when_off(p_off) { };
    -00213 };                                     
    -00214 
    -00215 typedef std::vector<ExtMode> ExtModeList;
    -00216 typedef ExtModeList::iterator ExtModeListIter;
    +00182 // returns number of parameters for a custom mode when it is switched on
    +00183 int ModeDefinedOn(char modechar, int type)
    +00184 {
    +00185         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00186         {
    +00187                 if ((i->modechar == modechar) && (i->type == type))
    +00188                 {
    +00189                         return i->params_when_on;
    +00190                 }
    +00191         }
    +00192         return 0;
    +00193 }
    +00194 
    +00195 // returns number of parameters for a custom mode when it is switched on
    +00196 int ModeDefinedOff(char modechar, int type)
    +00197 {
    +00198         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00199         {
    +00200                 if ((i->modechar == modechar) && (i->type == type))
    +00201                 {
    +00202                         return i->params_when_off;
    +00203                 }
    +00204         }
    +00205         return 0;
    +00206 }
    +00207 
    +00208 // returns true if an extended mode character is in use
    +00209 bool DoAddExtendedMode(char modechar, int type, bool requires_oper, int params_on, int params_off)
    +00210 {
    +00211         if (ModeDefined(modechar,type)) {
    +00212                 return false;
    +00213         }
    +00214         EMode.push_back(ExtMode(modechar,type,requires_oper,params_on,params_off));
    +00215         return true;
    +00216 }
     00217 
    -00218 
    -00219 ExtModeList EMode;
    -00220 
    -00221 // returns true if an extended mode character is in use
    -00222 bool ModeDefined(char modechar, int type)
    -00223 {
    -00224         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00225         {
    -00226                 if ((i->modechar == modechar) && (i->type == type))
    -00227                 {
    -00228                         return true;
    -00229                 }
    -00230         }
    -00231         return false;
    -00232 }
    +00218 // turns a mode into a listmode
    +00219 void ModeMakeList(char modechar)
    +00220 {
    +00221         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00222         {
    +00223                 if ((i->modechar == modechar) && (i->type == MT_CHANNEL))
    +00224                 {
    +00225                         i->list = true;
    +00226                         return;
    +00227                 }
    +00228         }
    +00229         return;
    +00230 }
    +00231 
    +00232 // version is a simple class for holding a modules version number
     00233 
    -00234 bool ModeIsListMode(char modechar, int type)
    -00235 {
    -00236         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00237         {
    -00238                 if ((i->modechar == modechar) && (i->type == type) && (i->list == true))
    -00239                 {
    -00240                         return true;
    -00241                 }
    -00242         }
    -00243         return false;
    -00244 }
    -00245 
    -00246 bool ModeDefinedOper(char modechar, int type)
    -00247 {
    -00248         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00249         {
    -00250                 if ((i->modechar == modechar) && (i->type == type) && (i->needsoper == true))
    -00251                 {
    -00252                         return true;
    -00253                 }
    -00254         }
    -00255         return false;
    -00256 }
    -00257 
    -00258 // returns number of parameters for a custom mode when it is switched on
    -00259 int ModeDefinedOn(char modechar, int type)
    -00260 {
    -00261         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00262         {
    -00263                 if ((i->modechar == modechar) && (i->type == type))
    -00264                 {
    -00265                         return i->params_when_on;
    -00266                 }
    -00267         }
    -00268         return 0;
    -00269 }
    +00234 Version::Version(int major, int minor, int revision, int build, int flags) : Major(major), Minor(minor), Revision(revision), Build(build), Flags(flags) { };
    +00235 
    +00236 // admin is a simple class for holding a server's administrative info
    +00237 
    +00238 Admin::Admin(std::string name, std::string email, std::string nick) : Name(name), Email(email), Nick(nick) { };
    +00239 
    +00240 Request::Request(char* anydata, Module* src, Module* dst) : data(anydata), source(src), dest(dst) { };
    +00241 
    +00242 char* Request::GetData()
    +00243 {
    +00244         return this->data;
    +00245 }
    +00246 
    +00247 Module* Request::GetSource()
    +00248 {
    +00249         return this->source;
    +00250 }
    +00251 
    +00252 Module* Request::GetDest()
    +00253 {
    +00254         return this->dest;
    +00255 }
    +00256 
    +00257 char* Request::Send()
    +00258 {
    +00259         if (this->dest)
    +00260         {
    +00261                 return dest->OnRequest(this);
    +00262         }
    +00263         else
    +00264         {
    +00265                 return NULL;
    +00266         }
    +00267 }
    +00268 
    +00269 Event::Event(char* anydata, Module* src, std::string eventid) : data(anydata), source(src), id(eventid) { };
     00270 
    -00271 // returns number of parameters for a custom mode when it is switched on
    -00272 int ModeDefinedOff(char modechar, int type)
    -00273 {
    -00274         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00275         {
    -00276                 if ((i->modechar == modechar) && (i->type == type))
    -00277                 {
    -00278                         return i->params_when_off;
    -00279                 }
    -00280         }
    -00281         return 0;
    -00282 }
    -00283 
    -00284 // returns true if an extended mode character is in use
    -00285 bool DoAddExtendedMode(char modechar, int type, bool requires_oper, int params_on, int params_off)
    -00286 {
    -00287         if (ModeDefined(modechar,type)) {
    -00288                 return false;
    -00289         }
    -00290         EMode.push_back(ExtMode(modechar,type,requires_oper,params_on,params_off));
    -00291         return true;
    -00292 }
    -00293 
    -00294 // turns a mode into a listmode
    -00295 void ModeMakeList(char modechar)
    -00296 {
    -00297         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00298         {
    -00299                 if ((i->modechar == modechar) && (i->type == MT_CHANNEL))
    -00300                 {
    -00301                         i->list = true;
    -00302                         return;
    -00303                 }
    -00304         }
    -00305         return;
    -00306 }
    -00307 
    -00308 // version is a simple class for holding a modules version number
    -00309 
    -00310 Version::Version(int major, int minor, int revision, int build, int flags) : Major(major), Minor(minor), Revision(revision), Build(build), Flags(flags) { };
    -00311 
    -00312 // admin is a simple class for holding a server's administrative info
    -00313 
    -00314 Admin::Admin(std::string name, std::string email, std::string nick) : Name(name), Email(email), Nick(nick) { };
    -00315 
    -00316 Request::Request(char* anydata, Module* src, Module* dst) : data(anydata), source(src), dest(dst) { };
    -00317 
    -00318 char* Request::GetData()
    -00319 {
    -00320         return this->data;
    -00321 }
    -00322 
    -00323 Module* Request::GetSource()
    -00324 {
    -00325         return this->source;
    -00326 }
    -00327 
    -00328 Module* Request::GetDest()
    -00329 {
    -00330         return this->dest;
    -00331 }
    -00332 
    -00333 char* Request::Send()
    -00334 {
    -00335         if (this->dest)
    -00336         {
    -00337                 return dest->OnRequest(this);
    -00338         }
    -00339         else
    -00340         {
    -00341                 return NULL;
    -00342         }
    -00343 }
    -00344 
    -00345 Event::Event(char* anydata, Module* src, std::string eventid) : data(anydata), source(src), id(eventid) { };
    -00346 
    -00347 char* Event::GetData()
    -00348 {
    -00349         return this->data;
    -00350 }
    -00351 
    -00352 Module* Event::GetSource()
    -00353 {
    -00354         return this->source;
    -00355 }
    -00356 
    -00357 char* Event::Send()
    -00358 {
    -00359         FOREACH_MOD OnEvent(this);
    -00360         return NULL;
    +00271 char* Event::GetData()
    +00272 {
    +00273         return this->data;
    +00274 }
    +00275 
    +00276 Module* Event::GetSource()
    +00277 {
    +00278         return this->source;
    +00279 }
    +00280 
    +00281 char* Event::Send()
    +00282 {
    +00283         FOREACH_MOD OnEvent(this);
    +00284         return NULL;
    +00285 }
    +00286 
    +00287 std::string Event::GetEventID()
    +00288 {
    +00289         return this->id;
    +00290 }
    +00291 
    +00292 
    +00293 // These declarations define the behavours of the base class Module (which does nothing at all)
    +00294                 Module::Module() { }
    +00295                 Module::~Module() { }
    +00296 void            Module::OnUserConnect(userrec* user) { }
    +00297 void            Module::OnUserQuit(userrec* user) { }
    +00298 void            Module::OnUserDisconnect(userrec* user) { }
    +00299 void            Module::OnUserJoin(userrec* user, chanrec* channel) { }
    +00300 void            Module::OnUserPart(userrec* user, chanrec* channel) { }
    +00301 void            Module::OnPacketTransmit(std::string &data, std::string serv) { }
    +00302 void            Module::OnPacketReceive(std::string &data, std::string serv) { }
    +00303 void            Module::OnRehash() { }
    +00304 void            Module::OnServerRaw(std::string &raw, bool inbound, userrec* user) { }
    +00305 int             Module::OnUserPreJoin(userrec* user, chanrec* chan, const char* cname) { return 0; }
    +00306 int             Module::OnExtendedMode(userrec* user, void* target, char modechar, int type, bool mode_on, string_list &params) { return false; }
    +00307 Version         Module::GetVersion() { return Version(1,0,0,0,VF_VENDOR); }
    +00308 void            Module::OnOper(userrec* user) { };
    +00309 void            Module::OnInfo(userrec* user) { };
    +00310 void            Module::OnWhois(userrec* source, userrec* dest) { };
    +00311 int             Module::OnUserPreInvite(userrec* source,userrec* dest,chanrec* channel) { return 0; };
    +00312 int             Module::OnUserPreMessage(userrec* user,void* dest,int target_type, std::string &text) { return 0; };
    +00313 int             Module::OnUserPreNotice(userrec* user,void* dest,int target_type, std::string &text) { return 0; };
    +00314 int             Module::OnUserPreNick(userrec* user, std::string newnick) { return 0; };
    +00315 void            Module::OnUserPostNick(userrec* user, std::string oldnick) { };
    +00316 int             Module::OnAccessCheck(userrec* source,userrec* dest,chanrec* channel,int access_type) { return ACR_DEFAULT; };
    +00317 string_list     Module::OnUserSync(userrec* user) { string_list empty; return empty; }
    +00318 string_list     Module::OnChannelSync(chanrec* chan) { string_list empty; return empty; }
    +00319 void            Module::On005Numeric(std::string &output) { };
    +00320 int             Module::OnKill(userrec* source, userrec* dest, std::string reason) { return 0; };
    +00321 void            Module::OnLoadModule(Module* mod,std::string name) { };
    +00322 void            Module::OnBackgroundTimer(time_t curtime) { };
    +00323 void            Module::OnSendList(userrec* user, chanrec* channel, char mode) { };
    +00324 int             Module::OnPreCommand(std::string command, char **parameters, int pcnt, userrec *user) { return 0; };
    +00325 bool            Module::OnCheckReady(userrec* user) { return true; };
    +00326 void            Module::OnUserRegister(userrec* user) { };
    +00327 int             Module::OnUserPreKick(userrec* source, userrec* user, chanrec* chan, std::string reason) { return 0; };
    +00328 void            Module::OnUserKick(userrec* source, userrec* user, chanrec* chan, std::string reason) { };
    +00329 int             Module::OnRawMode(userrec* user, chanrec* chan, char mode, std::string param, bool adding, int pcnt) { return 0; };
    +00330 int             Module::OnCheckInvite(userrec* user, chanrec* chan) { return 0; };
    +00331 int             Module::OnCheckKey(userrec* user, chanrec* chan, std::string keygiven) { return 0; };
    +00332 int             Module::OnCheckLimit(userrec* user, chanrec* chan) { return 0; };
    +00333 int             Module::OnCheckBan(userrec* user, chanrec* chan) { return 0; };
    +00334 void            Module::OnStats(char symbol) { };
    +00335 int             Module::OnChangeLocalUserHost(userrec* user, std::string newhost) { return 0; };
    +00336 int             Module::OnChangeLocalUserGECOS(userrec* user, std::string newhost) { return 0; };
    +00337 int             Module::OnLocalTopicChange(userrec* user, chanrec* chan, std::string topic) { return 0; };
    +00338 int             Module::OnMeshToken(char token,string_list params,serverrec* source,serverrec* reply, std::string tcp_host,std::string ipaddr,int port) { return 0; };
    +00339 void            Module::OnEvent(Event* event) { return; };
    +00340 char*           Module::OnRequest(Request* request) { return NULL; };
    +00341 int             Module::OnOperCompare(std::string password, std::string input) { return 0; };
    +00342 void            Module::OnGlobalOper(userrec* user) { };
    +00343 void            Module::OnGlobalConnect(userrec* user) { };
    +00344 int             Module::OnAddBan(userrec* source, chanrec* channel,std::string banmask) { return 0; };
    +00345 int             Module::OnDelBan(userrec* source, chanrec* channel,std::string banmask) { return 0; };
    +00346 void            Module::OnRawSocketAccept(int fd, std::string ip, int localport) { };
    +00347 int             Module::OnRawSocketWrite(int fd, char* buffer, int count) { return 0; };
    +00348 void            Module::OnRawSocketClose(int fd) { };
    +00349 int             Module::OnRawSocketRead(int fd, char* buffer, unsigned int count, int &readresult) { return 0; };
    +00350 
    +00351 // server is a wrapper class that provides methods to all of the C-style
    +00352 // exports in the core
    +00353 //
    +00354 
    +00355 Server::Server()
    +00356 {
    +00357 }
    +00358 
    +00359 Server::~Server()
    +00360 {
     00361 }
     00362 
    -00363 std::string Event::GetEventID()
    +00363 void Server::SendOpers(std::string s)
     00364 {
    -00365         return this->id;
    +00365         WriteOpers("%s",s.c_str());
     00366 }
     00367 
    -00368 
    -00369 // These declarations define the behavours of the base class Module (which does nothing at all)
    -00370                 Module::Module() { }
    -00371                 Module::~Module() { }
    -00372 void            Module::OnUserConnect(userrec* user) { }
    -00373 void            Module::OnUserQuit(userrec* user) { }
    -00374 void            Module::OnUserDisconnect(userrec* user) { }
    -00375 void            Module::OnUserJoin(userrec* user, chanrec* channel) { }
    -00376 void            Module::OnUserPart(userrec* user, chanrec* channel) { }
    -00377 void            Module::OnPacketTransmit(std::string &data, std::string serv) { }
    -00378 void            Module::OnPacketReceive(std::string &data, std::string serv) { }
    -00379 void            Module::OnRehash() { }
    -00380 void            Module::OnServerRaw(std::string &raw, bool inbound, userrec* user) { }
    -00381 int             Module::OnUserPreJoin(userrec* user, chanrec* chan, const char* cname) { return 0; }
    -00382 int             Module::OnExtendedMode(userrec* user, void* target, char modechar, int type, bool mode_on, string_list &params) { return false; }
    -00383 Version         Module::GetVersion() { return Version(1,0,0,0,VF_VENDOR); }
    -00384 void            Module::OnOper(userrec* user) { };
    -00385 void            Module::OnInfo(userrec* user) { };
    -00386 void            Module::OnWhois(userrec* source, userrec* dest) { };
    -00387 int             Module::OnUserPreInvite(userrec* source,userrec* dest,chanrec* channel) { return 0; };
    -00388 int             Module::OnUserPreMessage(userrec* user,void* dest,int target_type, std::string &text) { return 0; };
    -00389 int             Module::OnUserPreNotice(userrec* user,void* dest,int target_type, std::string &text) { return 0; };
    -00390 int             Module::OnUserPreNick(userrec* user, std::string newnick) { return 0; };
    -00391 void            Module::OnUserPostNick(userrec* user, std::string oldnick) { };
    -00392 int             Module::OnAccessCheck(userrec* source,userrec* dest,chanrec* channel,int access_type) { return ACR_DEFAULT; };
    -00393 string_list     Module::OnUserSync(userrec* user) { string_list empty; return empty; }
    -00394 string_list     Module::OnChannelSync(chanrec* chan) { string_list empty; return empty; }
    -00395 void            Module::On005Numeric(std::string &output) { };
    -00396 int             Module::OnKill(userrec* source, userrec* dest, std::string reason) { return 0; };
    -00397 void            Module::OnLoadModule(Module* mod,std::string name) { };
    -00398 void            Module::OnBackgroundTimer(time_t curtime) { };
    -00399 void            Module::OnSendList(userrec* user, chanrec* channel, char mode) { };
    -00400 int             Module::OnPreCommand(std::string command, char **parameters, int pcnt, userrec *user) { return 0; };
    -00401 bool            Module::OnCheckReady(userrec* user) { return true; };
    -00402 void            Module::OnUserRegister(userrec* user) { };
    -00403 int             Module::OnUserPreKick(userrec* source, userrec* user, chanrec* chan, std::string reason) { return 0; };
    -00404 void            Module::OnUserKick(userrec* source, userrec* user, chanrec* chan, std::string reason) { };
    -00405 int             Module::OnRawMode(userrec* user, chanrec* chan, char mode, std::string param, bool adding, int pcnt) { return 0; };
    -00406 int             Module::OnCheckInvite(userrec* user, chanrec* chan) { return 0; };
    -00407 int             Module::OnCheckKey(userrec* user, chanrec* chan, std::string keygiven) { return 0; };
    -00408 int             Module::OnCheckLimit(userrec* user, chanrec* chan) { return 0; };
    -00409 int             Module::OnCheckBan(userrec* user, chanrec* chan) { return 0; };
    -00410 void            Module::OnStats(char symbol) { };
    -00411 int             Module::OnChangeLocalUserHost(userrec* user, std::string newhost) { return 0; };
    -00412 int             Module::OnChangeLocalUserGECOS(userrec* user, std::string newhost) { return 0; };
    -00413 int             Module::OnLocalTopicChange(userrec* user, chanrec* chan, std::string topic) { return 0; };
    -00414 int             Module::OnMeshToken(char token,string_list params,serverrec* source,serverrec* reply, std::string tcp_host,std::string ipaddr,int port) { return 0; };
    -00415 void            Module::OnEvent(Event* event) { return; };
    -00416 char*           Module::OnRequest(Request* request) { return NULL; };
    -00417 int             Module::OnOperCompare(std::string password, std::string input) { return 0; };
    -00418 void            Module::OnGlobalOper(userrec* user) { };
    -00419 void            Module::OnGlobalConnect(userrec* user) { };
    -00420 int             Module::OnAddBan(userrec* source, chanrec* channel,std::string banmask) { return 0; };
    -00421 int             Module::OnDelBan(userrec* source, chanrec* channel,std::string banmask) { return 0; };
    -00422 void            Module::OnRawSocketAccept(int fd, std::string ip, int localport) { };
    -00423 int             Module::OnRawSocketWrite(int fd, char* buffer, int count) { return 0; };
    -00424 void            Module::OnRawSocketClose(int fd) { };
    -00425 int             Module::OnRawSocketRead(int fd, char* buffer, unsigned int count, int &readresult) { return 0; };
    -00426 
    -00427 // server is a wrapper class that provides methods to all of the C-style
    -00428 // exports in the core
    -00429 //
    -00430 
    -00431 Server::Server()
    -00432 {
    -00433 }
    -00434 
    -00435 Server::~Server()
    -00436 {
    -00437 }
    -00438 
    -00439 void Server::SendOpers(std::string s)
    -00440 {
    -00441         WriteOpers("%s",s.c_str());
    -00442 }
    -00443 
    -00444 bool Server::MatchText(std::string sliteral, std::string spattern)
    -00445 {
    -00446         char literal[MAXBUF],pattern[MAXBUF];
    -00447         strlcpy(literal,sliteral.c_str(),MAXBUF);
    -00448         strlcpy(pattern,spattern.c_str(),MAXBUF);
    -00449         return match(literal,pattern);
    -00450 }
    -00451 
    -00452 void Server::SendToModeMask(std::string modes, int flags, std::string text)
    -00453 {
    -00454         WriteMode(modes.c_str(),flags,"%s",text.c_str());
    -00455 }
    -00456 
    -00457 chanrec* Server::JoinUserToChannel(userrec* user, std::string cname, std::string key)
    -00458 {
    -00459         return add_channel(user,cname.c_str(),key.c_str(),false);
    -00460 }
    -00461 
    -00462 chanrec* Server::PartUserFromChannel(userrec* user, std::string cname, std::string reason)
    -00463 {
    -00464         return del_channel(user,cname.c_str(),reason.c_str(),false);
    +00368 bool Server::MatchText(std::string sliteral, std::string spattern)
    +00369 {
    +00370         char literal[MAXBUF],pattern[MAXBUF];
    +00371         strlcpy(literal,sliteral.c_str(),MAXBUF);
    +00372         strlcpy(pattern,spattern.c_str(),MAXBUF);
    +00373         return match(literal,pattern);
    +00374 }
    +00375 
    +00376 void Server::SendToModeMask(std::string modes, int flags, std::string text)
    +00377 {
    +00378         WriteMode(modes.c_str(),flags,"%s",text.c_str());
    +00379 }
    +00380 
    +00381 chanrec* Server::JoinUserToChannel(userrec* user, std::string cname, std::string key)
    +00382 {
    +00383         return add_channel(user,cname.c_str(),key.c_str(),false);
    +00384 }
    +00385 
    +00386 chanrec* Server::PartUserFromChannel(userrec* user, std::string cname, std::string reason)
    +00387 {
    +00388         return del_channel(user,cname.c_str(),reason.c_str(),false);
    +00389 }
    +00390 
    +00391 chanuserlist Server::GetUsers(chanrec* chan)
    +00392 {
    +00393         chanuserlist userl;
    +00394         userl.clear();
    +00395         std::vector<char*> *list = chan->GetUsers();
    +00396         for (std::vector<char*>::iterator i = list->begin(); i != list->end(); i++)
    +00397         {
    +00398                 char* o = *i;
    +00399                 userl.push_back((userrec*)o);
    +00400         }
    +00401         return userl;
    +00402 }
    +00403 void Server::ChangeUserNick(userrec* user, std::string nickname)
    +00404 {
    +00405         force_nickchange(user,nickname.c_str());
    +00406 }
    +00407 
    +00408 void Server::QuitUser(userrec* user, std::string reason)
    +00409 {
    +00410         kill_link(user,reason.c_str());
    +00411 }
    +00412 
    +00413 bool Server::IsUlined(std::string server)
    +00414 {
    +00415         return is_uline(server.c_str());
    +00416 }
    +00417 
    +00418 void Server::CallCommandHandler(std::string commandname, char** parameters, int pcnt, userrec* user)
    +00419 {
    +00420         call_handler(commandname.c_str(),parameters,pcnt,user);
    +00421 }
    +00422 
    +00423 void Server::Log(int level, std::string s)
    +00424 {
    +00425         log(level,"%s",s.c_str());
    +00426 }
    +00427 
    +00428 void Server::AddCommand(char* cmd, handlerfunc f, char flags, int minparams, char* source)
    +00429 {
    +00430         createcommand(cmd,f,flags,minparams,source);
    +00431 }
    +00432 
    +00433 void Server::SendMode(char **parameters, int pcnt, userrec *user)
    +00434 {
    +00435         server_mode(parameters,pcnt,user);
    +00436 }
    +00437 
    +00438 void Server::Send(int Socket, std::string s)
    +00439 {
    +00440         Write(Socket,"%s",s.c_str());
    +00441 }
    +00442 
    +00443 void Server::SendServ(int Socket, std::string s)
    +00444 {
    +00445         WriteServ(Socket,"%s",s.c_str());
    +00446 }
    +00447 
    +00448 void Server::SendFrom(int Socket, userrec* User, std::string s)
    +00449 {
    +00450         WriteFrom(Socket,User,"%s",s.c_str());
    +00451 }
    +00452 
    +00453 void Server::SendTo(userrec* Source, userrec* Dest, std::string s)
    +00454 {
    +00455         if (!Source)
    +00456         {
    +00457                 // if source is NULL, then the message originates from the local server
    +00458                 Write(Dest->fd,":%s %s",this->GetServerName().c_str(),s.c_str());
    +00459         }
    +00460         else
    +00461         {
    +00462                 // otherwise it comes from the user specified
    +00463                 WriteTo(Source,Dest,"%s",s.c_str());
    +00464         }
     00465 }
     00466 
    -00467 chanuserlist Server::GetUsers(chanrec* chan)
    +00467 void Server::SendChannelServerNotice(std::string ServName, chanrec* Channel, std::string text)
     00468 {
    -00469         chanuserlist userl;
    -00470         userl.clear();
    -00471         std::vector<char*> *list = chan->GetUsers();
    -00472         for (std::vector<char*>::iterator i = list->begin(); i != list->end(); i++)
    -00473         {
    -00474                 char* o = *i;
    -00475                 userl.push_back((userrec*)o);
    -00476         }
    -00477         return userl;
    -00478 }
    -00479 void Server::ChangeUserNick(userrec* user, std::string nickname)
    -00480 {
    -00481         force_nickchange(user,nickname.c_str());
    +00469         WriteChannelWithServ((char*)ServName.c_str(), Channel, "%s", text.c_str());
    +00470 }
    +00471 
    +00472 void Server::SendChannel(userrec* User, chanrec* Channel, std::string s,bool IncludeSender)
    +00473 {
    +00474         if (IncludeSender)
    +00475         {
    +00476                 WriteChannel(Channel,User,"%s",s.c_str());
    +00477         }
    +00478         else
    +00479         {
    +00480                 ChanExceptSender(Channel,User,"%s",s.c_str());
    +00481         }
     00482 }
     00483 
    -00484 void Server::QuitUser(userrec* user, std::string reason)
    +00484 bool Server::CommonChannels(userrec* u1, userrec* u2)
     00485 {
    -00486         kill_link(user,reason.c_str());
    +00486         return (common_channels(u1,u2) != 0);
     00487 }
     00488 
    -00489 bool Server::IsUlined(std::string server)
    +00489 void Server::SendCommon(userrec* User, std::string text,bool IncludeSender)
     00490 {
    -00491         return is_uline(server.c_str());
    -00492 }
    -00493 
    -00494 void Server::CallCommandHandler(std::string commandname, char** parameters, int pcnt, userrec* user)
    -00495 {
    -00496         call_handler(commandname.c_str(),parameters,pcnt,user);
    -00497 }
    -00498 
    -00499 void Server::Log(int level, std::string s)
    -00500 {
    -00501         log(level,"%s",s.c_str());
    -00502 }
    -00503 
    -00504 void Server::AddCommand(char* cmd, handlerfunc f, char flags, int minparams, char* source)
    -00505 {
    -00506         createcommand(cmd,f,flags,minparams,source);
    -00507 }
    -00508 
    -00509 void Server::SendMode(char **parameters, int pcnt, userrec *user)
    -00510 {
    -00511         server_mode(parameters,pcnt,user);
    -00512 }
    -00513 
    -00514 void Server::Send(int Socket, std::string s)
    -00515 {
    -00516         Write(Socket,"%s",s.c_str());
    -00517 }
    -00518 
    -00519 void Server::SendServ(int Socket, std::string s)
    -00520 {
    -00521         WriteServ(Socket,"%s",s.c_str());
    -00522 }
    -00523 
    -00524 void Server::SendFrom(int Socket, userrec* User, std::string s)
    -00525 {
    -00526         WriteFrom(Socket,User,"%s",s.c_str());
    -00527 }
    -00528 
    -00529 void Server::SendTo(userrec* Source, userrec* Dest, std::string s)
    -00530 {
    -00531         if (!Source)
    -00532         {
    -00533                 // if source is NULL, then the message originates from the local server
    -00534                 Write(Dest->fd,":%s %s",this->GetServerName().c_str(),s.c_str());
    -00535         }
    -00536         else
    -00537         {
    -00538                 // otherwise it comes from the user specified
    -00539                 WriteTo(Source,Dest,"%s",s.c_str());
    -00540         }
    -00541 }
    -00542 
    -00543 void Server::SendChannelServerNotice(std::string ServName, chanrec* Channel, std::string text)
    -00544 {
    -00545         WriteChannelWithServ((char*)ServName.c_str(), Channel, "%s", text.c_str());
    -00546 }
    -00547 
    -00548 void Server::SendChannel(userrec* User, chanrec* Channel, std::string s,bool IncludeSender)
    -00549 {
    -00550         if (IncludeSender)
    -00551         {
    -00552                 WriteChannel(Channel,User,"%s",s.c_str());
    -00553         }
    -00554         else
    -00555         {
    -00556                 ChanExceptSender(Channel,User,"%s",s.c_str());
    -00557         }
    -00558 }
    -00559 
    -00560 bool Server::CommonChannels(userrec* u1, userrec* u2)
    -00561 {
    -00562         return (common_channels(u1,u2) != 0);
    -00563 }
    -00564 
    -00565 void Server::SendCommon(userrec* User, std::string text,bool IncludeSender)
    -00566 {
    -00567         if (IncludeSender)
    -00568         {
    -00569                 WriteCommon(User,"%s",text.c_str());
    -00570         }
    -00571         else
    -00572         {
    -00573                 WriteCommonExcept(User,"%s",text.c_str());
    -00574         }
    -00575 }
    -00576 
    -00577 void Server::SendWallops(userrec* User, std::string text)
    -00578 {
    -00579         WriteWallOps(User,false,"%s",text.c_str());
    -00580 }
    -00581 
    -00582 void Server::ChangeHost(userrec* user, std::string host)
    -00583 {
    -00584         ChangeDisplayedHost(user,host.c_str());
    -00585 }
    -00586 
    -00587 void Server::ChangeGECOS(userrec* user, std::string gecos)
    -00588 {
    -00589         ChangeName(user,gecos.c_str());
    -00590 }
    -00591 
    -00592 bool Server::IsNick(std::string nick)
    -00593 {
    -00594         return (isnick(nick.c_str()) != 0);
    -00595 }
    -00596 
    -00597 userrec* Server::FindNick(std::string nick)
    -00598 {
    -00599         return Find(nick);
    -00600 }
    -00601 
    -00602 userrec* Server::FindDescriptor(int socket)
    -00603 {
    -00604         return (socket < 65536 ? fd_ref_table[socket] : NULL);
    -00605 }
    -00606 
    -00607 chanrec* Server::FindChannel(std::string channel)
    -00608 {
    -00609         return FindChan(channel.c_str());
    -00610 }
    -00611 
    -00612 std::string Server::ChanMode(userrec* User, chanrec* Chan)
    -00613 {
    -00614         return cmode(User,Chan);
    -00615 }
    -00616 
    -00617 bool Server::IsOnChannel(userrec* User, chanrec* Chan)
    -00618 {
    -00619         return has_channel(User,Chan);
    -00620 }
    -00621 
    -00622 std::string Server::GetServerName()
    -00623 {
    -00624         return getservername();
    -00625 }
    -00626 
    -00627 std::string Server::GetNetworkName()
    -00628 {
    -00629         return getnetworkname();
    -00630 }
    -00631 
    -00632 Admin Server::GetAdmin()
    -00633 {
    -00634         return Admin(getadminname(),getadminemail(),getadminnick());
    -00635 }
    -00636 
    -00637 
    -00638 
    -00639 bool Server::AddExtendedMode(char modechar, int type, bool requires_oper, int params_when_on, int params_when_off)
    -00640 {
    -00641         if (((modechar >= 'A') && (modechar <= 'Z')) || ((modechar >= 'a') && (modechar <= 'z')))
    -00642         {
    -00643                 if (type == MT_SERVER)
    -00644                 {
    -00645                         log(DEBUG,"*** API ERROR *** Modes of type MT_SERVER are reserved for future expansion");
    -00646                         return false;
    -00647                 }
    -00648                 if (((params_when_on>0) || (params_when_off>0)) && (type == MT_CLIENT))
    -00649                 {
    -00650                         log(DEBUG,"*** API ERROR *** Parameters on MT_CLIENT modes are not supported");
    -00651                         return false;
    -00652                 }
    -00653                 if ((params_when_on>1) || (params_when_off>1))
    -00654                 {
    -00655                         log(DEBUG,"*** API ERROR *** More than one parameter for an MT_CHANNEL mode is not yet supported");
    -00656                         return false;
    -00657                 }
    -00658                 return DoAddExtendedMode(modechar,type,requires_oper,params_when_on,params_when_off);
    -00659         }
    -00660         else
    -00661         {
    -00662                 log(DEBUG,"*** API ERROR *** Muppet modechar detected.");
    -00663         }
    -00664         return false;
    -00665 }
    -00666 
    -00667 bool Server::AddExtendedListMode(char modechar)
    -00668 {
    -00669         bool res = DoAddExtendedMode(modechar,MT_CHANNEL,false,1,1);
    -00670         if (res)
    -00671                 ModeMakeList(modechar);
    -00672         return res;
    -00673 }
    -00674 
    -00675 int Server::CountUsers(chanrec* c)
    -00676 {
    -00677         return usercount(c);
    -00678 }
    -00679 
    -00680 
    -00681 bool Server::UserToPseudo(userrec* user,std::string message)
    -00682 {
    -00683         unsigned int old_fd = user->fd;
    -00684         user->fd = FD_MAGIC_NUMBER;
    -00685         user->ClearBuffer();
    -00686         Write(old_fd,"ERROR :Closing link (%s@%s) [%s]",user->ident,user->host,message.c_str());
    -00687 #ifdef USE_KQUEUE
    -00688         struct kevent ke;
    -00689         EV_SET(&ke, old_fd, EVFILT_READ, EV_DELETE, 0, 0, NULL);
    -00690         int i = kevent(kq, &ke, 1, 0, 0, NULL);
    -00691         if (i == -1)
    -00692         {
    -00693                 log(DEBUG,"kqueue: Failed to remove user from queue!");
    -00694         }
    -00695 #endif
    -00696         shutdown(old_fd,2);
    -00697         close(old_fd);
    -00698 }
    -00699 
    -00700 bool Server::PseudoToUser(userrec* alive,userrec* zombie,std::string message)
    -00701 {
    -00702         zombie->fd = alive->fd;
    -00703         alive->fd = FD_MAGIC_NUMBER;
    -00704         alive->ClearBuffer();
    -00705         Write(zombie->fd,":%s!%s@%s NICK %s",alive->nick,alive->ident,alive->host,zombie->nick);
    -00706         kill_link(alive,message.c_str());
    -00707         fd_ref_table[zombie->fd] = zombie;
    -00708         for (int i = 0; i != MAXCHANS; i++)
    -00709         {
    -00710                 if (zombie->chans[i].channel != NULL)
    -00711                 {
    -00712                         if (zombie->chans[i].channel->name)
    -00713                         {
    -00714                                 chanrec* Ptr = zombie->chans[i].channel;
    -00715                                 WriteFrom(zombie->fd,zombie,"JOIN %s",Ptr->name);
    -00716                                 if (Ptr->topicset)
    -00717                                 {
    -00718                                         WriteServ(zombie->fd,"332 %s %s :%s", zombie->nick, Ptr->name, Ptr->topic);
    -00719                                         WriteServ(zombie->fd,"333 %s %s %s %d", zombie->nick, Ptr->name, Ptr->setby, Ptr->topicset);
    -00720                                 }
    -00721                                 userlist(zombie,Ptr);
    -00722                                 WriteServ(zombie->fd,"366 %s %s :End of /NAMES list.", zombie->nick, Ptr->name);
    -00723 
    -00724                         }
    -00725                 }
    -00726         }
    -00727 
    -00728 }
    -00729 
    -00730 void Server::AddGLine(long duration, std::string source, std::string reason, std::string hostmask)
    -00731 {
    -00732         add_gline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
    -00733 }
    -00734 
    -00735 void Server::AddQLine(long duration, std::string source, std::string reason, std::string nickname)
    -00736 {
    -00737         add_qline(duration, source.c_str(), reason.c_str(), nickname.c_str());
    -00738 }
    +00491         if (IncludeSender)
    +00492         {
    +00493                 WriteCommon(User,"%s",text.c_str());
    +00494         }
    +00495         else
    +00496         {
    +00497                 WriteCommonExcept(User,"%s",text.c_str());
    +00498         }
    +00499 }
    +00500 
    +00501 void Server::SendWallops(userrec* User, std::string text)
    +00502 {
    +00503         WriteWallOps(User,false,"%s",text.c_str());
    +00504 }
    +00505 
    +00506 void Server::ChangeHost(userrec* user, std::string host)
    +00507 {
    +00508         ChangeDisplayedHost(user,host.c_str());
    +00509 }
    +00510 
    +00511 void Server::ChangeGECOS(userrec* user, std::string gecos)
    +00512 {
    +00513         ChangeName(user,gecos.c_str());
    +00514 }
    +00515 
    +00516 bool Server::IsNick(std::string nick)
    +00517 {
    +00518         return (isnick(nick.c_str()) != 0);
    +00519 }
    +00520 
    +00521 userrec* Server::FindNick(std::string nick)
    +00522 {
    +00523         return Find(nick);
    +00524 }
    +00525 
    +00526 userrec* Server::FindDescriptor(int socket)
    +00527 {
    +00528         return (socket < 65536 ? fd_ref_table[socket] : NULL);
    +00529 }
    +00530 
    +00531 chanrec* Server::FindChannel(std::string channel)
    +00532 {
    +00533         return FindChan(channel.c_str());
    +00534 }
    +00535 
    +00536 std::string Server::ChanMode(userrec* User, chanrec* Chan)
    +00537 {
    +00538         return cmode(User,Chan);
    +00539 }
    +00540 
    +00541 bool Server::IsOnChannel(userrec* User, chanrec* Chan)
    +00542 {
    +00543         return has_channel(User,Chan);
    +00544 }
    +00545 
    +00546 std::string Server::GetServerName()
    +00547 {
    +00548         return getservername();
    +00549 }
    +00550 
    +00551 std::string Server::GetNetworkName()
    +00552 {
    +00553         return getnetworkname();
    +00554 }
    +00555 
    +00556 std::string Server::GetServerDescription()
    +00557 {
    +00558         return getserverdesc();
    +00559 }
    +00560 
    +00561 Admin Server::GetAdmin()
    +00562 {
    +00563         return Admin(getadminname(),getadminemail(),getadminnick());
    +00564 }
    +00565 
    +00566 
    +00567 
    +00568 bool Server::AddExtendedMode(char modechar, int type, bool requires_oper, int params_when_on, int params_when_off)
    +00569 {
    +00570         if (((modechar >= 'A') && (modechar <= 'Z')) || ((modechar >= 'a') && (modechar <= 'z')))
    +00571         {
    +00572                 if (type == MT_SERVER)
    +00573                 {
    +00574                         log(DEBUG,"*** API ERROR *** Modes of type MT_SERVER are reserved for future expansion");
    +00575                         return false;
    +00576                 }
    +00577                 if (((params_when_on>0) || (params_when_off>0)) && (type == MT_CLIENT))
    +00578                 {
    +00579                         log(DEBUG,"*** API ERROR *** Parameters on MT_CLIENT modes are not supported");
    +00580                         return false;
    +00581                 }
    +00582                 if ((params_when_on>1) || (params_when_off>1))
    +00583                 {
    +00584                         log(DEBUG,"*** API ERROR *** More than one parameter for an MT_CHANNEL mode is not yet supported");
    +00585                         return false;
    +00586                 }
    +00587                 return DoAddExtendedMode(modechar,type,requires_oper,params_when_on,params_when_off);
    +00588         }
    +00589         else
    +00590         {
    +00591                 log(DEBUG,"*** API ERROR *** Muppet modechar detected.");
    +00592         }
    +00593         return false;
    +00594 }
    +00595 
    +00596 bool Server::AddExtendedListMode(char modechar)
    +00597 {
    +00598         bool res = DoAddExtendedMode(modechar,MT_CHANNEL,false,1,1);
    +00599         if (res)
    +00600                 ModeMakeList(modechar);
    +00601         return res;
    +00602 }
    +00603 
    +00604 int Server::CountUsers(chanrec* c)
    +00605 {
    +00606         return usercount(c);
    +00607 }
    +00608 
    +00609 
    +00610 bool Server::UserToPseudo(userrec* user,std::string message)
    +00611 {
    +00612         unsigned int old_fd = user->fd;
    +00613         user->fd = FD_MAGIC_NUMBER;
    +00614         user->ClearBuffer();
    +00615         Write(old_fd,"ERROR :Closing link (%s@%s) [%s]",user->ident,user->host,message.c_str());
    +00616 #ifdef USE_KQUEUE
    +00617         struct kevent ke;
    +00618         EV_SET(&ke, old_fd, EVFILT_READ, EV_DELETE, 0, 0, NULL);
    +00619         int i = kevent(kq, &ke, 1, 0, 0, NULL);
    +00620         if (i == -1)
    +00621         {
    +00622                 log(DEBUG,"kqueue: Failed to remove user from queue!");
    +00623         }
    +00624 #endif
    +00625         shutdown(old_fd,2);
    +00626         close(old_fd);
    +00627 }
    +00628 
    +00629 bool Server::PseudoToUser(userrec* alive,userrec* zombie,std::string message)
    +00630 {
    +00631         zombie->fd = alive->fd;
    +00632         alive->fd = FD_MAGIC_NUMBER;
    +00633         alive->ClearBuffer();
    +00634         Write(zombie->fd,":%s!%s@%s NICK %s",alive->nick,alive->ident,alive->host,zombie->nick);
    +00635         kill_link(alive,message.c_str());
    +00636         fd_ref_table[zombie->fd] = zombie;
    +00637         for (int i = 0; i != MAXCHANS; i++)
    +00638         {
    +00639                 if (zombie->chans[i].channel != NULL)
    +00640                 {
    +00641                         if (zombie->chans[i].channel->name)
    +00642                         {
    +00643                                 chanrec* Ptr = zombie->chans[i].channel;
    +00644                                 WriteFrom(zombie->fd,zombie,"JOIN %s",Ptr->name);
    +00645                                 if (Ptr->topicset)
    +00646                                 {
    +00647                                         WriteServ(zombie->fd,"332 %s %s :%s", zombie->nick, Ptr->name, Ptr->topic);
    +00648                                         WriteServ(zombie->fd,"333 %s %s %s %d", zombie->nick, Ptr->name, Ptr->setby, Ptr->topicset);
    +00649                                 }
    +00650                                 userlist(zombie,Ptr);
    +00651                                 WriteServ(zombie->fd,"366 %s %s :End of /NAMES list.", zombie->nick, Ptr->name);
    +00652 
    +00653                         }
    +00654                 }
    +00655         }
    +00656 
    +00657 }
    +00658 
    +00659 void Server::AddGLine(long duration, std::string source, std::string reason, std::string hostmask)
    +00660 {
    +00661         add_gline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
    +00662 }
    +00663 
    +00664 void Server::AddQLine(long duration, std::string source, std::string reason, std::string nickname)
    +00665 {
    +00666         add_qline(duration, source.c_str(), reason.c_str(), nickname.c_str());
    +00667 }
    +00668 
    +00669 void Server::AddZLine(long duration, std::string source, std::string reason, std::string ipaddr)
    +00670 {
    +00671         add_zline(duration, source.c_str(), reason.c_str(), ipaddr.c_str());
    +00672 }
    +00673 
    +00674 void Server::AddKLine(long duration, std::string source, std::string reason, std::string hostmask)
    +00675 {
    +00676         add_kline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
    +00677 }
    +00678 
    +00679 void Server::AddELine(long duration, std::string source, std::string reason, std::string hostmask)
    +00680 {
    +00681         add_eline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
    +00682 }
    +00683 
    +00684 bool Server::DelGLine(std::string hostmask)
    +00685 {
    +00686         del_gline(hostmask.c_str());
    +00687 }
    +00688 
    +00689 bool Server::DelQLine(std::string nickname)
    +00690 {
    +00691         del_qline(nickname.c_str());
    +00692 }
    +00693 
    +00694 bool Server::DelZLine(std::string ipaddr)
    +00695 {
    +00696         del_zline(ipaddr.c_str());
    +00697 }
    +00698 
    +00699 bool Server::DelKLine(std::string hostmask)
    +00700 {
    +00701         del_kline(hostmask.c_str());
    +00702 }
    +00703 
    +00704 bool Server::DelELine(std::string hostmask)
    +00705 {
    +00706         del_eline(hostmask.c_str());
    +00707 }
    +00708 
    +00709 long Server::CalcDuration(std::string delta)
    +00710 {
    +00711         return duration(delta.c_str());
    +00712 }
    +00713 
    +00714 bool Server::IsValidMask(std::string mask)
    +00715 {
    +00716         const char* dest = mask.c_str();
    +00717         if (strchr(dest,'!')==0)
    +00718                 return false;
    +00719         if (strchr(dest,'@')==0)
    +00720                 return false;
    +00721         for (int i = 0; i < strlen(dest); i++)
    +00722                 if (dest[i] < 32)
    +00723                         return false;
    +00724         for (int i = 0; i < strlen(dest); i++)
    +00725                 if (dest[i] > 126)
    +00726                         return false;
    +00727         int c = 0;
    +00728         for (int i = 0; i < strlen(dest); i++)
    +00729                 if (dest[i] == '!')
    +00730                         c++;
    +00731         if (c>1)
    +00732                 return false;
    +00733         c = 0;
    +00734         for (int i = 0; i < strlen(dest); i++)
    +00735                 if (dest[i] == '@')
    +00736                         c++;
    +00737         if (c>1)
    +00738                 return false;
     00739 
    -00740 void Server::AddZLine(long duration, std::string source, std::string reason, std::string ipaddr)
    -00741 {
    -00742         add_zline(duration, source.c_str(), reason.c_str(), ipaddr.c_str());
    -00743 }
    -00744 
    -00745 void Server::AddKLine(long duration, std::string source, std::string reason, std::string hostmask)
    -00746 {
    -00747         add_kline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
    -00748 }
    -00749 
    -00750 void Server::AddELine(long duration, std::string source, std::string reason, std::string hostmask)
    -00751 {
    -00752         add_eline(duration, source.c_str(), reason.c_str(), hostmask.c_str());
    -00753 }
    -00754 
    -00755 bool Server::DelGLine(std::string hostmask)
    -00756 {
    -00757         del_gline(hostmask.c_str());
    -00758 }
    -00759 
    -00760 bool Server::DelQLine(std::string nickname)
    -00761 {
    -00762         del_qline(nickname.c_str());
    -00763 }
    -00764 
    -00765 bool Server::DelZLine(std::string ipaddr)
    -00766 {
    -00767         del_zline(ipaddr.c_str());
    -00768 }
    -00769 
    -00770 bool Server::DelKLine(std::string hostmask)
    -00771 {
    -00772         del_kline(hostmask.c_str());
    -00773 }
    -00774 
    -00775 bool Server::DelELine(std::string hostmask)
    -00776 {
    -00777         del_eline(hostmask.c_str());
    -00778 }
    -00779 
    -00780 long Server::CalcDuration(std::string delta)
    -00781 {
    -00782         return duration(delta.c_str());
    -00783 }
    -00784 
    -00785 bool Server::IsValidMask(std::string mask)
    -00786 {
    -00787         const char* dest = mask.c_str();
    -00788         if (strchr(dest,'!')==0)
    -00789                 return false;
    -00790         if (strchr(dest,'@')==0)
    -00791                 return false;
    -00792         for (int i = 0; i < strlen(dest); i++)
    -00793                 if (dest[i] < 32)
    -00794                         return false;
    -00795         for (int i = 0; i < strlen(dest); i++)
    -00796                 if (dest[i] > 126)
    -00797                         return false;
    -00798         int c = 0;
    -00799         for (int i = 0; i < strlen(dest); i++)
    -00800                 if (dest[i] == '!')
    -00801                         c++;
    -00802         if (c>1)
    -00803                 return false;
    -00804         c = 0;
    -00805         for (int i = 0; i < strlen(dest); i++)
    -00806                 if (dest[i] == '@')
    -00807                         c++;
    -00808         if (c>1)
    -00809                 return false;
    -00810 
    -00811         return true;
    -00812 }
    -00813 
    -00814 void Server::MeshSendAll(std::string text)
    -00815 {
    -00816         NetSendToAll((char*)text.c_str());
    -00817 }
    -00818 
    -00819 void Server::MeshSendCommon(userrec* user, std::string text)
    -00820 {
    -00821         if (user)
    -00822                 NetSendToCommon(user,(char*)text.c_str());
    -00823 }
    -00824 
    -00825 void Server::MeshSendAllAlive(std::string text)
    -00826 {
    -00827         NetSendToAllAlive((char*)text.c_str());
    -00828 }
    -00829 
    -00830 void Server::MeshSendUnicast(std::string destination, std::string text)
    -00831 {
    -00832         NetSendToOne((char*)destination.c_str(),(char*)text.c_str());
    -00833 }
    -00834 
    -00835 void Server::MeshSendAllExcept(std::string target, std::string text)
    -00836 {
    -00837         NetSendToAllExcept(target.c_str(),(char*)text.c_str());
    -00838 }
    -00839 
    -00840 bool Server::MeshCheckChan(chanrec *c,std::string servername)
    -00841 {
    -00842         if (c)
    -00843         {
    -00844                 return ChanAnyOnThisServer(c,(char*)servername.c_str());
    -00845         }
    -00846         else return false;
    -00847 }
    -00848 
    -00849 bool Server::MeshCheckCommon(userrec* u,std::string servername)
    -00850 {
    -00851         if (u)
    +00740         return true;
    +00741 }
    +00742 
    +00743 void Server::MeshSendAll(std::string text)
    +00744 {
    +00745         NetSendToAll((char*)text.c_str());
    +00746 }
    +00747 
    +00748 void Server::MeshSendCommon(userrec* user, std::string text)
    +00749 {
    +00750         if (user)
    +00751                 NetSendToCommon(user,(char*)text.c_str());
    +00752 }
    +00753 
    +00754 void Server::MeshSendAllAlive(std::string text)
    +00755 {
    +00756         NetSendToAllAlive((char*)text.c_str());
    +00757 }
    +00758 
    +00759 void Server::MeshSendUnicast(std::string destination, std::string text)
    +00760 {
    +00761         NetSendToOne((char*)destination.c_str(),(char*)text.c_str());
    +00762 }
    +00763 
    +00764 void Server::MeshSendAllExcept(std::string target, std::string text)
    +00765 {
    +00766         NetSendToAllExcept(target.c_str(),(char*)text.c_str());
    +00767 }
    +00768 
    +00769 bool Server::MeshCheckChan(chanrec *c,std::string servername)
    +00770 {
    +00771         if (c)
    +00772         {
    +00773                 return ChanAnyOnThisServer(c,(char*)servername.c_str());
    +00774         }
    +00775         else return false;
    +00776 }
    +00777 
    +00778 bool Server::MeshCheckCommon(userrec* u,std::string servername)
    +00779 {
    +00780         if (u)
    +00781         {
    +00782                 return CommonOnThisServer(u,(char*)servername.c_str());
    +00783         }
    +00784         else return false;
    +00785 }
    +00786 
    +00787 Module* Server::FindModule(std::string name)
    +00788 {
    +00789         for (int i = 0; i <= MODCOUNT; i++)
    +00790         {
    +00791                 if (module_names[i] == name)
    +00792                 {
    +00793                         return modules[i];
    +00794                 }
    +00795         }
    +00796         return NULL;
    +00797 }
    +00798 
    +00799 ConfigReader::ConfigReader()
    +00800 {
    +00801         this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out);
    +00802         this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out);
    +00803         this->readerror = LoadConf(CONFIG_FILE,this->cache,this->errorlog);
    +00804         if (!this->readerror)
    +00805                 this->error = CONF_FILE_NOT_FOUND;
    +00806 }
    +00807 
    +00808 
    +00809 ConfigReader::~ConfigReader()
    +00810 {
    +00811         if (this->cache)
    +00812                 delete this->cache;
    +00813         if (this->errorlog)
    +00814                 delete this->errorlog;
    +00815 }
    +00816 
    +00817 
    +00818 ConfigReader::ConfigReader(std::string filename)
    +00819 {
    +00820         this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out);
    +00821         this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out);
    +00822         this->readerror = LoadConf(filename.c_str(),this->cache,this->errorlog);
    +00823         if (!this->readerror)
    +00824                 this->error = CONF_FILE_NOT_FOUND;
    +00825 };
    +00826 
    +00827 std::string ConfigReader::ReadValue(std::string tag, std::string name, int index)
    +00828 {
    +00829         char val[MAXBUF];
    +00830         char t[MAXBUF];
    +00831         char n[MAXBUF];
    +00832         strlcpy(t,tag.c_str(),MAXBUF);
    +00833         strlcpy(n,name.c_str(),MAXBUF);
    +00834         int res = ReadConf(cache,t,n,index,val);
    +00835         if (!res)
    +00836         {
    +00837                 this->error = CONF_VALUE_NOT_FOUND;
    +00838                 return "";
    +00839         }
    +00840         return val;
    +00841 }
    +00842 
    +00843 bool ConfigReader::ReadFlag(std::string tag, std::string name, int index)
    +00844 {
    +00845         char val[MAXBUF];
    +00846         char t[MAXBUF];
    +00847         char n[MAXBUF];
    +00848         strlcpy(t,tag.c_str(),MAXBUF);
    +00849         strlcpy(n,name.c_str(),MAXBUF);
    +00850         int res = ReadConf(cache,t,n,index,val);
    +00851         if (!res)
     00852         {
    -00853                 return CommonOnThisServer(u,(char*)servername.c_str());
    -00854         }
    -00855         else return false;
    -00856 }
    -00857 
    -00858 Module* Server::FindModule(std::string name)
    -00859 {
    -00860         for (int i = 0; i <= MODCOUNT; i++)
    -00861         {
    -00862                 if (module_names[i] == name)
    -00863                 {
    -00864                         return modules[i];
    -00865                 }
    -00866         }
    -00867         return NULL;
    -00868 }
    -00869 
    -00870 ConfigReader::ConfigReader()
    -00871 {
    -00872         this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out);
    -00873         this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out);
    -00874         this->readerror = LoadConf(CONFIG_FILE,this->cache,this->errorlog);
    -00875         if (!this->readerror)
    -00876                 this->error = CONF_FILE_NOT_FOUND;
    -00877 }
    -00878 
    -00879 
    -00880 ConfigReader::~ConfigReader()
    -00881 {
    -00882         if (this->cache)
    -00883                 delete this->cache;
    -00884         if (this->errorlog)
    -00885                 delete this->errorlog;
    -00886 }
    -00887 
    +00853                 this->error = CONF_VALUE_NOT_FOUND;
    +00854                 return false;
    +00855         }
    +00856         std::string s = val;
    +00857         return ((s == "yes") || (s == "YES") || (s == "true") || (s == "TRUE") || (s == "1"));
    +00858 }
    +00859 
    +00860 long ConfigReader::ReadInteger(std::string tag, std::string name, int index, bool needs_unsigned)
    +00861 {
    +00862         char val[MAXBUF];
    +00863         char t[MAXBUF];
    +00864         char n[MAXBUF];
    +00865         strlcpy(t,tag.c_str(),MAXBUF);
    +00866         strlcpy(n,name.c_str(),MAXBUF);
    +00867         int res = ReadConf(cache,t,n,index,val);
    +00868         if (!res)
    +00869         {
    +00870                 this->error = CONF_VALUE_NOT_FOUND;
    +00871                 return 0;
    +00872         }
    +00873         for (int i = 0; i < strlen(val); i++)
    +00874         {
    +00875                 if (!isdigit(val[i]))
    +00876                 {
    +00877                         this->error = CONF_NOT_A_NUMBER;
    +00878                         return 0;
    +00879                 }
    +00880         }
    +00881         if ((needs_unsigned) && (atoi(val)<0))
    +00882         {
    +00883                 this->error = CONF_NOT_UNSIGNED;
    +00884                 return 0;
    +00885         }
    +00886         return atoi(val);
    +00887 }
     00888 
    -00889 ConfigReader::ConfigReader(std::string filename)
    +00889 long ConfigReader::GetError()
     00890 {
    -00891         this->cache = new std::stringstream(std::stringstream::in | std::stringstream::out);
    -00892         this->errorlog = new std::stringstream(std::stringstream::in | std::stringstream::out);
    -00893         this->readerror = LoadConf(filename.c_str(),this->cache,this->errorlog);
    -00894         if (!this->readerror)
    -00895                 this->error = CONF_FILE_NOT_FOUND;
    -00896 };
    -00897 
    -00898 std::string ConfigReader::ReadValue(std::string tag, std::string name, int index)
    -00899 {
    -00900         char val[MAXBUF];
    -00901         char t[MAXBUF];
    -00902         char n[MAXBUF];
    -00903         strlcpy(t,tag.c_str(),MAXBUF);
    -00904         strlcpy(n,name.c_str(),MAXBUF);
    -00905         int res = ReadConf(cache,t,n,index,val);
    -00906         if (!res)
    -00907         {
    -00908                 this->error = CONF_VALUE_NOT_FOUND;
    -00909                 return "";
    -00910         }
    -00911         return val;
    -00912 }
    -00913 
    -00914 bool ConfigReader::ReadFlag(std::string tag, std::string name, int index)
    -00915 {
    -00916         char val[MAXBUF];
    -00917         char t[MAXBUF];
    -00918         char n[MAXBUF];
    -00919         strlcpy(t,tag.c_str(),MAXBUF);
    -00920         strlcpy(n,name.c_str(),MAXBUF);
    -00921         int res = ReadConf(cache,t,n,index,val);
    -00922         if (!res)
    -00923         {
    -00924                 this->error = CONF_VALUE_NOT_FOUND;
    -00925                 return false;
    -00926         }
    -00927         std::string s = val;
    -00928         return ((s == "yes") || (s == "YES") || (s == "true") || (s == "TRUE") || (s == "1"));
    -00929 }
    -00930 
    -00931 long ConfigReader::ReadInteger(std::string tag, std::string name, int index, bool needs_unsigned)
    -00932 {
    -00933         char val[MAXBUF];
    -00934         char t[MAXBUF];
    -00935         char n[MAXBUF];
    -00936         strlcpy(t,tag.c_str(),MAXBUF);
    -00937         strlcpy(n,name.c_str(),MAXBUF);
    -00938         int res = ReadConf(cache,t,n,index,val);
    -00939         if (!res)
    -00940         {
    -00941                 this->error = CONF_VALUE_NOT_FOUND;
    -00942                 return 0;
    -00943         }
    -00944         for (int i = 0; i < strlen(val); i++)
    -00945         {
    -00946                 if (!isdigit(val[i]))
    -00947                 {
    -00948                         this->error = CONF_NOT_A_NUMBER;
    -00949                         return 0;
    -00950                 }
    -00951         }
    -00952         if ((needs_unsigned) && (atoi(val)<0))
    -00953         {
    -00954                 this->error = CONF_NOT_UNSIGNED;
    -00955                 return 0;
    -00956         }
    -00957         return atoi(val);
    -00958 }
    -00959 
    -00960 long ConfigReader::GetError()
    -00961 {
    -00962         long olderr = this->error;
    -00963         this->error = 0;
    -00964         return olderr;
    -00965 }
    -00966 
    -00967 void ConfigReader::DumpErrors(bool bail, userrec* user)
    -00968 {
    -00969         if (bail)
    -00970         {
    -00971                 printf("There were errors in your configuration:\n%s",errorlog->str().c_str());
    -00972                 exit(0);
    +00891         long olderr = this->error;
    +00892         this->error = 0;
    +00893         return olderr;
    +00894 }
    +00895 
    +00896 void ConfigReader::DumpErrors(bool bail, userrec* user)
    +00897 {
    +00898         if (bail)
    +00899         {
    +00900                 printf("There were errors in your configuration:\n%s",errorlog->str().c_str());
    +00901                 exit(0);
    +00902         }
    +00903         else
    +00904         {
    +00905                 char dataline[1024];
    +00906                 if (user)
    +00907                 {
    +00908                         WriteServ(user->fd,"NOTICE %s :There were errors in the configuration file:",user->nick);
    +00909                         while (!errorlog->eof())
    +00910                         {
    +00911                                 errorlog->getline(dataline,1024);
    +00912                                 WriteServ(user->fd,"NOTICE %s :%s",user->nick,dataline);
    +00913                         }
    +00914                 }
    +00915                 else
    +00916                 {
    +00917                         WriteOpers("There were errors in the configuration file:",user->nick);
    +00918                         while (!errorlog->eof())
    +00919                         {
    +00920                                 errorlog->getline(dataline,1024);
    +00921                                 WriteOpers(dataline);
    +00922                         }
    +00923                 }
    +00924                 return;
    +00925         }
    +00926 }
    +00927 
    +00928 
    +00929 int ConfigReader::Enumerate(std::string tag)
    +00930 {
    +00931         return EnumConf(cache,tag.c_str());
    +00932 }
    +00933 
    +00934 int ConfigReader::EnumerateValues(std::string tag, int index)
    +00935 {
    +00936         return EnumValues(cache, tag.c_str(), index);
    +00937 }
    +00938 
    +00939 bool ConfigReader::Verify()
    +00940 {
    +00941         return this->readerror;
    +00942 }
    +00943 
    +00944 
    +00945 FileReader::FileReader(std::string filename)
    +00946 {
    +00947         file_cache c;
    +00948         readfile(c,filename.c_str());
    +00949         this->fc = c;
    +00950 }
    +00951 
    +00952 FileReader::FileReader()
    +00953 {
    +00954 }
    +00955 
    +00956 void FileReader::LoadFile(std::string filename)
    +00957 {
    +00958         file_cache c;
    +00959         readfile(c,filename.c_str());
    +00960         this->fc = c;
    +00961 }
    +00962 
    +00963 
    +00964 FileReader::~FileReader()
    +00965 {
    +00966 }
    +00967 
    +00968 bool FileReader::Exists()
    +00969 {
    +00970         if (fc.size() == 0)
    +00971         {
    +00972                 return(false);
     00973         }
     00974         else
     00975         {
    -00976                 char dataline[1024];
    -00977                 if (user)
    -00978                 {
    -00979                         WriteServ(user->fd,"NOTICE %s :There were errors in the configuration file:",user->nick);
    -00980                         while (!errorlog->eof())
    -00981                         {
    -00982                                 errorlog->getline(dataline,1024);
    -00983                                 WriteServ(user->fd,"NOTICE %s :%s",user->nick,dataline);
    -00984                         }
    -00985                 }
    -00986                 else
    -00987                 {
    -00988                         WriteOpers("There were errors in the configuration file:",user->nick);
    -00989                         while (!errorlog->eof())
    -00990                         {
    -00991                                 errorlog->getline(dataline,1024);
    -00992                                 WriteOpers(dataline);
    -00993                         }
    -00994                 }
    -00995                 return;
    -00996         }
    -00997 }
    +00976                 return(true);
    +00977         }
    +00978 }
    +00979 
    +00980 std::string FileReader::GetLine(int x)
    +00981 {
    +00982         if ((x<0) || (x>fc.size()))
    +00983                 return "";
    +00984         return fc[x];
    +00985 }
    +00986 
    +00987 int FileReader::FileSize()
    +00988 {
    +00989         return fc.size();
    +00990 }
    +00991 
    +00992 
    +00993 std::vector<Module*> modules(255);
    +00994 std::vector<ircd_module*> factory(255);
    +00995 
    +00996 int MODCOUNT  = -1;
    +00997 
     00998 
    -00999 
    -01000 int ConfigReader::Enumerate(std::string tag)
    -01001 {
    -01002         return EnumConf(cache,tag.c_str());
    -01003 }
    -01004 
    -01005 int ConfigReader::EnumerateValues(std::string tag, int index)
    -01006 {
    -01007         return EnumValues(cache, tag.c_str(), index);
    -01008 }
    -01009 
    -01010 bool ConfigReader::Verify()
    -01011 {
    -01012         return this->readerror;
    -01013 }
    -01014 
    -01015 
    -01016 FileReader::FileReader(std::string filename)
    -01017 {
    -01018         file_cache c;
    -01019         readfile(c,filename.c_str());
    -01020         this->fc = c;
    -01021 }
    -01022 
    -01023 FileReader::FileReader()
    -01024 {
    -01025 }
    -01026 
    -01027 void FileReader::LoadFile(std::string filename)
    -01028 {
    -01029         file_cache c;
    -01030         readfile(c,filename.c_str());
    -01031         this->fc = c;
    -01032 }
    -01033 
    -01034 
    -01035 FileReader::~FileReader()
    -01036 {
    -01037 }
    -01038 
    -01039 bool FileReader::Exists()
    -01040 {
    -01041         if (fc.size() == 0)
    -01042         {
    -01043                 return(false);
    -01044         }
    -01045         else
    -01046         {
    -01047                 return(true);
    -01048         }
    -01049 }
    -01050 
    -01051 std::string FileReader::GetLine(int x)
    -01052 {
    -01053         if ((x<0) || (x>fc.size()))
    -01054                 return "";
    -01055         return fc[x];
    -01056 }
    -01057 
    -01058 int FileReader::FileSize()
    -01059 {
    -01060         return fc.size();
    -01061 }
    -01062 
    -01063 
    -01064 std::vector<Module*> modules(255);
    -01065 std::vector<ircd_module*> factory(255);
    -01066 
    -01067 int MODCOUNT  = -1;
    -01068 
    -01069 
    -

    Generated on Fri May 13 15:48:41 2005 for InspIRCd by +

    Generated on Sun May 15 17:02:06 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/modules_8cpp.html b/docs/module-doc/modules_8cpp.html index 0f38ceb30..b43b1f7af 100644 --- a/docs/module-doc/modules_8cpp.html +++ b/docs/module-doc/modules_8cpp.html @@ -4,26 +4,20 @@ - +

    modules.cpp File Reference

    #include "inspircd.h"
    #include "inspircd_io.h"
    #include "inspircd_util.h"
    #include "inspircd_config.h"
    #include <unistd.h>
    -#include <fcntl.h>
    #include <sys/errno.h>
    -#include <sys/ioctl.h>
    -#include <sys/utsname.h>
    -#include <cstdio>
    #include <time.h>
    #include <string>
    #include <hash_map>
    #include <map>
    #include <sstream>
    #include <vector>
    -#include <errno.h>
    #include <deque>
    -#include <sched.h>
    #include "connection.h"
    #include "users.h"
    #include "servers.h"
    @@ -37,206 +31,174 @@ #include "xline.h"
    #include "commands.h"
    #include "inspstring.h"
    +#include "helperfuncs.h"
    +#include "hashcomp.h"

    Include dependency graph for modules.cpp:

    Include dependency graph
    - - - - - - - - - + + + + + + + + + +

    Go to the source code of this file. - - - - - - - - - - + string >, StrHashComp >  + string >, StrHashComp >  + in_addr >, InAddr_HashComp >  + nspace::hash< string >, StrHashComp >  - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + - + -

    Namespaces

    namespace  nspace

    Compounds

    class  ExtMode
    struct  InAddr_HashComp
    struct  StrHashComp

    Defines

    #define nspace   std

    Typedefs

    typedef nspace::hash_map<
    std::string, userrec *, nspace::hash<
    - string >, StrHashComp
    user_hash
    user_hash
    typedef nspace::hash_map<
    std::string, chanrec *, nspace::hash<
    - string >, StrHashComp
    chan_hash
    chan_hash
    typedef nspace::hash_map<
    in_addr, string *, nspace::hash<
    - in_addr >, InAddr_HashComp
    address_cache
    address_cache
    typedef nspace::hash_map<
    std::string, WhoWasUser *,
    - nspace::hash< string >, StrHashComp
    whowas_hash
    whowas_hash
    typedef std::deque< command_tcommand_table
    typedef std::deque< command_tcommand_table
    typedef std::vector< ExtModeExtModeList
    typedef std::vector< ExtModeExtModeList
    typedef ExtModeList::iterator ExtModeListIter
    typedef ExtModeList::iterator ExtModeListIter

    Functions

    bool ModeDefined (char modechar, int type)
    bool ModeDefined (char modechar, int type)
    bool ModeIsListMode (char modechar, int type)
    bool ModeIsListMode (char modechar, int type)
    bool ModeDefinedOper (char modechar, int type)
    bool ModeDefinedOper (char modechar, int type)
    int ModeDefinedOn (char modechar, int type)
    int ModeDefinedOn (char modechar, int type)
    int ModeDefinedOff (char modechar, int type)
    int ModeDefinedOff (char modechar, int type)
    bool DoAddExtendedMode (char modechar, int type, bool requires_oper, int params_on, int params_off)
    bool DoAddExtendedMode (char modechar, int type, bool requires_oper, int params_on, int params_off)
    void ModeMakeList (char modechar)
    void ModeMakeList (char modechar)
    std::vector< Module * > modules (255)
    std::vector< Module * > modules (255)
    std::vector< ircd_module * > factory (255)
    std::vector< ircd_module * > factory (255)

    Variables

    int MODCOUNT = -1
    int MODCOUNT = -1
    std::vector< Module * > modules
    std::vector< Module * > modules
    std::vector< ircd_module * > factory
    std::vector< ircd_module * > factory
    time_t TIME
    time_t TIME
    int LogLevel
    int LogLevel
    char ServerName [MAXBUF]
    char ServerName [MAXBUF]
    char Network [MAXBUF]
    char Network [MAXBUF]
    char ServerDesc [MAXBUF]
    char ServerDesc [MAXBUF]
    char AdminName [MAXBUF]
    char AdminName [MAXBUF]
    char AdminEmail [MAXBUF]
    char AdminEmail [MAXBUF]
    char AdminNick [MAXBUF]
    char AdminNick [MAXBUF]
    char diepass [MAXBUF]
    char diepass [MAXBUF]
    char restartpass [MAXBUF]
    char restartpass [MAXBUF]
    char motd [MAXBUF]
    char motd [MAXBUF]
    char rules [MAXBUF]
    char rules [MAXBUF]
    char list [MAXBUF]
    char list [MAXBUF]
    char PrefixQuit [MAXBUF]
    char PrefixQuit [MAXBUF]
    char DieValue [MAXBUF]
    char DieValue [MAXBUF]
    int debugging
    int debugging
    int WHOWAS_STALE
    int WHOWAS_STALE
    int WHOWAS_MAX
    int WHOWAS_MAX
    int DieDelay
    int DieDelay
    time_t startup_time
    time_t startup_time
    int NetBufferSize
    int NetBufferSize
    int MaxWhoResults
    int MaxWhoResults
    time_t nb_start
    time_t nb_start
    std::vector< int > fd_reap
    std::vector< int > fd_reap
    std::vector< std::string > module_names
    std::vector< std::string > module_names
    int boundPortCount
    int boundPortCount
    int portCount
    int portCount
    int SERVERportCount
    int SERVERportCount
    int ports [MAXSOCKS]
    int ports [MAXSOCKS]
    int defaultRoute
    int defaultRoute
    std::vector< long > auth_cookies
    std::vector< long > auth_cookies
    std::stringstream config_f
    std::stringstream config_f
    serverrecme [32]
    serverrecme [32]
    FILE * log_file
    FILE * log_file
    userrecfd_ref_table [65536]
    userrecfd_ref_table [65536]
    user_hash clientlist
    user_hash clientlist
    chan_hash chanlist
    chan_hash chanlist
    whowas_hash whowas
    whowas_hash whowas
    command_table cmdlist
    command_table cmdlist
    file_cache MOTD
    file_cache MOTD
    file_cache RULES
    file_cache RULES
    address_cache IP
    address_cache IP
    ExtModeList EMode
    ExtModeList EMode
    -


    Define Documentation

    -

    - - - - -
    - - -
    #define nspace   std -
    -
    - - - - -
    -   - - -

    - -

    -Definition at line 64 of file modules.cpp.


    Typedef Documentation

    -

    +

    @@ -251,16 +213,16 @@ Definition at line 64 o

    -Definition at line 187 of file modules.cpp. +Definition at line 111 of file modules.cpp.

    -
    typedef nspace::hash_map<in_addr,string*, nspace::hash<in_addr>, InAddr_HashComp> address_cache + typedef nspace::hash_map<in_addr,string*, nspace::hash<in_addr>, InAddr_HashComp> address_cache
    -

    +

    @@ -275,16 +237,16 @@ Definition at line 187

    -Definition at line 186 of file modules.cpp. +Definition at line 110 of file modules.cpp.

    -
    typedef nspace::hash_map<std::string, chanrec*, nspace::hash<string>, StrHashComp> chan_hash + typedef nspace::hash_map<std::string, chanrec*, nspace::hash<string>, StrHashComp> chan_hash
    -

    +

    @@ -299,16 +261,16 @@ Definition at line 186

    -Definition at line 189 of file modules.cpp. +Definition at line 113 of file modules.cpp.

    -
    typedef std::deque<command_t> command_table + typedef std::deque<command_t> command_table
    -

    +

    @@ -323,16 +285,16 @@ Definition at line 189

    -Definition at line 215 of file modules.cpp. +Definition at line 139 of file modules.cpp.

    -
    typedef std::vector<ExtMode> ExtModeList + typedef std::vector<ExtMode> ExtModeList
    -

    +

    @@ -347,18 +309,18 @@ Definition at line 215

    -Definition at line 216 of file modules.cpp. +Definition at line 140 of file modules.cpp.

    -Referenced by ModeDefined(), ModeDefinedOff(), ModeDefinedOn(), ModeDefinedOper(), ModeIsListMode(), and ModeMakeList(). +Referenced by ModeDefined(), ModeDefinedOff(), ModeDefinedOn(), ModeDefinedOper(), ModeIsListMode(), and ModeMakeList().

    -
    typedef ExtModeList::iterator ExtModeListIter + typedef ExtModeList::iterator ExtModeListIter
    -

    +

    @@ -373,16 +335,16 @@ Referenced by ModeDefined()

    -Definition at line 185 of file modules.cpp. +Definition at line 109 of file modules.cpp.

    -
    typedef nspace::hash_map<std::string, userrec*, nspace::hash<string>, StrHashComp> user_hash + typedef nspace::hash_map<std::string, userrec*, nspace::hash<string>, StrHashComp> user_hash
    -

    +

    @@ -397,11 +359,11 @@ Definition at line 185

    -Definition at line 188 of file modules.cpp. +Definition at line 112 of file modules.cpp.

    -
    typedef nspace::hash_map<std::string, WhoWasUser*, nspace::hash<string>, StrHashComp> whowas_hash + typedef nspace::hash_map<std::string, WhoWasUser*, nspace::hash<string>, StrHashComp> whowas_hash


    Function Documentation

    -

    +

    @@ -456,23 +418,23 @@ Definition at line 188

    -Definition at line 285 of file modules.cpp. +Definition at line 209 of file modules.cpp.

    -References EMode, and ModeDefined(). +References EMode, and ModeDefined().

    -Referenced by Server::AddExtendedListMode(), and Server::AddExtendedMode(). +Referenced by Server::AddExtendedListMode(), and Server::AddExtendedMode().

    -

    00286 {
    -00287         if (ModeDefined(modechar,type)) {
    -00288                 return false;
    -00289         }
    -00290         EMode.push_back(ExtMode(modechar,type,requires_oper,params_on,params_off));
    -00291         return true;
    -00292 }
    +
    00210 {
    +00211         if (ModeDefined(modechar,type)) {
    +00212                 return false;
    +00213         }
    +00214         EMode.push_back(ExtMode(modechar,type,requires_oper,params_on,params_off));
    +00215         return true;
    +00216 }
     
    -

    +

    @@ -501,7 +463,7 @@ Referenced by Server::AddEx
    -

    +

    @@ -538,26 +500,26 @@ Referenced by Server::AddEx

    -Definition at line 222 of file modules.cpp. +Definition at line 146 of file modules.cpp.

    -References EMode, and ExtModeListIter. +References EMode, and ExtModeListIter.

    -Referenced by DoAddExtendedMode(). +Referenced by DoAddExtendedMode().

    -

    00223 {
    -00224         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00225         {
    -00226                 if ((i->modechar == modechar) && (i->type == type))
    -00227                 {
    -00228                         return true;
    -00229                 }
    -00230         }
    -00231         return false;
    -00232 }
    +
    00147 {
    +00148         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00149         {
    +00150                 if ((i->modechar == modechar) && (i->type == type))
    +00151                 {
    +00152                         return true;
    +00153                 }
    +00154         }
    +00155         return false;
    +00156 }
     
    -

    +

    @@ -594,24 +556,24 @@ Referenced by DoAddExtended

    -Definition at line 272 of file modules.cpp. +Definition at line 196 of file modules.cpp.

    -References EMode, and ExtModeListIter. +References EMode, and ExtModeListIter.

    -

    00273 {
    -00274         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00275         {
    -00276                 if ((i->modechar == modechar) && (i->type == type))
    -00277                 {
    -00278                         return i->params_when_off;
    -00279                 }
    -00280         }
    -00281         return 0;
    -00282 }
    +
    00197 {
    +00198         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00199         {
    +00200                 if ((i->modechar == modechar) && (i->type == type))
    +00201                 {
    +00202                         return i->params_when_off;
    +00203                 }
    +00204         }
    +00205         return 0;
    +00206 }
     
    -

    +

    @@ -648,24 +610,24 @@ References EMode, and <

    -Definition at line 259 of file modules.cpp. +Definition at line 183 of file modules.cpp.

    -References EMode, and ExtModeListIter. +References EMode, and ExtModeListIter.

    -

    00260 {
    -00261         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00262         {
    -00263                 if ((i->modechar == modechar) && (i->type == type))
    -00264                 {
    -00265                         return i->params_when_on;
    -00266                 }
    -00267         }
    -00268         return 0;
    -00269 }
    +
    00184 {
    +00185         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00186         {
    +00187                 if ((i->modechar == modechar) && (i->type == type))
    +00188                 {
    +00189                         return i->params_when_on;
    +00190                 }
    +00191         }
    +00192         return 0;
    +00193 }
     
    -

    +

    @@ -702,24 +664,24 @@ References EMode, and <

    -Definition at line 246 of file modules.cpp. +Definition at line 170 of file modules.cpp.

    -References EMode, and ExtModeListIter. +References EMode, and ExtModeListIter.

    -

    00247 {
    -00248         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00249         {
    -00250                 if ((i->modechar == modechar) && (i->type == type) && (i->needsoper == true))
    -00251                 {
    -00252                         return true;
    -00253                 }
    -00254         }
    -00255         return false;
    -00256 }
    +
    00171 {
    +00172         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00173         {
    +00174                 if ((i->modechar == modechar) && (i->type == type) && (i->needsoper == true))
    +00175                 {
    +00176                         return true;
    +00177                 }
    +00178         }
    +00179         return false;
    +00180 }
     
    -

    +

    @@ -756,24 +718,24 @@ References EMode, and <

    -Definition at line 234 of file modules.cpp. +Definition at line 158 of file modules.cpp.

    -References EMode, and ExtModeListIter. +References EMode, and ExtModeListIter.

    -

    00235 {
    -00236         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00237         {
    -00238                 if ((i->modechar == modechar) && (i->type == type) && (i->list == true))
    -00239                 {
    -00240                         return true;
    -00241                 }
    -00242         }
    -00243         return false;
    -00244 }
    +
    00159 {
    +00160         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00161         {
    +00162                 if ((i->modechar == modechar) && (i->type == type) && (i->list == true))
    +00163                 {
    +00164                         return true;
    +00165                 }
    +00166         }
    +00167         return false;
    +00168 }
     
    -

    +

    @@ -801,27 +763,27 @@ References EMode, and <

    -Definition at line 295 of file modules.cpp. -

    -References EMode, ExtModeListIter, and MT_CHANNEL. -

    -Referenced by Server::AddExtendedListMode(). +Definition at line 219 of file modules.cpp.

    -

    00296 {
    -00297         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    -00298         {
    -00299                 if ((i->modechar == modechar) && (i->type == MT_CHANNEL))
    -00300                 {
    -00301                         i->list = true;
    -00302                         return;
    -00303                 }
    -00304         }
    -00305         return;
    -00306 }
    +References EMode, ExtModeListIter, and MT_CHANNEL.
    +

    +Referenced by Server::AddExtendedListMode(). +

    +

    00220 {
    +00221         for (ExtModeListIter i = EMode.begin(); i < EMode.end(); i++)
    +00222         {
    +00223                 if ((i->modechar == modechar) && (i->type == MT_CHANNEL))
    +00224                 {
    +00225                         i->list = true;
    +00226                         return;
    +00227                 }
    +00228         }
    +00229         return;
    +00230 }
     
    -

    +

    @@ -851,13 +813,13 @@ Referenced by Server::AddEx


    Variable Documentation

    -

    +

    @@ -872,16 +834,16 @@ Referenced by Server::AddEx

    -Definition at line 84 of file modules.cpp. +Definition at line 72 of file modules.cpp.

    -
    char AdminEmail[MAXBUF] + char AdminEmail[MAXBUF]
    -

    +

    @@ -896,16 +858,16 @@ Definition at line 84 o

    -Definition at line 83 of file modules.cpp. +Definition at line 71 of file modules.cpp.

    -
    char AdminName[MAXBUF] + char AdminName[MAXBUF]
    -

    +

    @@ -920,16 +882,16 @@ Definition at line 83 o

    -Definition at line 85 of file modules.cpp. +Definition at line 73 of file modules.cpp.

    -
    char AdminNick[MAXBUF] + char AdminNick[MAXBUF]
    -

    +

    @@ -944,16 +906,16 @@ Definition at line 85 o

    -Definition at line 112 of file modules.cpp. +Definition at line 100 of file modules.cpp.

    -
    std::vector<long> auth_cookies + std::vector<long> auth_cookies
    -

    +

    @@ -968,16 +930,16 @@ Definition at line 112

    -Definition at line 106 of file modules.cpp. +Definition at line 94 of file modules.cpp.

    -
    int boundPortCount + int boundPortCount
    -

    +

    @@ -992,16 +954,16 @@ Definition at line 106

    -Definition at line 193 of file modules.cpp. +Definition at line 117 of file modules.cpp.

    -
    chan_hash chanlist + chan_hash chanlist
    -

    +

    @@ -1016,16 +978,16 @@ Definition at line 193

    -Definition at line 192 of file modules.cpp. +Definition at line 116 of file modules.cpp.

    -
    user_hash clientlist + user_hash clientlist
    -

    +

    @@ -1040,10 +1002,10 @@ Definition at line 192

    -Definition at line 195 of file modules.cpp. +Definition at line 119 of file modules.cpp.

    -
    command_table cmdlist + command_table cmdlist
    -

    +

    +Definition at line 101 of file modules.cpp.
    @@ -1064,16 +1026,16 @@ Definition at line 195

    -Definition at line 113 of file modules.cpp.

    -

    +

    @@ -1088,16 +1050,16 @@ Definition at line 113

    -Definition at line 94 of file modules.cpp. +Definition at line 82 of file modules.cpp.

    -
    int debugging + int debugging
    -

    +

    @@ -1112,16 +1074,16 @@ Definition at line 94 o

    -Definition at line 110 of file modules.cpp. +Definition at line 98 of file modules.cpp.

    -
    int defaultRoute + int defaultRoute
    -

    +

    @@ -1136,16 +1098,16 @@ Definition at line 110

    -Definition at line 97 of file modules.cpp. +Definition at line 85 of file modules.cpp.

    -
    int DieDelay + int DieDelay
    -

    +

    @@ -1160,16 +1122,16 @@ Definition at line 97 o

    -Definition at line 86 of file modules.cpp. +Definition at line 74 of file modules.cpp.

    -
    char diepass[MAXBUF] + char diepass[MAXBUF]
    -

    +

    @@ -1184,16 +1146,16 @@ Definition at line 86 o

    -Definition at line 92 of file modules.cpp. +Definition at line 80 of file modules.cpp.

    -
    char DieValue[MAXBUF] + char DieValue[MAXBUF]
    -

    +

    @@ -1208,12 +1170,12 @@ Definition at line 92 o

    -Definition at line 219 of file modules.cpp. +Definition at line 143 of file modules.cpp.

    -Referenced by DoAddExtendedMode(), ModeDefined(), ModeDefinedOff(), ModeDefinedOn(), ModeDefinedOper(), ModeIsListMode(), and ModeMakeList(). +Referenced by DoAddExtendedMode(), ModeDefined(), ModeDefinedOff(), ModeDefinedOn(), ModeDefinedOper(), ModeIsListMode(), and ModeMakeList().

    -
    ExtModeList EMode + ExtModeList EMode
    -

    +

    +Definition at line 63 of file modules.cpp.
    @@ -1234,16 +1196,16 @@ Referenced by DoAddExtended

    -Definition at line 75 of file modules.cpp.

    -

    +

    @@ -1258,16 +1220,16 @@ Definition at line 75 o

    -Definition at line 103 of file modules.cpp. +Definition at line 91 of file modules.cpp.

    -
    std::vector<int> fd_reap + std::vector<int> fd_reap
    -

    +

    @@ -1282,18 +1244,18 @@ Definition at line 103

    -Definition at line 119 of file modules.cpp. +Definition at line 107 of file modules.cpp.

    -Referenced by Server::FindDescriptor(), and Server::PseudoToUser(). +Referenced by Server::FindDescriptor(), and Server::PseudoToUser().

    -
    userrec* fd_ref_table[65536] + userrec* fd_ref_table[65536]
    -

    +

    @@ -1308,16 +1270,16 @@ Referenced by Server::FindD

    -Definition at line 198 of file modules.cpp. +Definition at line 122 of file modules.cpp.

    -
    address_cache IP + address_cache IP
    -

    +

    @@ -1332,16 +1294,16 @@ Definition at line 198

    -Definition at line 90 of file modules.cpp. +Definition at line 78 of file modules.cpp.

    -
    char list[MAXBUF] + char list[MAXBUF]
    -

    +

    @@ -1356,16 +1318,16 @@ Definition at line 90 o

    -Definition at line 117 of file modules.cpp. +Definition at line 105 of file modules.cpp.

    -
    FILE* log_file + FILE* log_file
    -

    +

    @@ -1380,16 +1342,16 @@ Definition at line 117

    -Definition at line 79 of file modules.cpp. +Definition at line 67 of file modules.cpp.

    -
    int LogLevel + int LogLevel
    -

    +

    @@ -1404,16 +1366,16 @@ Definition at line 79 o

    -Definition at line 100 of file modules.cpp. +Definition at line 88 of file modules.cpp.

    -
    int MaxWhoResults + int MaxWhoResults
    -

    +

    @@ -1428,16 +1390,16 @@ Definition at line 100

    -Definition at line 115 of file modules.cpp. +Definition at line 103 of file modules.cpp.

    -
    serverrec* me[32] + serverrec* me[32]
    -

    +

    @@ -1452,16 +1414,16 @@ Definition at line 115

    -Definition at line 1067 of file modules.cpp. +Definition at line 996 of file modules.cpp.

    -
    int MODCOUNT = -1 + int MODCOUNT = -1
    -

    +

    @@ -1476,10 +1438,10 @@ Definition at line 1067

    -Definition at line 104 of file modules.cpp. +Definition at line 92 of file modules.cpp.

    -
    std::vector<std::string> module_names + std::vector<std::string> module_names
    -

    +

    +Definition at line 62 of file modules.cpp.
    @@ -1500,16 +1462,16 @@ Definition at line 104

    -Definition at line 74 of file modules.cpp.

    -

    +

    @@ -1524,16 +1486,16 @@ Definition at line 74 o

    -Definition at line 196 of file modules.cpp. +Definition at line 120 of file modules.cpp.

    -
    file_cache MOTD + file_cache MOTD
    -

    +

    @@ -1548,16 +1510,16 @@ Definition at line 196

    -Definition at line 88 of file modules.cpp. +Definition at line 76 of file modules.cpp.

    -
    char motd[MAXBUF] + char motd[MAXBUF]
    -

    +

    @@ -1572,16 +1534,16 @@ Definition at line 88 o

    -Definition at line 101 of file modules.cpp. +Definition at line 89 of file modules.cpp.

    -
    time_t nb_start + time_t nb_start
    -

    +

    @@ -1596,16 +1558,16 @@ Definition at line 101

    -Definition at line 99 of file modules.cpp. +Definition at line 87 of file modules.cpp.

    -
    int NetBufferSize + int NetBufferSize
    -

    +

    @@ -1620,16 +1582,16 @@ Definition at line 99 o

    -Definition at line 81 of file modules.cpp. +Definition at line 69 of file modules.cpp.

    -
    char Network[MAXBUF] + char Network[MAXBUF]
    -

    +

    @@ -1644,16 +1606,16 @@ Definition at line 81 o

    -Definition at line 107 of file modules.cpp. +Definition at line 95 of file modules.cpp.

    -
    int portCount + int portCount
    -

    +

    @@ -1668,16 +1630,16 @@ Definition at line 107

    -Definition at line 109 of file modules.cpp. +Definition at line 97 of file modules.cpp.

    -
    int ports[MAXSOCKS] + int ports[MAXSOCKS]
    -

    +

    @@ -1692,16 +1654,16 @@ Definition at line 109

    -Definition at line 91 of file modules.cpp. +Definition at line 79 of file modules.cpp.

    -
    char PrefixQuit[MAXBUF] + char PrefixQuit[MAXBUF]
    -

    +

    @@ -1716,16 +1678,16 @@ Definition at line 91 o

    -Definition at line 87 of file modules.cpp. +Definition at line 75 of file modules.cpp.

    -
    char restartpass[MAXBUF] + char restartpass[MAXBUF]
    -

    +

    @@ -1740,16 +1702,16 @@ Definition at line 87 o

    -Definition at line 197 of file modules.cpp. +Definition at line 121 of file modules.cpp.

    -
    file_cache RULES + file_cache RULES
    -

    +

    @@ -1764,16 +1726,16 @@ Definition at line 197

    -Definition at line 89 of file modules.cpp. +Definition at line 77 of file modules.cpp.

    -
    char rules[MAXBUF] + char rules[MAXBUF]
    -

    +

    @@ -1788,16 +1750,16 @@ Definition at line 89 o

    -Definition at line 82 of file modules.cpp. +Definition at line 70 of file modules.cpp.

    -
    char ServerDesc[MAXBUF] + char ServerDesc[MAXBUF]
    -

    +

    @@ -1812,16 +1774,16 @@ Definition at line 82 o

    -Definition at line 80 of file modules.cpp. +Definition at line 68 of file modules.cpp.

    -
    char ServerName[MAXBUF] + char ServerName[MAXBUF]
    -

    +

    @@ -1836,16 +1798,16 @@ Definition at line 80 o

    -Definition at line 108 of file modules.cpp. +Definition at line 96 of file modules.cpp.

    -
    int SERVERportCount + int SERVERportCount
    -

    +

    @@ -1860,10 +1822,10 @@ Definition at line 108

    -Definition at line 98 of file modules.cpp. +Definition at line 86 of file modules.cpp.

    -
    time_t startup_time + time_t startup_time
    -

    +

    +Definition at line 65 of file modules.cpp.
    @@ -1884,16 +1846,16 @@ Definition at line 98 o

    -Definition at line 77 of file modules.cpp.

    -

    +

    @@ -1908,16 +1870,16 @@ Definition at line 77 o

    -Definition at line 194 of file modules.cpp. +Definition at line 118 of file modules.cpp.

    -
    whowas_hash whowas + whowas_hash whowas
    -

    +

    @@ -1932,16 +1894,16 @@ Definition at line 194

    -Definition at line 96 of file modules.cpp. +Definition at line 84 of file modules.cpp.

    -
    int WHOWAS_MAX + int WHOWAS_MAX
    -

    +

    @@ -1956,10 +1918,10 @@ Definition at line 96 o

    -Definition at line 95 of file modules.cpp. +Definition at line 83 of file modules.cpp.

    -
    int WHOWAS_STALE + int WHOWAS_STALE
    -


    Generated on Fri May 13 15:49:09 2005 for InspIRCd by +
    Generated on Sun May 15 17:02:42 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/modules_8cpp__incl.gif b/docs/module-doc/modules_8cpp__incl.gif index b2ba0c231677292c690f5ed06d159dca5a971c01..b041fb6b8cd893b53cf06ae8a17dd0baf3bc02db 100644 GIT binary patch literal 40960 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 EJIXTY*Z=?k literal 42186 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 diff --git a/docs/module-doc/modules_8h-source.html b/docs/module-doc/modules_8h-source.html index 03cd2a9b7..ec270a4ae 100644 --- a/docs/module-doc/modules_8h-source.html +++ b/docs/module-doc/modules_8h-source.html @@ -4,7 +4,7 @@ - +

    modules.h

    Go to the documentation of this file.
    00001 /*       +------------------------------------+
     00002  *       | Inspire Internet Relay Chat Daemon |
     00003  *       +------------------------------------+
    @@ -309,147 +309,148 @@
     00803         virtual bool IsOnChannel(userrec* User, chanrec* Chan);
     00806         virtual std::string GetServerName();
     00809         virtual std::string GetNetworkName();
    -00815         virtual Admin GetAdmin();
    -00834         virtual bool AddExtendedMode(char modechar, int type, bool requires_oper, int params_when_on, int params_when_off);
    -00835 
    -00857         virtual bool AddExtendedListMode(char modechar);
    -00858 
    -00876         virtual void AddCommand(char* cmd, handlerfunc f, char flags, int minparams, char* source);
    -00877          
    -00899         virtual void SendMode(char **parameters, int pcnt, userrec *user);
    -00900         
    -00913         virtual void SendToModeMask(std::string modes, int flags, std::string text);
    -00914 
    -00920         virtual chanrec* JoinUserToChannel(userrec* user, std::string cname, std::string key);
    -00921         
    -00927         virtual chanrec* PartUserFromChannel(userrec* user, std::string cname, std::string reason);
    -00928         
    -00934         virtual void ChangeUserNick(userrec* user, std::string nickname);
    -00935         
    -00946         virtual void QuitUser(userrec* user, std::string reason);
    -00947         
    -00952         virtual bool MatchText(std::string sliteral, std::string spattern);
    -00953         
    -00965         virtual void CallCommandHandler(std::string commandname, char** parameters, int pcnt, userrec* user);
    -00966         
    -00972         virtual void ChangeHost(userrec* user, std::string host);
    -00973         
    -00979         virtual void ChangeGECOS(userrec* user, std::string gecos);
    -00980         
    -00989         virtual bool IsUlined(std::string server);
    -00990         
    -00994         virtual chanuserlist GetUsers(chanrec* chan);
    -00995 
    -01002         virtual bool UserToPseudo(userrec* user,std::string message);
    -01003 
    -01010         virtual bool PseudoToUser(userrec* alive,userrec* zombie,std::string message);
    -01011 
    -01019         virtual void AddGLine(long duration, std::string source, std::string reason, std::string hostmask);
    -01020 
    -01028         virtual void AddQLine(long duration, std::string source, std::string reason, std::string nickname);
    -01029 
    -01037         virtual void AddZLine(long duration, std::string source, std::string reason, std::string ipaddr);
    -01038 
    -01046         virtual void AddKLine(long duration, std::string source, std::string reason, std::string hostmask);
    -01047 
    -01055         virtual void AddELine(long duration, std::string source, std::string reason, std::string hostmask);
    -01056 
    -01059         virtual bool DelGLine(std::string hostmask);
    -01060 
    -01063         virtual bool DelQLine(std::string nickname);
    -01064 
    -01067         virtual bool DelZLine(std::string ipaddr);
    -01068 
    -01071         virtual bool DelKLine(std::string hostmask);
    -01072 
    -01075         virtual bool DelELine(std::string hostmask);
    -01076 
    -01082         virtual long CalcDuration(std::string duration);
    -01083 
    -01086         virtual bool IsValidMask(std::string mask);
    -01087 
    -01092         virtual void MeshSendAll(std::string text);
    -01093 
    -01100         virtual void MeshSendCommon(userrec* user, std::string text);
    -01101 
    -01104         virtual void MeshSendAllAlive(std::string text);
    -01105 
    -01109         virtual void MeshSendUnicast(std::string destination, std::string text);
    -01110 
    -01115         virtual void MeshSendAllExcept(std::string target, std::string text);
    -01116 
    -01120         virtual bool MeshCheckChan(chanrec *c,std::string servername);
    -01121 
    -01125         virtual bool MeshCheckCommon(userrec* u,std::string servername);
    -01126 
    -01131         virtual Module* FindModule(std::string name);
    -01132 };
    -01133 
    -01134 
    -01135 #define CONF_NOT_A_NUMBER       0x000010
    -01136 #define CONF_NOT_UNSIGNED       0x000080
    -01137 #define CONF_VALUE_NOT_FOUND    0x000100
    -01138 #define CONF_FILE_NOT_FOUND     0x000200
    -01139 
    -01140 
    -01147 class ConfigReader : public classbase
    -01148 {
    -01149   protected:
    -01155         std::stringstream *cache;
    -01156         std::stringstream *errorlog;
    -01159         bool readerror;
    -01160         long error;
    -01161         
    -01162   public:
    -01167         ConfigReader();                 // default constructor reads ircd.conf
    -01171         ConfigReader(std::string filename);     // read a module-specific config
    -01175         ~ConfigReader();
    -01180         std::string ReadValue(std::string tag, std::string name, int index);
    -01186         bool ReadFlag(std::string tag, std::string name, int index);
    -01195         long ReadInteger(std::string tag, std::string name, int index, bool needs_unsigned);
    -01200         long GetError();
    -01207         int Enumerate(std::string tag);
    -01212         bool Verify();
    -01219         void DumpErrors(bool bail,userrec* user);
    -01220 
    -01226         int EnumerateValues(std::string tag, int index);
    -01227 };
    -01228 
    -01229 
    -01230 
    -01236 class FileReader : public classbase
    -01237 {
    -01238  file_cache fc;
    -01239  public:
    -01244          FileReader();
    -01245 
    -01251          FileReader(std::string filename);
    -01252 
    -01256          ~FileReader();
    -01257 
    -01263          void LoadFile(std::string filename);
    -01264 
    -01268          bool Exists();
    -01269          
    -01274          std::string GetLine(int x);
    -01275 
    -01281          int FileSize();
    -01282 };
    -01283 
    -01284 
    -01291 class ModuleFactory : public classbase
    -01292 {
    -01293  public:
    -01294         ModuleFactory() { }
    -01295         virtual ~ModuleFactory() { }
    -01300         virtual Module * CreateModule() = 0;
    -01301 };
    -01302 
    -01303 
    -01304 typedef DLLFactory<ModuleFactory> ircd_module;
    +00812         virtual std::string GetServerDescription();
    +00818         virtual Admin GetAdmin();
    +00837         virtual bool AddExtendedMode(char modechar, int type, bool requires_oper, int params_when_on, int params_when_off);
    +00838 
    +00860         virtual bool AddExtendedListMode(char modechar);
    +00861 
    +00879         virtual void AddCommand(char* cmd, handlerfunc f, char flags, int minparams, char* source);
    +00880          
    +00902         virtual void SendMode(char **parameters, int pcnt, userrec *user);
    +00903         
    +00916         virtual void SendToModeMask(std::string modes, int flags, std::string text);
    +00917 
    +00923         virtual chanrec* JoinUserToChannel(userrec* user, std::string cname, std::string key);
    +00924         
    +00930         virtual chanrec* PartUserFromChannel(userrec* user, std::string cname, std::string reason);
    +00931         
    +00937         virtual void ChangeUserNick(userrec* user, std::string nickname);
    +00938         
    +00949         virtual void QuitUser(userrec* user, std::string reason);
    +00950         
    +00955         virtual bool MatchText(std::string sliteral, std::string spattern);
    +00956         
    +00968         virtual void CallCommandHandler(std::string commandname, char** parameters, int pcnt, userrec* user);
    +00969         
    +00975         virtual void ChangeHost(userrec* user, std::string host);
    +00976         
    +00982         virtual void ChangeGECOS(userrec* user, std::string gecos);
    +00983         
    +00992         virtual bool IsUlined(std::string server);
    +00993         
    +00997         virtual chanuserlist GetUsers(chanrec* chan);
    +00998 
    +01005         virtual bool UserToPseudo(userrec* user,std::string message);
    +01006 
    +01013         virtual bool PseudoToUser(userrec* alive,userrec* zombie,std::string message);
    +01014 
    +01022         virtual void AddGLine(long duration, std::string source, std::string reason, std::string hostmask);
    +01023 
    +01031         virtual void AddQLine(long duration, std::string source, std::string reason, std::string nickname);
    +01032 
    +01040         virtual void AddZLine(long duration, std::string source, std::string reason, std::string ipaddr);
    +01041 
    +01049         virtual void AddKLine(long duration, std::string source, std::string reason, std::string hostmask);
    +01050 
    +01058         virtual void AddELine(long duration, std::string source, std::string reason, std::string hostmask);
    +01059 
    +01062         virtual bool DelGLine(std::string hostmask);
    +01063 
    +01066         virtual bool DelQLine(std::string nickname);
    +01067 
    +01070         virtual bool DelZLine(std::string ipaddr);
    +01071 
    +01074         virtual bool DelKLine(std::string hostmask);
    +01075 
    +01078         virtual bool DelELine(std::string hostmask);
    +01079 
    +01085         virtual long CalcDuration(std::string duration);
    +01086 
    +01089         virtual bool IsValidMask(std::string mask);
    +01090 
    +01095         virtual void MeshSendAll(std::string text);
    +01096 
    +01103         virtual void MeshSendCommon(userrec* user, std::string text);
    +01104 
    +01107         virtual void MeshSendAllAlive(std::string text);
    +01108 
    +01112         virtual void MeshSendUnicast(std::string destination, std::string text);
    +01113 
    +01118         virtual void MeshSendAllExcept(std::string target, std::string text);
    +01119 
    +01123         virtual bool MeshCheckChan(chanrec *c,std::string servername);
    +01124 
    +01128         virtual bool MeshCheckCommon(userrec* u,std::string servername);
    +01129 
    +01134         virtual Module* FindModule(std::string name);
    +01135 };
    +01136 
    +01137 
    +01138 #define CONF_NOT_A_NUMBER       0x000010
    +01139 #define CONF_NOT_UNSIGNED       0x000080
    +01140 #define CONF_VALUE_NOT_FOUND    0x000100
    +01141 #define CONF_FILE_NOT_FOUND     0x000200
    +01142 
    +01143 
    +01150 class ConfigReader : public classbase
    +01151 {
    +01152   protected:
    +01158         std::stringstream *cache;
    +01159         std::stringstream *errorlog;
    +01162         bool readerror;
    +01163         long error;
    +01164         
    +01165   public:
    +01170         ConfigReader();                 // default constructor reads ircd.conf
    +01174         ConfigReader(std::string filename);     // read a module-specific config
    +01178         ~ConfigReader();
    +01183         std::string ReadValue(std::string tag, std::string name, int index);
    +01189         bool ReadFlag(std::string tag, std::string name, int index);
    +01198         long ReadInteger(std::string tag, std::string name, int index, bool needs_unsigned);
    +01203         long GetError();
    +01210         int Enumerate(std::string tag);
    +01215         bool Verify();
    +01222         void DumpErrors(bool bail,userrec* user);
    +01223 
    +01229         int EnumerateValues(std::string tag, int index);
    +01230 };
    +01231 
    +01232 
    +01233 
    +01239 class FileReader : public classbase
    +01240 {
    +01241  file_cache fc;
    +01242  public:
    +01247          FileReader();
    +01248 
    +01254          FileReader(std::string filename);
    +01255 
    +01259          ~FileReader();
    +01260 
    +01266          void LoadFile(std::string filename);
    +01267 
    +01271          bool Exists();
    +01272          
    +01277          std::string GetLine(int x);
    +01278 
    +01284          int FileSize();
    +01285 };
    +01286 
    +01287 
    +01294 class ModuleFactory : public classbase
    +01295 {
    +01296  public:
    +01297         ModuleFactory() { }
    +01298         virtual ~ModuleFactory() { }
    +01303         virtual Module * CreateModule() = 0;
    +01304 };
     01305 
    -01306 #endif
    -

    Generated on Fri May 13 15:48:42 2005 for InspIRCd by +01306 +01307 typedef DLLFactory<ModuleFactory> ircd_module; +01308 +01309 #endif +

    Generated on Sun May 15 17:02:06 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/modules_8h.html b/docs/module-doc/modules_8h.html index be75f5ea4..33f708825 100644 --- a/docs/module-doc/modules_8h.html +++ b/docs/module-doc/modules_8h.html @@ -4,7 +4,7 @@ - +

    modules.h File Reference

    #include "dynamic.h"
    #include "base.h"
    #include "ctables.h"
    @@ -109,7 +109,7 @@ This graph shows which files directly or indirectly include this file:

    #define VF_COMMON   8 -#define FOREACH_MOD   for (int _i = 0; _i <= MODCOUNT; _i++) modules[_i]-> +#define FOREACH_MOD   for (int _i = 0; _i <= MODCOUNT; _i++) modules[_i]-> #define FOREACH_RESULT(x) @@ -404,7 +404,7 @@ Definition at line 39 of

    Definition at line 37 of file modules.h.

    -Referenced by Module::OnAccessCheck(). +Referenced by Module::OnAccessCheck().

    @@ -452,9 +452,9 @@ Definition at line 38 of

    -Definition at line 1138 of file modules.h. +Definition at line 1141 of file modules.h.

    -Referenced by ConfigReader::ConfigReader(). +Referenced by ConfigReader::ConfigReader().

    @@ -478,9 +478,9 @@ Referenced by ConfigReader:

    -Definition at line 1135 of file modules.h. +Definition at line 1138 of file modules.h.

    -Referenced by ConfigReader::ReadInteger(). +Referenced by ConfigReader::ReadInteger().

    @@ -504,9 +504,9 @@ Referenced by ConfigReader:

    -Definition at line 1136 of file modules.h. +Definition at line 1139 of file modules.h.

    -Referenced by ConfigReader::ReadInteger(). +Referenced by ConfigReader::ReadInteger().

    @@ -530,9 +530,9 @@ Referenced by ConfigReader:

    -Definition at line 1137 of file modules.h. +Definition at line 1140 of file modules.h.

    -Referenced by ConfigReader::ReadFlag(), ConfigReader::ReadInteger(), and ConfigReader::ReadValue(). +Referenced by ConfigReader::ReadFlag(), ConfigReader::ReadInteger(), and ConfigReader::ReadValue().

    @@ -558,7 +558,7 @@ Referenced by ConfigReader:

    Definition at line 23 of file modules.h.

    -Referenced by Server::AddExtendedMode(), chanrec::AddUser(), chanrec::DelUser(), userrec::HasPermission(), chanrec::IsCustomModeSet(), userrec::RemoveInvite(), chanrec::SetCustomMode(), chanrec::SetCustomModeParam(), userrec::SetWriteError(), and Server::UserToPseudo(). +Referenced by Server::AddExtendedMode(), chanrec::AddUser(), chanrec::DelUser(), userrec::HasPermission(), chanrec::IsCustomModeSet(), userrec::RemoveInvite(), chanrec::SetCustomMode(), chanrec::SetCustomModeParam(), userrec::SetWriteError(), and Server::UserToPseudo().

    @@ -608,7 +608,7 @@ Definition at line 25 of

    Definition at line 99 of file modules.h.

    -Referenced by Server::PseudoToUser(), and Server::UserToPseudo(). +Referenced by Server::PseudoToUser(), and Server::UserToPseudo().

    @@ -617,7 +617,7 @@ Referenced by Server::Pseud -
    #define FOREACH_MOD   for (int _i = 0; _i <= MODCOUNT; _i++) modules[_i]-> + #define FOREACH_MOD   for (int _i = 0; _i <= MODCOUNT; _i++) modules[_i]->
    @@ -634,7 +634,7 @@ Referenced by
    Server::Pseud

    Definition at line 79 of file modules.h.

    -Referenced by Event::Send(). +Referenced by Event::Send().

    @@ -698,7 +698,7 @@ Definition at line 87 of

    Definition at line 31 of file modules.h.

    -Referenced by Server::AddExtendedListMode(), and ModeMakeList(). +Referenced by Server::AddExtendedListMode(), and ModeMakeList().

    @@ -724,7 +724,7 @@ Referenced by Server::AddEx

    Definition at line 32 of file modules.h.

    -Referenced by Server::AddExtendedMode(). +Referenced by Server::AddExtendedMode().

    @@ -750,7 +750,7 @@ Referenced by Server::AddEx

    Definition at line 33 of file modules.h.

    -Referenced by Server::AddExtendedMode(). +Referenced by Server::AddExtendedMode().

    @@ -920,7 +920,7 @@ Definition at line 53 of

    Definition at line 54 of file modules.h.

    -Referenced by Module::GetVersion(). +Referenced by Module::GetVersion().


    Typedef Documentation

    @@ -949,7 +949,7 @@ Holds a list of users in a channel.

    Definition at line 72 of file modules.h.

    -Referenced by Server::GetUsers(). +Referenced by Server::GetUsers().

    @@ -977,7 +977,7 @@ Low level definition of a FileReader Definition at line 67 of file modules.h.

    -Referenced by FileReader::FileReader(), and FileReader::LoadFile(). +Referenced by FileReader::FileReader(), and FileReader::LoadFile().

    @@ -1001,7 +1001,7 @@ Referenced by FileReader::F

    -Definition at line 1304 of file modules.h. +Definition at line 1307 of file modules.h.

    @@ -1027,7 +1027,7 @@ Definition at line 1304 o

    Definition at line 68 of file modules.h.

    -Referenced by Module::OnChannelSync(), and Module::OnUserSync(). +Referenced by Module::OnChannelSync(), and Module::OnUserSync().


    Function Documentation

    @@ -1086,7 +1086,7 @@ Referenced by Module::OnCha

    -Referenced by Server::AddCommand(). +Referenced by Server::AddCommand().

    @@ -1132,10 +1132,10 @@ Referenced by Server::AddCo

    -Referenced by Server::SendMode(). +Referenced by Server::SendMode(). -


    Generated on Fri May 13 15:49:10 2005 for InspIRCd by +
    Generated on Sun May 15 17:02:44 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/namespaceirc.html b/docs/module-doc/namespaceirc.html new file mode 100644 index 000000000..fe1a06e8c --- /dev/null +++ b/docs/module-doc/namespaceirc.html @@ -0,0 +1,57 @@ + + +InspIRCd: irc Namespace Reference + + + + +

    irc Namespace Reference

    The irc namespace contains a number of helper classes. +More... +

    + + + + + + + + + + +

    Compounds

    struct  irc_char_traits
     The irc_char_traits class is used for RFC-style comparison of strings. More...


    Typedefs

    typedef basic_string< char,
    + irc_char_traits, allocator<
    + char > > 
    string
     This typedef declares irc::string based upon irc_char_traits.

    +


    Detailed Description

    +The irc namespace contains a number of helper classes.

    Typedef Documentation

    +

    + + + + +
    + + +
    typedef basic_string<char, irc_char_traits, allocator<char> > irc::string +
    +
    + + + + + +
    +   + + +

    +This typedef declares irc::string based upon irc_char_traits. +

    + +

    +Definition at line 111 of file hashcomp.h.

    +


    Generated on Sun May 15 17:03:56 2005 for InspIRCd by + +doxygen +1.3.3
    + + diff --git a/docs/module-doc/namespacemembers.html b/docs/module-doc/namespacemembers.html new file mode 100644 index 000000000..455fb3f7c --- /dev/null +++ b/docs/module-doc/namespacemembers.html @@ -0,0 +1,19 @@ + + +InspIRCd: Namespace Member Index + + + + + + +

    +Here is a list of all namespace members with links to the namespace documentation for each member:

      +
    • string +: irc
    +
    Generated on Sun May 15 17:03:57 2005 for InspIRCd by + +doxygen +1.3.3
    + + diff --git a/docs/module-doc/namespacemembers_type.html b/docs/module-doc/namespacemembers_type.html new file mode 100644 index 000000000..c7b742c84 --- /dev/null +++ b/docs/module-doc/namespacemembers_type.html @@ -0,0 +1,19 @@ + + +InspIRCd: Namespace Member Index + + + + + + +

    +

      +
    • string +: irc
    +
    Generated on Sun May 15 17:03:57 2005 for InspIRCd by + +doxygen +1.3.3
    + + diff --git a/docs/module-doc/namespacenspace.html b/docs/module-doc/namespacenspace.html index 7a733dbb4..3106c8370 100644 --- a/docs/module-doc/namespacenspace.html +++ b/docs/module-doc/namespacenspace.html @@ -4,7 +4,7 @@ - +

    nspace Namespace Reference

    @@ -15,7 +15,7 @@
    struct  nspace.hash< string >
    -


    Generated on Fri May 13 15:50:10 2005 for InspIRCd by +
    Generated on Sun May 15 17:03:56 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/namespaces.html b/docs/module-doc/namespaces.html index ad50a7a14..3083039d3 100644 --- a/docs/module-doc/namespaces.html +++ b/docs/module-doc/namespaces.html @@ -4,12 +4,13 @@ - +

    InspIRCd Namespace List

    Here is a list of all namespaces with brief descriptions: +
    ircThe irc namespace contains a number of helper classes
    nspace
    std
    -
    Generated on Fri May 13 15:50:10 2005 for InspIRCd by +
    Generated on Sun May 15 17:03:56 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/namespacestd.html b/docs/module-doc/namespacestd.html index 7b2a1dced..877b08682 100644 --- a/docs/module-doc/namespacestd.html +++ b/docs/module-doc/namespacestd.html @@ -4,13 +4,13 @@ - +

    std Namespace Reference

    -


    Generated on Fri May 13 15:50:10 2005 for InspIRCd by +
    Generated on Sun May 15 17:03:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/servers_8cpp-source.html b/docs/module-doc/servers_8cpp-source.html index f77ed551a..d3ece0aa5 100644 --- a/docs/module-doc/servers_8cpp-source.html +++ b/docs/module-doc/servers_8cpp-source.html @@ -4,7 +4,7 @@ - +

    servers.cpp

    Go to the documentation of this file.
    00001 /*       +------------------------------------+
     00002  *       | Inspire Internet Relay Chat Daemon |
     00003  *       +------------------------------------+
    @@ -27,43 +27,44 @@
     00020 #include <stdio.h>
     00021 #include <map>
     00022 #include "inspstring.h"
    -00023 
    -00024 extern time_t TIME;
    -00025 
    -00026 serverrec::serverrec()
    -00027 {
    -00028         strlcpy(name,"",256);
    -00029         pingtime = 0;
    -00030         lastping = TIME;
    -00031         usercount_i = usercount = opercount = version = 0;
    -00032         hops_away = 1;
    -00033         signon = TIME;
    -00034         jupiter = false;
    -00035         fd = 0;
    -00036         sync_soon = false;
    -00037         strlcpy(nickserv,"",NICKMAX);
    -00038 }
    -00039 
    -00040  
    -00041 serverrec::~serverrec()
    -00042 {
    -00043 }
    -00044 
    -00045 serverrec::serverrec(char* n, long ver, bool jupe)
    -00046 {
    -00047         strlcpy(name,n,256);
    -00048         lastping = TIME;
    -00049         usercount_i = usercount = opercount = 0;
    -00050         version = ver;
    -00051         hops_away = 1;
    -00052         signon = TIME;
    -00053         jupiter = jupe;
    -00054         fd = 0;
    -00055         sync_soon = false;
    -00056         strlcpy(nickserv,"",NICKMAX);
    -00057 }
    -00058 
    -

    Generated on Fri May 13 15:48:42 2005 for InspIRCd by +00023 #include "helperfuncs.h" +00024 +00025 extern time_t TIME; +00026 +00027 serverrec::serverrec() +00028 { +00029 strlcpy(name,"",256); +00030 pingtime = 0; +00031 lastping = TIME; +00032 usercount_i = usercount = opercount = version = 0; +00033 hops_away = 1; +00034 signon = TIME; +00035 jupiter = false; +00036 fd = 0; +00037 sync_soon = false; +00038 strlcpy(nickserv,"",NICKMAX); +00039 } +00040 +00041 +00042 serverrec::~serverrec() +00043 { +00044 } +00045 +00046 serverrec::serverrec(char* n, long ver, bool jupe) +00047 { +00048 strlcpy(name,n,256); +00049 lastping = TIME; +00050 usercount_i = usercount = opercount = 0; +00051 version = ver; +00052 hops_away = 1; +00053 signon = TIME; +00054 jupiter = jupe; +00055 fd = 0; +00056 sync_soon = false; +00057 strlcpy(nickserv,"",NICKMAX); +00058 } +00059 +

    Generated on Sun May 15 17:02:06 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/servers_8cpp.html b/docs/module-doc/servers_8cpp.html index 7e3ea1822..5c49966dd 100644 --- a/docs/module-doc/servers_8cpp.html +++ b/docs/module-doc/servers_8cpp.html @@ -4,13 +4,14 @@ - +

    servers.cpp File Reference

    #include "inspircd_config.h"
    #include "servers.h"
    #include "inspircd.h"
    #include <stdio.h>
    #include <map>
    #include "inspstring.h"
    +#include "helperfuncs.h"

    Include dependency graph for servers.cpp:

    Include dependency graph
    @@ -47,10 +48,10 @@ Include dependency graph for servers.cpp:

    24 of file servers.cpp. +Definition at line 25 of file servers.cpp. -
    Generated on Fri May 13 15:49:11 2005 for InspIRCd by +
    Generated on Sun May 15 17:02:45 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/servers_8cpp__incl.gif b/docs/module-doc/servers_8cpp__incl.gif index 035914c558af9f98a1bf458f041eb4492a01d94f..6158892d6cd29e584f13bf4bd71c376115c09166 100644 GIT binary patch delta 3681 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 I5dZ)IJHFf!J^%m! diff --git a/docs/module-doc/servers_8h-source.html b/docs/module-doc/servers_8h-source.html index e27f582cc..d5780b3e0 100644 --- a/docs/module-doc/servers_8h-source.html +++ b/docs/module-doc/servers_8h-source.html @@ -4,7 +4,7 @@ - +

    servers.h

    Go to the documentation of this file.
    00001 /*       +------------------------------------+
     00002  *       | Inspire Internet Relay Chat Daemon |
     00003  *       +------------------------------------+
    @@ -61,7 +61,7 @@
     00082 
     00083 #endif
     00084 
    -

    Generated on Fri May 13 15:48:42 2005 for InspIRCd by +

    Generated on Sun May 15 17:02:06 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/servers_8h.html b/docs/module-doc/servers_8h.html index cc8c8ea62..1ad696e14 100644 --- a/docs/module-doc/servers_8h.html +++ b/docs/module-doc/servers_8h.html @@ -4,7 +4,7 @@ - +

    servers.h File Reference

    #include "inspircd_config.h"
    #include "connection.h"
    #include <string>
    @@ -86,7 +86,7 @@ Definition at line 25 of Definition at line 26 of file servers.h. -
    Generated on Fri May 13 15:49:13 2005 for InspIRCd by +
    Generated on Sun May 15 17:02:47 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structInAddr__HashComp-members.html b/docs/module-doc/structInAddr__HashComp-members.html index 3a68f92cc..ccb39f559 100644 --- a/docs/module-doc/structInAddr__HashComp-members.html +++ b/docs/module-doc/structInAddr__HashComp-members.html @@ -4,10 +4,10 @@ - +

    InAddr_HashComp Member List

    This is the complete list of members for InAddr_HashComp, including all inherited members. - -
    operator()(const in_addr &s1, const in_addr &s2) constInAddr_HashComp [inline]

    Generated on Fri May 13 15:49:40 2005 for InspIRCd by + operator()(const in_addr &s1, const in_addr &s2) constInAddr_HashComp +
    Generated on Sun May 15 17:03:29 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structInAddr__HashComp.html b/docs/module-doc/structInAddr__HashComp.html index 8e0f35bb7..4aebb1d97 100644 --- a/docs/module-doc/structInAddr__HashComp.html +++ b/docs/module-doc/structInAddr__HashComp.html @@ -4,14 +4,27 @@ - -

    InAddr_HashComp Struct Reference

    List of all members. + +

    InAddr_HashComp Struct Reference

    This class returns true if two in_addr structs match. +More... +

    +#include <hashcomp.h> +

    +List of all members.

    +

    Public Member Functions

    bool operator() (const in_addr &s1, const in_addr &s2) const
     The operator () does the actual comparison in hash_map.

    -

    Member Function Documentation

    +

    Detailed Description

    +This class returns true if two in_addr structs match. +

    +Checking is done by copying both into a size_t then doing a numeric comparison of the two. +

    + +

    +Definition at line 71 of file hashcomp.h.


    Member Function Documentation

    @@ -32,7 +45,7 @@ - +
    const [inline] const
    @@ -47,25 +60,14 @@

    - -

    -Definition at line 171 of file modules.cpp. +The operator () does the actual comparison in hash_map.

    -

    00172         {
    -00173                 size_t q;
    -00174                 size_t p;
    -00175                 
    -00176                 memcpy(&q,&s1,sizeof(size_t));
    -00177                 memcpy(&p,&s2,sizeof(size_t));
    -00178                 
    -00179                 return (q == p);
    -00180         }
    -
    +
    The documentation for this struct was generated from the following file: -
    Generated on Fri May 13 15:49:40 2005 for InspIRCd by +
  • hashcomp.h +
    Generated on Sun May 15 17:03:29 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structStrHashComp-members.html b/docs/module-doc/structStrHashComp-members.html index 7e1c81f5c..98853fc0d 100644 --- a/docs/module-doc/structStrHashComp-members.html +++ b/docs/module-doc/structStrHashComp-members.html @@ -4,10 +4,10 @@ - +

    StrHashComp Member List

    This is the complete list of members for StrHashComp, including all inherited members. - -
    operator()(const string &s1, const string &s2) constStrHashComp [inline]

    Generated on Fri May 13 15:49:57 2005 for InspIRCd by + operator()(const string &s1, const string &s2) constStrHashComp +
    Generated on Sun May 15 17:03:46 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structStrHashComp.html b/docs/module-doc/structStrHashComp.html index 9c06b5618..23f3e82ef 100644 --- a/docs/module-doc/structStrHashComp.html +++ b/docs/module-doc/structStrHashComp.html @@ -4,14 +4,27 @@ - -

    StrHashComp Struct Reference

    List of all members. + +

    StrHashComp Struct Reference

    This class returns true if two strings match. +More... +

    +#include <hashcomp.h> +

    +List of all members.

    +

    Public Member Functions

    bool operator() (const string &s1, const string &s2) const
     The operator () does the actual comparison in hash_map.

    -

    Member Function Documentation

    +

    Detailed Description

    +This class returns true if two strings match. +

    +Case sensitivity is ignored, and the RFC 'character set' is adhered to +

    + +

    +Definition at line 60 of file hashcomp.h.


    Member Function Documentation

    @@ -32,7 +45,7 @@ - +
    const [inline] const
    @@ -47,24 +60,14 @@

    - -

    -Definition at line 156 of file modules.cpp. +The operator () does the actual comparison in hash_map.

    -

    00157         {
    -00158                 char a[MAXBUF],b[MAXBUF];
    -00159                 strlcpy(a,s1.c_str(),MAXBUF);
    -00160                 strlcpy(b,s2.c_str(),MAXBUF);
    -00161                 strlower(a);
    -00162                 strlower(b);
    -00163                 return (strcasecmp(a,b) == 0);
    -00164         }
    -
    +
    The documentation for this struct was generated from the following file: -
    Generated on Fri May 13 15:49:57 2005 for InspIRCd by +
  • hashcomp.h +
    Generated on Sun May 15 17:03:46 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structdns__ip4list-members.html b/docs/module-doc/structdns__ip4list-members.html index b6bdbb8eb..27dc1e726 100644 --- a/docs/module-doc/structdns__ip4list-members.html +++ b/docs/module-doc/structdns__ip4list-members.html @@ -4,11 +4,11 @@ - +

    dns_ip4list Member List

    This is the complete list of members for dns_ip4list, including all inherited members. -
    ipdns_ip4list
    nextdns_ip4list

    Generated on Fri May 13 15:49:31 2005 for InspIRCd by +
    Generated on Sun May 15 17:03:19 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structdns__ip4list.html b/docs/module-doc/structdns__ip4list.html index 17168b2ec..c3001ad65 100644 --- a/docs/module-doc/structdns__ip4list.html +++ b/docs/module-doc/structdns__ip4list.html @@ -4,7 +4,7 @@ - +

    dns_ip4list Struct Reference

    #include <dns.h>

    Collaboration diagram for dns_ip4list:

    Collaboration graph
    @@ -67,7 +67,7 @@ Definition at line 28 of file
    The documentation for this struct was generated from the following file: -
    Generated on Fri May 13 15:49:31 2005 for InspIRCd by +
    Generated on Sun May 15 17:03:19 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structirc_1_1irc__char__traits-members.html b/docs/module-doc/structirc_1_1irc__char__traits-members.html new file mode 100644 index 000000000..6d05351be --- /dev/null +++ b/docs/module-doc/structirc_1_1irc__char__traits-members.html @@ -0,0 +1,19 @@ + + +InspIRCd: Member List + + + + +

    irc::irc_char_traits Member List

    This is the complete list of members for irc::irc_char_traits, including all inherited members. + + + + + +
    compare(const char *str1, const char *str2, size_t n)irc::irc_char_traits [static]
    eq(char c1st, char c2nd)irc::irc_char_traits [static]
    find(const char *s1, int n, char c)irc::irc_char_traits [static]
    lt(char c1st, char c2nd)irc::irc_char_traits [static]
    ne(char c1st, char c2nd)irc::irc_char_traits [static]

    Generated on Sun May 15 17:03:56 2005 for InspIRCd by + +doxygen +1.3.3
    + + diff --git a/docs/module-doc/structirc_1_1irc__char__traits.html b/docs/module-doc/structirc_1_1irc__char__traits.html new file mode 100644 index 000000000..6953a5bdd --- /dev/null +++ b/docs/module-doc/structirc_1_1irc__char__traits.html @@ -0,0 +1,267 @@ + + +InspIRCd: irc::irc_char_traits struct Reference + + + + +

    irc::irc_char_traits Struct Reference

    The irc_char_traits class is used for RFC-style comparison of strings. +More... +

    +#include <hashcomp.h> +

    +Inheritance diagram for irc::irc_char_traits:

    Inheritance graph
    + + + +
    [legend]
    Collaboration diagram for irc::irc_char_traits:

    Collaboration graph
    + + + +
    [legend]
    List of all members. + + + + + + + + + + + + + + + + + +

    Static Public Member Functions

    bool eq (char c1st, char c2nd)
     Check if two chars match.

    bool ne (char c1st, char c2nd)
     Check if two chars do NOT match.

    bool lt (char c1st, char c2nd)
     Check if one char is less than another.

    int compare (const char *str1, const char *str2, size_t n)
     Compare two strings of size n.

    const char * find (const char *s1, int n, char c)
     Find a char within a string up to position n.

    +

    Detailed Description

    +The irc_char_traits class is used for RFC-style comparison of strings. +

    +This class is used to implement irc::string, a case-insensitive, RFC- comparing string class. +

    + +

    +Definition at line 86 of file hashcomp.h.


    Member Function Documentation

    +

    + + + + +
    + + + + + + + + + + + + + + + + + + + + + + + + + +
    int irc::irc_char_traits::compare const char *  str1,
    const char *  str2,
    size_t  n
    [static]
    +
    + + + + + +
    +   + + +

    +Compare two strings of size n. +

    +

    +

    + + + + +
    + + + + + + + + + + + + + + + + + + + +
    bool irc::irc_char_traits::eq char  c1st,
    char  c2nd
    [static]
    +
    + + + + + +
    +   + + +

    +Check if two chars match. +

    +

    +

    + + + + +
    + + + + + + + + + + + + + + + + + + + + + + + + + +
    const char* irc::irc_char_traits::find const char *  s1,
    int  n,
    char  c
    [static]
    +
    + + + + + +
    +   + + +

    +Find a char within a string up to position n. +

    +

    +

    + + + + +
    + + + + + + + + + + + + + + + + + + + +
    bool irc::irc_char_traits::lt char  c1st,
    char  c2nd
    [static]
    +
    + + + + + +
    +   + + +

    +Check if one char is less than another. +

    +

    +

    + + + + +
    + + + + + + + + + + + + + + + + + + + +
    bool irc::irc_char_traits::ne char  c1st,
    char  c2nd
    [static]
    +
    + + + + + +
    +   + + +

    +Check if two chars do NOT match. +

    +

    +


    The documentation for this struct was generated from the following file: +
    Generated on Sun May 15 17:03:56 2005 for InspIRCd by + +doxygen +1.3.3
    + + diff --git a/docs/module-doc/structirc_1_1irc__char__traits__coll__graph.gif b/docs/module-doc/structirc_1_1irc__char__traits__coll__graph.gif new file mode 100644 index 0000000000000000000000000000000000000000..514f37993b9f1645292719263bc91143602f858f GIT binary patch literal 1111 zcmV-d1gQH*Nk%w1VW$9e0OJ4v|Ns900092~|9^jf-{0R~Utb>|AD^F}KR-XezrPt7 zZ~y=R000000000000000A^8LW00062EC2ui0H*+S000F35XecZy*TU5yZ>M)j$~<` zXsWJk>%MR-&vb3yc&_h!@BctRU`Q+)kI1BQ$!t2G(5TcC2wJZ~Dt7CucD&p$4!j|Y z&oXmHjc&8p7r1+Fl2`2XJP1GGQwVV(ejI>W0EKlngM$(VfqN;AA(DwTi;xzK5}Iow zehCPjAqWYch8PD!1_?wG1PBJHn|%`m1p%v@2L=HL5}>%gLIad{Lz~0^z_GNg0I9g8 zzX+tRx4A;Qz0<*c$)MFAmutSeSrP>U0Jjs$HC64A*K9H z#ISK9fdK`0c@&lMW=@$s5x^7}Zs$xdK6M%;>QDnq3g*BVsCW^j7X$+mSX^p#0#>a+ z)tH+Wt|ZW}TX#0Z)KY`O0EN=6vs0kd*sxmJrKEXsQ{J$J6jA_%&Mv%(0shV`Dh{HB z1iZHC1pv$5%$L}J?lQ2FYX!YvHh1=@7xEBc7cfiHY=AS+5>NHWHuYt;ZQ5L+sdxIlK9((!k=FV>~l0v<@^#BU4Yu~;kItK;b!&^{5Uc7k#`MTsU_fnth4tjMAdF22Y^j56v#V~sf6h@%QR?npzA zKFR=OkT48MqzgtK$wHD!s=#EEC_D+J2~ti;LX}pEfMu2-Y{{huUVizVm@|^OLzre_ zfM%NGv6-WrH>_zJcXZZiC!J&5spp=2CXr{KfCgIUpMn-@XcUAVs_3FeB+BTciaJ_^ z5Y|zOXPuEXVQHpQ+yLnmby_5asMJaNsS=iMm+BL%LSgDL#|&T*GcQ%q%B@w%+D)xU z&?;0F1psnO0M*#iimtoOf^4zF{!-dU0j~VY#H+Rf%gX_`1l!#)KVchywn=ykE&wY* zJA|?3a?7a^&i({fw$9=@7r4`UiYlz$}DqC1ic_Da__+h z2t_l>IO|Mu5jlS=YRi-{gDa{!OFMN37 djH5bu|AD^F}KR-XezrPt7 zZ~y=R000000000000000A^8LW00062EC2ui0H*+S000F35XecZy*TU5yZ>M)j$~<` zXsWJk>%MR-&vb3yc&_h!@BctRU`Q+)kI1BQ$!t2G(5TcC2wJZ~Dt7CucD&p$4!j|Y z&oXmHjc&8p7r1+Fl2`2XJP1GGQwVV(ejI>W0EKlngM$(VfqN;AA(DwTi;xzK5}Iow zehCPjAqWYch8PD!1_?wG1PBJHn|%`m1p%v@2L=HL5}>%gLIad{Lz~0^z_GNg0I9g8 zzX+tRx4A;Qz0<*c$)MFAmutSeSrP>U0Jjs$HC64A*K9H z#ISK9fdK`0c@&lMW=@$s5x^7}Zs$xdK6M%;>QDnq3g*BVsCW^j7X$+mSX^p#0#>a+ z)tH+Wt|ZW}TX#0Z)KY`O0EN=6vs0kd*sxmJrKEXsQ{J$J6jA_%&Mv%(0shV`Dh{HB z1iZHC1pv$5%$L}J?lQ2FYX!YvHh1=@7xEBc7cfiHY=AS+5>NHWHuYt;ZQ5L+sdxIlK9((!k=FV>~l0v<@^#BU4Yu~;kItK;b!&^{5Uc7k#`MTsU_fnth4tjMAdF22Y^j56v#V~sf6h@%QR?npzA zKFR=OkT48MqzgtK$wHD!s=#EEC_D+J2~ti;LX}pEfMu2-Y{{huUVizVm@|^OLzre_ zfM%NGv6-WrH>_zJcXZZiC!J&5spp=2CXr{KfCgIUpMn-@XcUAVs_3FeB+BTciaJ_^ z5Y|zOXPuEXVQHpQ+yLnmby_5asMJaNsS=iMm+BL%LSgDL#|&T*GcQ%q%B@w%+D)xU z&?;0F1psnO0M*#iimtoOf^4zF{!-dU0j~VY#H+Rf%gX_`1l!#)KVchywn=ykE&wY* zJA|?3a?7a^&i({fw$9=@7r4`UiYlz$}DqC1ic_Da__+h z2t_l>IO|Mu5jlS=YRi-{gDa{!OFMN37 djH5bu - +

    nspace::hash< in_addr > Member List

    This is the complete list of members for nspace::hash< in_addr >, including all inherited members. - -
    operator()(const struct in_addr &a) constnspace::hash< in_addr > [inline]

    Generated on Fri May 13 15:50:10 2005 for InspIRCd by + operator()(const struct in_addr &a) constnspace::hash< in_addr > +
    Generated on Sun May 15 17:03:56 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01in__addr_01_4.html b/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01in__addr_01_4.html index 8e0f5ea66..6326e91b6 100644 --- a/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01in__addr_01_4.html +++ b/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01in__addr_01_4.html @@ -4,8 +4,10 @@ - -

    nspace::hash< in_addr > Struct Template Reference

    List of all members. + +

    nspace::hash< in_addr > Struct Template Reference

    #include <hashcomp.h> +

    +List of all members.

    @@ -26,7 +28,7 @@ - +

    Public Member Functions

    size_t operator() (const struct in_addr &a) const
    const struct in_addr &  a  )  const [inline] const
    @@ -41,21 +43,12 @@

    - -

    -Definition at line 129 of file modules.cpp. -

    -

    00130                 {
    -00131                         size_t q;
    -00132                         memcpy(&q,&a,sizeof(size_t));
    -00133                         return q;
    -00134                 }
    -
    +
    The documentation for this struct was generated from the following file: -
    Generated on Fri May 13 15:50:10 2005 for InspIRCd by +
  • hashcomp.h +
    Generated on Sun May 15 17:03:56 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4-members.html b/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4-members.html index 78dc1f303..895c45869 100644 --- a/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4-members.html +++ b/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4-members.html @@ -4,10 +4,10 @@ - +

    nspace::hash< string > Member List

    This is the complete list of members for nspace::hash< string >, including all inherited members. - -
    operator()(const string &s) constnspace::hash< string > [inline]

    Generated on Fri May 13 15:50:10 2005 for InspIRCd by + operator()(const string &s) constnspace::hash< string > +
    Generated on Sun May 15 17:03:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4.html b/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4.html index ba45c743c..daa13eb4a 100644 --- a/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4.html +++ b/docs/module-doc/structnspace_1_1nspace_1_1hash_3_01string_01_4.html @@ -4,8 +4,10 @@ - -

    nspace::hash< string > Struct Template Reference

    List of all members. + +

    nspace::hash< string > Struct Template Reference

    #include <hashcomp.h> +

    +List of all members.

    @@ -26,7 +28,7 @@ - +

    Public Member Functions

    size_t operator() (const string &s) const
    const string &  s  )  const [inline] const
    @@ -41,23 +43,12 @@

    - -

    -Definition at line 142 of file modules.cpp. -

    -

    00143                 {
    -00144                         char a[MAXBUF];
    -00145                         static struct hash<const char *> strhash;
    -00146                         strlcpy(a,s.c_str(),MAXBUF);
    -00147                         strlower(a);
    -00148                         return strhash(a);
    -00149                 }
    -
    +
    The documentation for this struct was generated from the following file: -
    Generated on Fri May 13 15:50:10 2005 for InspIRCd by +
  • hashcomp.h +
    Generated on Sun May 15 17:03:57 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/tree.html b/docs/module-doc/tree.html index 74bb23f49..000e9bac7 100644 --- a/docs/module-doc/tree.html +++ b/docs/module-doc/tree.html @@ -120,6 +120,7 @@

    |o*connection.h

    |o*ctables.h

    |o*dns.h

    +

    |o*hashcomp.h

    |o*message.h

    |o*mode.h

    |o*modules.cpp

    @@ -135,6 +136,7 @@

    |o*Admin

    |o*BanItem

    |o*chanrec

    +

    |o*char_traits

    |o*classbase

    |o*command_t

    |o*ConfigReader

    @@ -153,6 +155,7 @@

    |o*InAddr_HashComp

    |o*Invited

    |o*InviteItem

    +

    |o*irc::irc_char_traits

    |o*ircd_connector

    |o*KLine

    |o*ModeParameter

    @@ -175,17 +178,21 @@
  • o+Class Hierarchy

    -

    |o+classbase

    +

    |o+char_traits

    +

    |o+classbase

    +

    ||o*Admin

    ||o*ConfigReader

    ||o*ConnectClass

    -

    ||o+Extensible

    -
    +

    ||o+Extensible

    +

    |||o*chanrec

    |||o*command_t

    -

    |||o+connection

    -
    +

    |||o+connection

    + @@ -193,8 +200,8 @@

    ||o*ExtMode

    ||o*FileReader

    -

    ||o+HostItem

    -
    +

    ||o+HostItem

    +

    |||o*BanItem

    |||o*ExemptItem

    |||\*InviteItem

    @@ -203,16 +210,16 @@

    ||o*ModeParameter

    ||o*Module

    ||o*ModuleFactory

    -

    ||o+ModuleMessage

    -
    +

    ||o+ModuleMessage

    +

    ||o*Server

    ||o*ucrec

    ||o*Version

    -

    ||\+XLine

    - diff --git a/docs/module-doc/users_8cpp-source.html b/docs/module-doc/users_8cpp-source.html index b1258eb0a..4e2e35443 100644 --- a/docs/module-doc/users_8cpp-source.html +++ b/docs/module-doc/users_8cpp-source.html @@ -4,7 +4,7 @@ - +

    users.cpp

    Go to the documentation of this file.
    00001 /*       +------------------------------------+
     00002  *       | Inspire Internet Relay Chat Daemon |
     00003  *       +------------------------------------+
    @@ -27,259 +27,265 @@
     00020 #include "inspircd.h"
     00021 #include <stdio.h>
     00022 #include "inspstring.h"
    -00023 
    -00024 extern std::stringstream config_f;
    -00025 
    -00026 extern time_t TIME;
    -00027 
    -00028 userrec::userrec()
    -00029 {
    -00030         // the PROPER way to do it, AVOID bzero at *ALL* costs
    -00031         strcpy(nick,"");
    -00032         strcpy(ip,"127.0.0.1");
    -00033         timeout = 0;
    -00034         strcpy(ident,"");
    -00035         strcpy(host,"");
    -00036         strcpy(dhost,"");
    -00037         strcpy(fullname,"");
    -00038         strcpy(modes,"");
    -00039         strcpy(server,"");
    -00040         strcpy(awaymsg,"");
    -00041         strcpy(oper,"");
    -00042         reset_due = TIME;
    -00043         lines_in = 0;
    -00044         fd = lastping = signon = idle_lastmsg = nping = registered = 0;
    -00045         flood = port = bytes_in = bytes_out = cmds_in = cmds_out = 0;
    -00046         haspassed = false;
    -00047         dns_done = false;
    -00048         recvq = "";
    -00049         sendq = "";
    -00050         strcpy(result,"");
    -00051         for (int i = 0; i < MAXCHANS; i++)
    -00052         {
    -00053                 this->chans[i].channel = NULL;
    -00054                 this->chans[i].uc_modes = 0;
    -00055         }
    -00056         invites.clear();
    -00057 }
    -00058 
    +00023 #include "helperfuncs.h"
    +00024 
    +00025 extern std::stringstream config_f;
    +00026 
    +00027 extern time_t TIME;
    +00028 
    +00029 userrec::userrec()
    +00030 {
    +00031         // the PROPER way to do it, AVOID bzero at *ALL* costs
    +00032         strcpy(nick,"");
    +00033         strcpy(ip,"127.0.0.1");
    +00034         timeout = 0;
    +00035         strcpy(ident,"");
    +00036         strcpy(host,"");
    +00037         strcpy(dhost,"");
    +00038         strcpy(fullname,"");
    +00039         strcpy(modes,"");
    +00040         strcpy(server,"");
    +00041         strcpy(awaymsg,"");
    +00042         strcpy(oper,"");
    +00043         reset_due = TIME;
    +00044         lines_in = 0;
    +00045         fd = lastping = signon = idle_lastmsg = nping = registered = 0;
    +00046         flood = port = bytes_in = bytes_out = cmds_in = cmds_out = 0;
    +00047         haspassed = false;
    +00048         dns_done = false;
    +00049         recvq = "";
    +00050         sendq = "";
    +00051         strcpy(result,"");
    +00052         for (int i = 0; i < MAXCHANS; i++)
    +00053         {
    +00054                 this->chans[i].channel = NULL;
    +00055                 this->chans[i].uc_modes = 0;
    +00056         }
    +00057         invites.clear();
    +00058 }
     00059 
    -00060  
    -00061 char* userrec::GetFullHost()
    -00062 {
    -00063         snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,dhost);
    -00064         return result;
    -00065 }
    -00066 
    +00060 
    +00061  
    +00062 char* userrec::GetFullHost()
    +00063 {
    +00064         snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,dhost);
    +00065         return result;
    +00066 }
     00067 
    -00068 char* userrec::GetFullRealHost()
    -00069 {
    -00070         snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,host);
    -00071         return result;
    -00072 }
    -00073 
    -00074 bool userrec::IsInvited(char* channel)
    -00075 {
    -00076         for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++)
    -00077         {
    -00078                 if (i->channel) {
    -00079                         if (!strcasecmp(i->channel,channel))
    -00080                         {
    -00081                                 return true;
    -00082                         }
    -00083                 }
    -00084         }
    -00085         return false;
    -00086 }
    -00087 
    -00088 void userrec::InviteTo(char* channel)
    -00089 {
    -00090         Invited i;
    -00091         strlcpy(i.channel,channel,CHANMAX);
    -00092         invites.push_back(i);
    -00093 }
    -00094 
    -00095 void userrec::RemoveInvite(char* channel)
    -00096 {
    -00097         log(DEBUG,"Removing invites");
    -00098         if (channel)
    -00099         {
    -00100                 if (invites.size())
    -00101                 {
    -00102                         for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++)
    -00103                         {
    -00104                                 if (i->channel)
    -00105                                 {
    -00106                                         if (!strcasecmp(i->channel,channel))
    -00107                                         {
    -00108                                                 invites.erase(i);
    -00109                                                 return;
    -00110                                         }
    -00111                                 }
    -00112                         }
    -00113                 }
    -00114         }
    -00115 }
    -00116 
    -00117 bool userrec::HasPermission(char* command)
    -00118 {
    -00119         char TypeName[MAXBUF],Classes[MAXBUF],ClassName[MAXBUF],CommandList[MAXBUF];
    -00120         char* mycmd;
    -00121         char* savept;
    -00122         char* savept2;
    -00123         
    -00124         // are they even an oper at all?
    -00125         if (strchr(this->modes,'o'))
    -00126         {
    -00127                 log(DEBUG,"*** HasPermission: %s is an oper",this->nick);
    -00128                 for (int j =0; j < ConfValueEnum("type",&config_f); j++)
    -00129                 {
    -00130                         ConfValue("type","name",j,TypeName,&config_f);
    -00131                         if (!strcmp(TypeName,this->oper))
    -00132                         {
    -00133                                 log(DEBUG,"*** HasPermission: %s is an oper of type '%s'",this->nick,this->oper);
    -00134                                 ConfValue("type","classes",j,Classes,&config_f);
    -00135                                 char* myclass = strtok_r(Classes," ",&savept);
    -00136                                 while (myclass)
    -00137                                 {
    -00138                                         log(DEBUG,"*** HasPermission: checking classtype '%s'",myclass);
    -00139                                         for (int k =0; k < ConfValueEnum("class",&config_f); k++)
    -00140                                         {
    -00141                                                 ConfValue("class","name",k,ClassName,&config_f);
    -00142                                                 if (!strcmp(ClassName,myclass))
    -00143                                                 {
    -00144                                                         ConfValue("class","commands",k,CommandList,&config_f);
    -00145                                                         log(DEBUG,"*** HasPermission: found class named %s with commands: '%s'",ClassName,CommandList);
    -00146                                                         
    -00147                                                         
    -00148                                                         mycmd = strtok_r(CommandList," ",&savept2);
    -00149                                                         while (mycmd)
    -00150                                                         {
    -00151                                                                 if (!strcasecmp(mycmd,command))
    -00152                                                                 {
    -00153                                                                         log(DEBUG,"*** Command %s found, returning true",command);
    -00154                                                                         return true;
    -00155                                                                 }
    -00156                                                                 mycmd = strtok_r(NULL," ",&savept2);
    -00157                                                         }
    -00158                                                 }
    -00159                                         }
    -00160                                         myclass = strtok_r(NULL," ",&savept);
    -00161                                 }
    -00162                         }
    -00163                 }
    -00164         }
    -00165         return false;
    -00166 }
    -00167 
    -00168 
    -00169 bool userrec::AddBuffer(std::string a)
    -00170 {
    -00171         std::string b = "";
    -00172         for (int i = 0; i < a.length(); i++)
    -00173                 if ((a[i] != '\r') && (a[i] != '\0') && (a[i] != 7))
    -00174                         b = b + a[i];
    -00175         std::stringstream stream(recvq);
    -00176         stream << b;
    -00177         recvq = stream.str();
    -00178         int i = 0;
    -00179         // count the size of the first line in the buffer.
    -00180         while (i < recvq.length())
    -00181         {
    -00182                 if (recvq[i++] == '\n')
    -00183                         break;
    -00184         }
    -00185         if (recvq.length() > this->recvqmax)
    -00186         {
    -00187                 this->SetWriteError("RecvQ exceeded");
    -00188                 WriteOpers("*** User %s RecvQ of %d exceeds connect class maximum of %d",this->nick,recvq.length(),this->recvqmax);
    -00189         }
    -00190         // return false if we've had more than 600 characters WITHOUT
    -00191         // a carriage return (this is BAD, drop the socket)
    -00192         return (i < 600);
    -00193 }
    -00194 
    -00195 bool userrec::BufferIsReady()
    -00196 {
    -00197         for (int i = 0; i < recvq.length(); i++)
    -00198                 if (recvq[i] == '\n')
    -00199                         return true;
    -00200         return false;
    -00201 }
    -00202 
    -00203 void userrec::ClearBuffer()
    -00204 {
    -00205         recvq = "";
    -00206 }
    -00207 
    -00208 std::string userrec::GetBuffer()
    -00209 {
    -00210         if (recvq == "")
    -00211                 return "";
    -00212         char* line = (char*)recvq.c_str();
    -00213         std::string ret = "";
    -00214         while ((*line != '\n') && (strlen(line)))
    -00215         {
    -00216                 ret = ret + *line;
    -00217                 line++;
    -00218         }
    -00219         if ((*line == '\n') || (*line == '\r'))
    -00220                 line++;
    -00221         recvq = line;
    -00222         return ret;
    -00223 }
    -00224 
    -00225 void userrec::AddWriteBuf(std::string data)
    -00226 {
    -00227         if (this->GetWriteError() != "")
    -00228                 return;
    -00229         if (sendq.length() + data.length() > this->sendqmax)
    -00230         {
    -00231                 WriteOpers("*** User %s SendQ of %d exceeds connect class maximum of %d",this->nick,sendq.length() + data.length(),this->sendqmax);
    -00232                 this->SetWriteError("SendQ exceeded");
    -00233                 return;
    -00234         }
    -00235         std::stringstream stream;
    -00236         stream << sendq << data;
    -00237         sendq = stream.str();
    -00238 }
    -00239 
    -00240 // send AS MUCH OF THE USERS SENDQ as we are able to (might not be all of it)
    -00241 void userrec::FlushWriteBuf()
    -00242 {
    -00243         if (sendq.length())
    -00244         {
    -00245                 char* tb = (char*)this->sendq.c_str();
    -00246                 int n_sent = write(this->fd,tb,this->sendq.length());
    -00247                 if (n_sent == -1)
    -00248                 {
    -00249                         this->SetWriteError(strerror(errno));
    -00250                 }
    -00251                 else
    -00252                 {
    -00253                         // advance the queue
    -00254                         tb += n_sent;
    -00255                         this->sendq = tb;
    -00256                         // update the user's stats counters
    -00257                         this->bytes_out += n_sent;
    -00258                         this->cmds_out++;
    -00259                 }
    -00260         }
    -00261 }
    -00262 
    -00263 void userrec::SetWriteError(std::string error)
    -00264 {
    -00265         log(DEBUG,"Setting error string for %s to '%s'",this->nick,error.c_str());
    -00266         // don't try to set the error twice, its already set take the first string.
    -00267         if (this->WriteError == "")
    -00268                 this->WriteError = error;
    -00269 }
    -00270 
    -00271 std::string userrec::GetWriteError()
    -00272 {
    -00273         return this->WriteError;
    -00274 }
    -

    Generated on Fri May 13 15:48:42 2005 for InspIRCd by +00068 +00069 char* userrec::GetFullRealHost() +00070 { +00071 snprintf(result,MAXBUF,"%s!%s@%s",nick,ident,host); +00072 return result; +00073 } +00074 +00075 bool userrec::IsInvited(char* channel) +00076 { +00077 for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) +00078 { +00079 if (i->channel) { +00080 if (!strcasecmp(i->channel,channel)) +00081 { +00082 return true; +00083 } +00084 } +00085 } +00086 return false; +00087 } +00088 +00089 InvitedList* userrec::GetInviteList() +00090 { +00091 return &invites; +00092 } +00093 +00094 void userrec::InviteTo(char* channel) +00095 { +00096 Invited i; +00097 strlcpy(i.channel,channel,CHANMAX); +00098 invites.push_back(i); +00099 } +00100 +00101 void userrec::RemoveInvite(char* channel) +00102 { +00103 log(DEBUG,"Removing invites"); +00104 if (channel) +00105 { +00106 if (invites.size()) +00107 { +00108 for (InvitedList::iterator i = invites.begin(); i != invites.end(); i++) +00109 { +00110 if (i->channel) +00111 { +00112 if (!strcasecmp(i->channel,channel)) +00113 { +00114 invites.erase(i); +00115 return; +00116 } +00117 } +00118 } +00119 } +00120 } +00121 } +00122 +00123 bool userrec::HasPermission(char* command) +00124 { +00125 char TypeName[MAXBUF],Classes[MAXBUF],ClassName[MAXBUF],CommandList[MAXBUF]; +00126 char* mycmd; +00127 char* savept; +00128 char* savept2; +00129 +00130 // are they even an oper at all? +00131 if (strchr(this->modes,'o')) +00132 { +00133 log(DEBUG,"*** HasPermission: %s is an oper",this->nick); +00134 for (int j =0; j < ConfValueEnum("type",&config_f); j++) +00135 { +00136 ConfValue("type","name",j,TypeName,&config_f); +00137 if (!strcmp(TypeName,this->oper)) +00138 { +00139 log(DEBUG,"*** HasPermission: %s is an oper of type '%s'",this->nick,this->oper); +00140 ConfValue("type","classes",j,Classes,&config_f); +00141 char* myclass = strtok_r(Classes," ",&savept); +00142 while (myclass) +00143 { +00144 log(DEBUG,"*** HasPermission: checking classtype '%s'",myclass); +00145 for (int k =0; k < ConfValueEnum("class",&config_f); k++) +00146 { +00147 ConfValue("class","name",k,ClassName,&config_f); +00148 if (!strcmp(ClassName,myclass)) +00149 { +00150 ConfValue("class","commands",k,CommandList,&config_f); +00151 log(DEBUG,"*** HasPermission: found class named %s with commands: '%s'",ClassName,CommandList); +00152 +00153 +00154 mycmd = strtok_r(CommandList," ",&savept2); +00155 while (mycmd) +00156 { +00157 if (!strcasecmp(mycmd,command)) +00158 { +00159 log(DEBUG,"*** Command %s found, returning true",command); +00160 return true; +00161 } +00162 mycmd = strtok_r(NULL," ",&savept2); +00163 } +00164 } +00165 } +00166 myclass = strtok_r(NULL," ",&savept); +00167 } +00168 } +00169 } +00170 } +00171 return false; +00172 } +00173 +00174 +00175 bool userrec::AddBuffer(std::string a) +00176 { +00177 std::string b = ""; +00178 for (int i = 0; i < a.length(); i++) +00179 if ((a[i] != '\r') && (a[i] != '\0') && (a[i] != 7)) +00180 b = b + a[i]; +00181 std::stringstream stream(recvq); +00182 stream << b; +00183 recvq = stream.str(); +00184 int i = 0; +00185 // count the size of the first line in the buffer. +00186 while (i < recvq.length()) +00187 { +00188 if (recvq[i++] == '\n') +00189 break; +00190 } +00191 if (recvq.length() > this->recvqmax) +00192 { +00193 this->SetWriteError("RecvQ exceeded"); +00194 WriteOpers("*** User %s RecvQ of %d exceeds connect class maximum of %d",this->nick,recvq.length(),this->recvqmax); +00195 } +00196 // return false if we've had more than 600 characters WITHOUT +00197 // a carriage return (this is BAD, drop the socket) +00198 return (i < 600); +00199 } +00200 +00201 bool userrec::BufferIsReady() +00202 { +00203 for (int i = 0; i < recvq.length(); i++) +00204 if (recvq[i] == '\n') +00205 return true; +00206 return false; +00207 } +00208 +00209 void userrec::ClearBuffer() +00210 { +00211 recvq = ""; +00212 } +00213 +00214 std::string userrec::GetBuffer() +00215 { +00216 if (recvq == "") +00217 return ""; +00218 char* line = (char*)recvq.c_str(); +00219 std::string ret = ""; +00220 while ((*line != '\n') && (strlen(line))) +00221 { +00222 ret = ret + *line; +00223 line++; +00224 } +00225 if ((*line == '\n') || (*line == '\r')) +00226 line++; +00227 recvq = line; +00228 return ret; +00229 } +00230 +00231 void userrec::AddWriteBuf(std::string data) +00232 { +00233 if (this->GetWriteError() != "") +00234 return; +00235 if (sendq.length() + data.length() > this->sendqmax) +00236 { +00237 WriteOpers("*** User %s SendQ of %d exceeds connect class maximum of %d",this->nick,sendq.length() + data.length(),this->sendqmax); +00238 this->SetWriteError("SendQ exceeded"); +00239 return; +00240 } +00241 std::stringstream stream; +00242 stream << sendq << data; +00243 sendq = stream.str(); +00244 } +00245 +00246 // send AS MUCH OF THE USERS SENDQ as we are able to (might not be all of it) +00247 void userrec::FlushWriteBuf() +00248 { +00249 if (sendq.length()) +00250 { +00251 char* tb = (char*)this->sendq.c_str(); +00252 int n_sent = write(this->fd,tb,this->sendq.length()); +00253 if (n_sent == -1) +00254 { +00255 this->SetWriteError(strerror(errno)); +00256 } +00257 else +00258 { +00259 // advance the queue +00260 tb += n_sent; +00261 this->sendq = tb; +00262 // update the user's stats counters +00263 this->bytes_out += n_sent; +00264 this->cmds_out++; +00265 } +00266 } +00267 } +00268 +00269 void userrec::SetWriteError(std::string error) +00270 { +00271 log(DEBUG,"Setting error string for %s to '%s'",this->nick,error.c_str()); +00272 // don't try to set the error twice, its already set take the first string. +00273 if (this->WriteError == "") +00274 this->WriteError = error; +00275 } +00276 +00277 std::string userrec::GetWriteError() +00278 { +00279 return this->WriteError; +00280 } +

    Generated on Sun May 15 17:02:06 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/users_8cpp.html b/docs/module-doc/users_8cpp.html index 1fcfca347..8a30d8f8f 100644 --- a/docs/module-doc/users_8cpp.html +++ b/docs/module-doc/users_8cpp.html @@ -4,13 +4,14 @@ - +

    users.cpp File Reference

    #include "inspircd_config.h"
    #include "channels.h"
    #include "users.h"
    #include "inspircd.h"
    #include <stdio.h>
    #include "inspstring.h"
    +#include "helperfuncs.h"

    Include dependency graph for users.cpp:

    Include dependency graph
    @@ -50,7 +51,7 @@ Include dependency graph for users.cpp:

    24 of file users.cpp. +Definition at line 25 of file users.cpp.

    @@ -74,10 +75,10 @@ Definition at line 24 of

    -Definition at line 26 of file users.cpp. +Definition at line 27 of file users.cpp. -


    Generated on Fri May 13 15:49:14 2005 for InspIRCd by +
    Generated on Sun May 15 17:02:49 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/users_8cpp__incl.gif b/docs/module-doc/users_8cpp__incl.gif index 4203b57ebd6006b431ff5f532a7e273adfa85bd4..97c4fd61005d7c0b39ed11513d28e1da83b79813 100644 GIT binary patch delta 4304 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 diff --git a/docs/module-doc/users_8h-source.html b/docs/module-doc/users_8h-source.html index a07350688..b42643395 100644 --- a/docs/module-doc/users_8h-source.html +++ b/docs/module-doc/users_8h-source.html @@ -4,7 +4,7 @@ - +

    users.h

    Go to the documentation of this file.
    00001 /*       +------------------------------------+
     00002  *       | Inspire Internet Relay Chat Daemon |
     00003  *       +------------------------------------+
    @@ -165,22 +165,23 @@
     00302 
     00309         void FlushWriteBuf();
     00310 
    -00311 };
    -00312 
    -00315 class WhoWasUser
    -00316 {
    -00317  public:
    -00318         char nick[NICKMAX];
    -00319         char ident[16];
    -00320         char dhost[160];
    -00321         char host[160];
    -00322         char fullname[128];
    -00323         char server[256];
    -00324         time_t signon;
    -00325 };
    -00326 
    -00327 #endif
    -

    Generated on Fri May 13 15:48:42 2005 for InspIRCd by +00313 InvitedList* GetInviteList(); +00314 }; +00315 +00318 class WhoWasUser +00319 { +00320 public: +00321 char nick[NICKMAX]; +00322 char ident[16]; +00323 char dhost[160]; +00324 char host[160]; +00325 char fullname[128]; +00326 char server[256]; +00327 time_t signon; +00328 }; +00329 +00330 #endif +

    Generated on Sun May 15 17:02:06 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/users_8h.html b/docs/module-doc/users_8h.html index 2770d9134..7dbbb6bb4 100644 --- a/docs/module-doc/users_8h.html +++ b/docs/module-doc/users_8h.html @@ -4,7 +4,7 @@ - +

    users.h File Reference

    #include "inspircd_config.h"
    #include "channels.h"
    #include "connection.h"
    @@ -262,10 +262,12 @@ Holds a complete list of all channels to which a user has been invited and has n

    -Definition at line 94 of file users.h. +Definition at line 94 of file users.h. +

    +Referenced by userrec::GetInviteList(). -


    Generated on Fri May 13 15:49:16 2005 for InspIRCd by +
    Generated on Sun May 15 17:02:52 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/xline_8h-source.html b/docs/module-doc/xline_8h-source.html index d5bcc75f0..66d7e8b30 100644 --- a/docs/module-doc/xline_8h-source.html +++ b/docs/module-doc/xline_8h-source.html @@ -4,7 +4,7 @@ - +

    xline.h

    Go to the documentation of this file.
    00001 /*       +------------------------------------+
     00002  *       | Inspire Internet Relay Chat Daemon |
     00003  *       +------------------------------------+
    @@ -123,7 +123,7 @@
     00157 void sync_xlines(serverrec* serv, char* tcp_host);
     00158 
     00159 #endif
    -

    Generated on Fri May 13 15:48:42 2005 for InspIRCd by +

    Generated on Sun May 15 17:02:06 2005 for InspIRCd by doxygen 1.3.3
    diff --git a/docs/module-doc/xline_8h.html b/docs/module-doc/xline_8h.html index e8ca32b26..82b18ac7a 100644 --- a/docs/module-doc/xline_8h.html +++ b/docs/module-doc/xline_8h.html @@ -4,7 +4,7 @@ - +

    xline.h File Reference

    #include <typeinfo>
    #include <iostream>
    #include <string>
    @@ -159,7 +159,7 @@ This graph shows which files directly or indirectly include this file:

    -Referenced by Server::AddELine(). +Referenced by Server::AddELine().

    @@ -211,7 +211,7 @@ Referenced by Server::AddEL

    -Referenced by Server::AddGLine(). +Referenced by Server::AddGLine().

    @@ -263,7 +263,7 @@ Referenced by Server::AddGL

    -Referenced by Server::AddKLine(). +Referenced by Server::AddKLine().

    @@ -315,7 +315,7 @@ Referenced by Server::AddKL

    -Referenced by Server::AddQLine(). +Referenced by Server::AddQLine().

    @@ -367,7 +367,7 @@ Referenced by Server::AddQL

    -Referenced by Server::AddZLine(). +Referenced by Server::AddZLine().

    @@ -426,7 +426,7 @@ Referenced by Server::AddZL

    -Referenced by Server::DelELine(). +Referenced by Server::DelELine().

    @@ -457,7 +457,7 @@ Referenced by Server::DelEL

    -Referenced by Server::DelGLine(). +Referenced by Server::DelGLine().

    @@ -488,7 +488,7 @@ Referenced by Server::DelGL

    -Referenced by Server::DelKLine(). +Referenced by Server::DelKLine().

    @@ -519,7 +519,7 @@ Referenced by Server::DelKL

    -Referenced by Server::DelQLine(). +Referenced by Server::DelQLine().

    @@ -550,7 +550,7 @@ Referenced by Server::DelQL

    -Referenced by Server::DelZLine(). +Referenced by Server::DelZLine().

    @@ -1109,7 +1109,7 @@ Referenced by Server::DelZL -


    Generated on Fri May 13 15:49:17 2005 for InspIRCd by +
    Generated on Sun May 15 17:02:54 2005 for InspIRCd by doxygen 1.3.3
    -- 2.39.5