]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - include/users.h
Removed has_channel(userrec*,chanrec*), the new preferred way of doing it is channel...
[user/henk/code/inspircd.git] / include / users.h
index 3b1ff5003386981ffe29381e0f4f33344a08c084..71563abfa9354f482d8a3979f3cae52b3ed2ae62 100644 (file)
@@ -37,7 +37,7 @@
 #define CC_ALLOW       0
 #define CC_DENY                1
 
-template<typename T> inline string ConvToStr(const T &in);
+template<typename T> string ConvToStr(const T &in);
 
 /** Holds a channel name to which a user has been invited.
  */
@@ -340,28 +340,36 @@ class userrec : public connection
 #endif
 };
 
-/** A lightweight userrec used by WHOWAS
- */
-class WhoWasUser
+class WhoWasGroup
 {
  public:
-       char nick[NICKMAX];
-       char ident[IDENTMAX+1];
-       char dhost[64];
-       char host[64];
-       char fullname[MAXGECOS+1];
-       char server[256];
+       char* host;
+       char* dhost;
+       char* ident;
+       char* server;
+       char* gecos;
        time_t signon;
+
+       WhoWasGroup(userrec* user);
+       ~WhoWasGroup();
 };
 
+typedef std::deque<WhoWasGroup*> whowas_set;
+typedef std::map<irc::string,whowas_set*> whowas_users;
+
+/** A lightweight userrec used by WHOWAS
+ */
+
 void AddOper(userrec* user);
 void DeleteOper(userrec* user);
 void kill_link(userrec *user,const char* r);
 void kill_link_silent(userrec *user,const char* r);
 void AddWhoWas(userrec* u);
+void MaintainWhoWas(time_t TIME);
 void AddClient(int socket, int port, bool iscached, in_addr ip4);
 void FullConnectUser(userrec* user, CullList* Goners);
 userrec* ReHashNick(char* Old, char* New);
 void force_nickchange(userrec* user,const char* newnick);
+void ReadClassesAndTypes();
 
 #endif