X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fircchannel.h;h=7f7d04a80de083ab7da539eb9e4c832bd1213b7a;hp=26340ce6fbbb595dc1d8d3af30c698c23220f6f8;hb=20b5edb626156df8c472df8250b5f2faaf37835e;hpb=56607f81246f04db3a0e71c9a8757d7f75d6cfcf diff --git a/src/common/ircchannel.h b/src/common/ircchannel.h index 26340ce6..7f7d04a8 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,9 +31,9 @@ class IrcUser; class Network; -class SignalProxy; class IrcChannel : public SyncableObject { + SYNCABLE_OBJECT Q_OBJECT Q_PROPERTY(QString name READ name STORED false) @@ -55,6 +56,11 @@ public: QString userModes(IrcUser *ircuser) const; QString userModes(const QString &nick) 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); @@ -71,8 +77,7 @@ public slots: void joinIrcUsers(const QList &users, const QStringList &modes); void joinIrcUsers(const QStringList &nicks, const QStringList &modes); - void joinIrcUsers(IrcUser *ircuser); - void joinIrcUsers(const QString &nick); + void joinIrcUser(IrcUser *ircuser); void part(IrcUser *ircuser); void part(const QString &nick); @@ -86,30 +91,36 @@ 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 initSetChanModes(const QVariantMap &chanModes); signals: - void topicSet(const QString &topic); - void passwordSet(const QString &password); - 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 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 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 parted(); // convenience signal emitted before channels destruction + private slots: void ircUserDestroyed(); void ircUserNickSet(QString nick); @@ -126,6 +137,12 @@ private: QTextCodec *_codecForEncoding; QTextCodec *_codecForDecoding; + + QHash _A_channelModes; + QHash _B_channelModes; + QHash _C_channelModes; + QSet _D_channelModes; + }; #endif