X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fclient%2Fclient.h;h=c3172a7f9e446d7f90b32f4fc51026b27dd82a0a;hp=127a07f87575accbf120ccb087344f71cf60cdfc;hb=93605206bc40e06446efabc71e155a3216dbb0b9;hpb=54ead1bace1c9306ccfd5ebd7fb7bbd0c9843db7 diff --git a/src/client/client.h b/src/client/client.h index 127a07f8..c3172a7f 100644 --- a/src/client/client.h +++ b/src/client/client.h @@ -18,8 +18,7 @@ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * ***************************************************************************/ -#ifndef CLIENT_H_ -#define CLIENT_H_ +#pragma once #include #include @@ -27,6 +26,7 @@ #include "bufferinfo.h" #include "coreaccount.h" #include "coreconnection.h" +#include "highlightrulemanager.h" #include "quassel.h" #include "types.h" @@ -122,15 +122,16 @@ public: static inline ClientUserInputHandler *inputHandler() { return instance()->_inputHandler; } static inline NetworkConfig *networkConfig() { return instance()->_networkConfig; } static inline ClientIgnoreListManager *ignoreListManager() { return instance()->_ignoreListManager; } + static inline HighlightRuleManager *highlightRuleManager() { return instance()->_highlightRuleManager; } static inline ClientTransferManager *transferManager() { return instance()->_transferManager; } static inline TransferModel *transferModel() { return instance()->_transferModel; } + static inline BufferSyncer *bufferSyncer() { return instance()->_bufferSyncer; } + static inline CoreAccountModel *coreAccountModel() { return instance()->_coreAccountModel; } static inline CoreConnection *coreConnection() { return instance()->_coreConnection; } static inline CoreAccount currentCoreAccount() { return coreConnection()->currentAccount(); } - static inline Quassel::Features coreFeatures() { return _coreFeatures; } - - static void setCoreFeatures(Quassel::Features features); + static bool isCoreFeatureEnabled(Quassel::Feature feature); static bool isConnected(); static bool internalCore(); @@ -147,6 +148,11 @@ public: static void purgeKnownBufferIds(); static void changePassword(const QString &oldPassword, const QString &newPassword); + static void kickClient(int peerId); + + void displayIgnoreList(QString ignoreRule) { + emit showIgnoreList(ignoreRule); + } #if QT_VERSION < 0x050000 static void logMessage(QtMsgType type, const char *msg); @@ -155,10 +161,16 @@ public: #endif static inline const QString &debugLog() { return instance()->_debugLogBuffer; } + void displayChannelList(NetworkId networkId) { + emit showChannelList(networkId); + } + signals: void requestNetworkStates(); void showConfigWizard(const QVariantMap &coredata); + void showChannelList(NetworkId networkId); + void showIgnoreList(QString ignoreRule); void connected(); void disconnected(); @@ -199,6 +211,8 @@ signals: //! Requests a password change (user name must match the currently logged in user) void requestPasswordChange(PeerPtr peer, const QString &userName, const QString &oldPassword, const QString &newPassword); + + void requestKickClient(int peerId); void passwordChanged(bool success); public slots: @@ -238,7 +252,6 @@ private: void requestInitialBacklog(); static void addNetwork(Network *); - static inline BufferSyncer *bufferSyncer() { return instance()->_bufferSyncer; } static QPointer instanceptr; @@ -256,6 +269,7 @@ private: ClientUserInputHandler *_inputHandler; NetworkConfig *_networkConfig; ClientIgnoreListManager *_ignoreListManager; + HighlightRuleManager *_highlightRuleManager; ClientTransferManager *_transferManager; TransferModel *_transferModel; @@ -271,7 +285,6 @@ private: QHash _identities; bool _connected; - static Quassel::Features _coreFeatures; QString _debugLogBuffer; QTextStream _debugLog; @@ -280,6 +293,3 @@ private: friend class CoreConnection; }; - - -#endif