X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fircchannel.h;h=564eda89c70664aa53dc0bfbe6f9518b3d4e99e3;hp=2840b5240cc05a66367baa0bcaeeb6a3cf93d72d;hb=5e9a649d94d1832e0b4f3f296e8a2df2d8741d9b;hpb=fd7c2c4a41b5bb9cffcfe7a8f86a28ab7f38ac27 diff --git a/src/common/ircchannel.h b/src/common/ircchannel.h index 2840b524..564eda89 100644 --- a/src/common/ircchannel.h +++ b/src/common/ircchannel.h @@ -18,10 +18,11 @@ * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. * ***************************************************************************/ -#ifndef _IRCCHANNEL_H_ -#define _IRCCHANNEL_H_ +#ifndef IRCCHANNEL_H +#define IRCCHANNEL_H #include +#include #include #include #include @@ -30,13 +31,14 @@ class IrcUser; class Network; -class SignalProxy; class IrcChannel : public SyncableObject { + SYNCABLE_OBJECT Q_OBJECT Q_PROPERTY(QString name READ name STORED false) Q_PROPERTY(QString topic READ topic WRITE setTopic STORED false) + Q_PROPERTY(QString password READ password WRITE setPassword STORED false) public: IrcChannel(const QString &channelname, Network *network); @@ -45,31 +47,38 @@ public: bool isKnownUser(IrcUser *ircuser) const; bool isValidChannelUserMode(const QString &mode) const; - bool initialized() const; + inline QString name() const { return _name; } + inline QString topic() const { return _topic; } + inline QString password() const { return _password; } + inline Network *network() const { return _network; } - QString name() const; - QString topic() const; - - QList ircUsers() const; + inline QList ircUsers() const { return _userModes.keys(); } QString userModes(IrcUser *ircuser) const; QString userModes(const QString &nick) const; - QTextCodec *codecForEncoding() const; - QTextCodec *codecForDecoding() const; + bool hasMode(const QChar &mode) const; + QString modeValue(const QChar &mode) const; + QStringList modeValueList(const QChar &mode) const; + QString channelModeString() const; + + inline QTextCodec *codecForEncoding() const { return _codecForEncoding; } + inline QTextCodec *codecForDecoding() const { return _codecForDecoding; } 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; + QByteArray encodeString(const QString &string) const; public slots: void setTopic(const QString &topic); + void setPassword(const QString &password); - void join(IrcUser *ircuser); - void join(const QString &nick); + void joinIrcUsers(const QList &users, const QStringList &modes); + void joinIrcUsers(const QStringList &nicks, const QStringList &modes); + void joinIrcUser(IrcUser *ircuser); void part(IrcUser *ircuser); void part(const QString &nick); @@ -83,31 +92,35 @@ public slots: void removeUserMode(IrcUser *ircuser, const QString &mode); void removeUserMode(const QString &nick, const QString &mode); + void addChannelMode(const QChar &mode, const QString &value); + void removeChannelMode(const QChar &mode, const QString &value); + // init geters QVariantMap initUserModes() const; + QVariantMap initChanModes() const; // init seters void initSetUserModes(const QVariantMap &usermodes); - - void setInitialized(); + void initSetChanModes(const QVariantMap &chanModes); signals: - void topicSet(QString topic); - void userModesSet(QString nick, QString modes); - //void userModesSet(IrcUser *ircuser, QString modes); - void userModeAdded(QString nick, QString mode); - //void userModeAdded(IrcUser *ircuser, QString mode); - void userModeRemoved(QString nick, QString mode); - //void userModeRemoved(IrcUser *ircuser, QString mode); - - void ircUserJoined(IrcUser *ircuser); + void topicSet(const QString &topic); // needed by NetworkModel +// void passwordSet(const QString &password); +// void userModesSet(QString nick, QString modes); +// void userModeAdded(QString nick, QString mode); +// void userModeRemoved(QString nick, QString mode); +// void channelModeAdded(const QChar &mode, const QString &value); +// void channelModeRemoved(const QChar &mode, const QString &value); + + void ircUsersJoined(QList ircusers); +// void ircUsersJoined(QStringList nicks, QStringList modes); void ircUserParted(IrcUser *ircuser); void ircUserNickSet(IrcUser *ircuser, QString nick); void ircUserModeAdded(IrcUser *ircuser, QString mode); void ircUserModeRemoved(IrcUser *ircuser, QString mode); void ircUserModesSet(IrcUser *ircuser, QString modes); - void initDone(); + void parted(); // convenience signal emitted before channels destruction private slots: void ircUserDestroyed(); @@ -117,13 +130,19 @@ private: bool _initialized; QString _name; QString _topic; + QString _password; QHash _userModes; - Network *network; + Network *_network; QTextCodec *_codecForEncoding; QTextCodec *_codecForDecoding; + + QHash _A_channelModes; + QHash _B_channelModes; + QHash _C_channelModes; + QSet _D_channelModes; }; #endif