X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcommon%2Fircuser.h;h=f624fb41916e1318d6418aaad819e7bd2833a20e;hb=04c923c596fbde976b23979b92b0636635f97951;hp=f2f84ff01fcefaabc6671474b5c2b709ded354cc;hpb=09312db1a755642802ff15595900878fbe76b21a;p=quassel.git diff --git a/src/common/ircuser.h b/src/common/ircuser.h index f2f84ff0..f624fb41 100644 --- a/src/common/ircuser.h +++ b/src/common/ircuser.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-08 by the Quassel Project * + * Copyright (C) 2005-09 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -18,8 +18,8 @@ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ -#ifndef _IRCUSER_H_ -#define _IRCUSER_H_ +#ifndef IRCUSER_H +#define IRCUSER_H #include #include @@ -28,9 +28,10 @@ #include #include "syncableobject.h" -#include "network.h" +#include "types.h" class SignalProxy; +class Network; class IrcChannel; class IrcUser : public SyncableObject { @@ -57,13 +58,13 @@ public: IrcUser(const QString &hostmask, Network *network); virtual ~IrcUser(); - inline QString user() const { return network()->decodeServerString(_user); } - inline QString host() const { return network()->decodeServerString(_host); } - inline QString nick() const { return network()->decodeServerString(_nick); } - inline QString realName() const { return network()->decodeServerString(_realName); } + inline QString user() const { return _user; } + inline QString host() const { return _host; } + inline QString nick() const { return _nick; } + inline QString realName() const { return _realName; } QString hostmask() const; inline bool isAway() const { return _away; } - inline QString awayMessage() const { return network()->decodeServerString(_awayMessage); } + inline QString awayMessage() const { return _awayMessage; } QDateTime idleTime(); inline QDateTime loginTime() const { return _loginTime; } inline QString server() const { return _server; } @@ -88,6 +89,12 @@ public: QString decodeString(const QByteArray &text) const; QByteArray encodeString(const QString &string) const; + // only valid on client side, these are not synced! + inline QDateTime lastChannelActivity(BufferId id) const { return _lastActivity.value(id); } + void setLastChannelActivity(BufferId id, const QDateTime &time); + inline QDateTime lastSpokenTo(BufferId id) const { return _lastSpokenTo.value(id); } + void setLastSpokenTo(BufferId id, const QDateTime &time); + public slots: void setUser(const QString &user); void setHost(const QString &host); @@ -110,6 +117,7 @@ public slots: void joinChannel(const QString &channelname); void partChannel(IrcChannel *channel); void partChannel(const QString &channelname); + void quit(); void addUserModes(const QString &modes); void removeUserModes(const QString &modes); @@ -134,10 +142,14 @@ signals: // void channelJoined(QString channel); void channelParted(QString channel); + void quited(); void userModesAdded(QString modes); void userModesRemoved(QString modes); + void lastChannelActivityUpdated(BufferId id, const QDateTime &newTime); + void lastSpokenToUpdated(BufferId id, const QDateTime &newTime); + private slots: void updateObjectName(); void channelDestroyed(); @@ -153,11 +165,11 @@ private: bool _initialized; - QByteArray _nick; - QByteArray _user; - QByteArray _host; - QByteArray _realName; - QByteArray _awayMessage; + QString _nick; + QString _user; + QString _host; + QString _realName; + QString _awayMessage; bool _away; QString _server; QDateTime _idleTime; @@ -176,6 +188,9 @@ private: QTextCodec *_codecForEncoding; QTextCodec *_codecForDecoding; + + QHash _lastActivity; + QHash _lastSpokenTo; }; #endif