X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcommon%2Fircuser.h;h=41c1792f9da6c872d6f2060dabf3cffe38b357b9;hb=2e6dc76ae100a6b8e1b1661e422995f90083500e;hp=cba3d03c8ed99f267a0814fd3c84c1561a1fc780;hpb=d6b056e936ec441258d291b7a8af7b83f9f53016;p=quassel.git diff --git a/src/common/ircuser.h b/src/common/ircuser.h index cba3d03c..41c1792f 100644 --- a/src/common/ircuser.h +++ b/src/common/ircuser.h @@ -1,5 +1,5 @@ /*************************************************************************** - * Copyright (C) 2005-07 by the Quassel IRC Team * + * Copyright (C) 2005-08 by the Quassel Project * * devel@quassel-irc.org * * * * This program is free software; you can redistribute it and/or modify * @@ -26,11 +26,13 @@ #include #include +#include "syncableobject.h" + class SignalProxy; class NetworkInfo; class IrcChannel; -class IrcUser : public QObject { +class IrcUser : public SyncableObject { Q_OBJECT Q_PROPERTY(QString user READ user WRITE setUser STORED false) @@ -40,7 +42,6 @@ class IrcUser : public QObject { Q_PROPERTY(QStringList channels READ channels STORED false) // Q_PROPERTY(QStringList usermodes READ usermodes WRITE setUsermodes) - public: IrcUser(const QString &hostmask, NetworkInfo *networkInfo); virtual ~IrcUser(); @@ -56,6 +57,17 @@ public: QStringList channels() const; + // user-specific encodings + QTextCodec *codecForEncoding() const; + QTextCodec *codecForDecoding() const; + void setCodecForEncoding(const QString &codecName); + void setCodecForEncoding(QTextCodec *codec); + void setCodecForDecoding(const QString &codecName); + void setCodecForDecoding(QTextCodec *codec); + + QString decodeString(const QByteArray &text) const; + QByteArray encodeString(const QString string) const; + public slots: void setUser(const QString &user); void setHost(const QString &host); @@ -64,8 +76,10 @@ public slots: void setUserModes(const QString &modes); - void joinChannel(const QString &channel); - void partChannel(const QString &channel); + void joinChannel(IrcChannel *channel); + void joinChannel(const QString &channelname); + void partChannel(IrcChannel *channel); + void partChannel(const QString &channelname); void addUserMode(const QString &mode); void removeUserMode(const QString &mode); @@ -80,10 +94,9 @@ signals: void hostSet(QString host); void nickSet(QString newnick); void hostmaskUpdated(QString mask); - - void channelsSet(QStringList channels); + void userModesSet(QString modes); - + void channelJoined(QString channel); void channelParted(QString channel); @@ -91,7 +104,7 @@ signals: void userModeRemoved(QString mode); void renameObject(QString oldname, QString newname); - + // void setUsermodes(const QSet &usermodes); // QSet usermodes() const; @@ -99,7 +112,8 @@ signals: private slots: void updateObjectName(); - + void channelDestroyed(); + private: inline bool operator==(const IrcUser &ircuser2) { return (_nick.toLower() == ircuser2.nick().toLower()); @@ -115,10 +129,14 @@ private: QString _user; QString _host; - QSet _channels; + // QSet _channels; + QSet _channels; QString _userModes; - + NetworkInfo *networkInfo; + + QTextCodec *_codecForEncoding; + QTextCodec *_codecForDecoding; }; #endif