X-Git-Url: https://git.quassel-irc.org/?a=blobdiff_plain;f=src%2Fcommon%2Fircuser.h;h=45be422035185eb653ec8acc523c97369c0e1e26;hb=4295cdd849be0ae914387d0f62afb6f653f5f27f;hp=e933fb61fc6081252ec23cc14a1a78bf2bf4fb79;hpb=27be9c5a706bf690921617bf66614c4479550c4d;p=quassel.git diff --git a/src/common/ircuser.h b/src/common/ircuser.h index e933fb61..45be4220 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 Network; class IrcChannel; -class IrcUser : public QObject { +class IrcUser : public SyncableObject { Q_OBJECT Q_PROPERTY(QString user READ user WRITE setUser STORED false) @@ -40,22 +42,31 @@ 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); + IrcUser(const QString &hostmask, Network *network); virtual ~IrcUser(); - bool initialized() const; - QString user() const; QString host() const; QString nick() const; QString hostmask() const; + Network *network() const; QString userModes() const; 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); @@ -63,7 +74,7 @@ public slots: void updateHostmask(const QString &mask); void setUserModes(const QString &modes); - + void joinChannel(IrcChannel *channel); void joinChannel(const QString &channelname); void partChannel(IrcChannel *channel); @@ -75,16 +86,14 @@ public slots: // init seters void initSetChannels(const QStringList channels); - void setInitialized(); - signals: void userSet(QString user); void hostSet(QString host); void nickSet(QString newnick); void hostmaskUpdated(QString mask); - + void userModesSet(QString modes); - + void channelJoined(QString channel); void channelParted(QString channel); @@ -92,16 +101,14 @@ signals: void userModeRemoved(QString mode); void renameObject(QString oldname, QString newname); - + // void setUsermodes(const QSet &usermodes); // QSet usermodes() const; - void initDone(); - private slots: void updateObjectName(); void channelDestroyed(); - + private: inline bool operator==(const IrcUser &ircuser2) { return (_nick.toLower() == ircuser2.nick().toLower()); @@ -120,8 +127,11 @@ private: // QSet _channels; QSet _channels; QString _userModes; - - NetworkInfo *networkInfo; + + Network *_network; + + QTextCodec *_codecForEncoding; + QTextCodec *_codecForDecoding; }; #endif