X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=include%2Fmembership.h;h=44eaf1eb6c2d39f404b8c144b6b047ec40c7c722;hb=b15cffc167391fc8af6cab52061d4b591ec5bbf8;hp=b0924bef72fe5f6f75d066a627bcb52e3849727b;hpb=932e8d13f81c7c94a89dc3702f6d45bc185f5dcf;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/include/membership.h b/include/membership.h index b0924bef7..44eaf1eb6 100644 --- a/include/membership.h +++ b/include/membership.h @@ -43,12 +43,29 @@ class CoreExport Membership : public Extensible, public intrusive_list_node +class InviteBase { protected: - InviteList invites; + intrusive_list invites; public: void ClearInvites(); @@ -56,7 +73,7 @@ class CoreExport InviteBase friend class Invitation; }; -class CoreExport Invitation : public classbase +class CoreExport Invitation : public intrusive_list_node, public intrusive_list_node { Invitation(Channel* c, LocalUser* u, time_t timeout) : user(u), chan(c), expiry(timeout) {} @@ -69,3 +86,16 @@ class CoreExport Invitation : public classbase static void Create(Channel* c, LocalUser* u, time_t timeout); static Invitation* Find(Channel* c, LocalUser* u, bool check_expired = true); }; + +typedef intrusive_list InviteList; + +template +inline void InviteBase::ClearInvites() +{ + for (typename intrusive_list::iterator i = invites.begin(); i != invites.end(); ) + { + Invitation* inv = *i; + ++i; + delete inv; + } +}