X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=include%2Fcull_list.h;h=96d5a83c5121fec27627d81be95aab6f8f40fcc4;hb=d54fd9b1e6b31f69332a9241b5f17330c0ad61e0;hp=e20eb1dd07b46f86bc54402db687ab07440ed52a;hpb=7a3d08f06cc22688a70c5274fe0dd489f93e9794;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/include/cull_list.h b/include/cull_list.h index e20eb1dd0..96d5a83c5 100644 --- a/include/cull_list.h +++ b/include/cull_list.h @@ -28,12 +28,14 @@ #include "users.h" #include "channels.h" +class InspIRCd; + /** The CullItem class holds a user and their quitmessage, * and is used internally by the CullList class to compile * a list of users which are to be culled when a long * operation (such as a netsplit) has completed. */ -class CullItem +class CullItem : public classbase { private: /** Holds a pointer to the user, @@ -42,7 +44,7 @@ class CullItem userrec* user; /** Holds the quit reason to use for this user. */ - std::string reason; + std::string reason; public: /** Constrcutor. * Initializes the CullItem with a user pointer @@ -51,12 +53,16 @@ class CullItem * @param r The quit reason of the added user */ CullItem(userrec* u, std::string &r); + CullItem(userrec* u, const char* r); + + ~CullItem(); + /** Returns a pointer to the user */ userrec* GetUser(); /** Returns the user's quit reason */ - std::string GetReason(); + std::string& GetReason(); }; /** The CullList class can be used by modules, and is used @@ -72,9 +78,12 @@ class CullItem * you attempt to add the same user twice, then the second * attempt will be ignored. */ -class CullList +class CullList : public classbase { private: + /** Creator of this CullList + */ + InspIRCd* ServerInstance; /** Holds a list of users being quit. * See the information for CullItem for * more information. @@ -97,14 +106,16 @@ class CullList /** Constructor. * Clears the CullList::list and CullList::exempt * items. + * @param Instance Creator of this CullList object */ - CullList(); + CullList(InspIRCd* Instance); /** Adds a user to the cull list for later * removal via QUIT. * @param user The user to add * @param reason The quit reason of the user being added */ void AddItem(userrec* user, std::string &reason); + void AddItem(userrec* user, const char* reason); /** Applies the cull list, quitting all the users * on the list with their quit reasons all at once. * This is a very fast operation compared to