src: Yearly copyright bump
[quassel.git] / src / client / client.h
index 00c9c97..944b344 100644 (file)
@@ -1,5 +1,5 @@
 /***************************************************************************
- *   Copyright (C) 2005-2018 by the Quassel Project                        *
+ *   Copyright (C) 2005-2020 by the Quassel Project                        *
  *   devel@quassel-irc.org                                                 *
  *                                                                         *
  *   This program is free software; you can redistribute it and/or modify  *
 
 #pragma once
 
+#include "client-export.h"
+
+#include <memory>
+
 #include <QList>
 #include <QPointer>
 
 #include "bufferinfo.h"
-#include "coreinfo.h"
 #include "coreaccount.h"
 #include "coreconnection.h"
+#include "coreinfo.h"
 #include "highlightrulemanager.h"
 #include "quassel.h"
+#include "singleton.h"
 #include "types.h"
 
 class Message;
@@ -63,89 +68,89 @@ class TransferModel;
 
 struct NetworkInfo;
 
-class Client : public QObject
+class CLIENT_EXPORT Client : public QObject, public Singleton<Client>
 {
     Q_OBJECT
 
 public:
-    enum ClientMode {
+    enum ClientMode
+    {
         LocalCore,
         RemoteCore
     };
 
-    static bool instanceExists();
-    static Client *instance();
-    static void destroy();
-    static void init(AbstractUi *);
-    static AbstractUi *mainUi();
+    Client(std::unique_ptr<AbstractUi>, QObject* parent = nullptr);
+    ~Client() override;
+
+    static AbstractUi* mainUi();
 
     static QList<NetworkId> networkIds();
-    static const Network *network(NetworkId);
+    static const Networknetwork(NetworkId);
 
     static QList<IdentityId> identityIds();
-    static const Identity *identity(IdentityId);
+    static const Identityidentity(IdentityId);
 
     //! Request creation of an identity with the given data.
     /** The request will be sent to the core, and will be propagated back to all the clients
      *  with a new valid IdentityId.
      *  \param identity The identity template for the new identity. It does not need to have a valid ID.
      */
-    static void createIdentity(const CertIdentity &identity);
+    static void createIdentity(const CertIdentityidentity);
 
     //! Request update of an identity with the given data.
     /** The request will be sent to the core, and will be propagated back to all the clients.
      *  \param id The identity to be updated.
      *  \param serializedData The identity's content (cf. SyncableObject::toVariantMap())
      */
-    static void updateIdentity(IdentityId id, const QVariantMap &serializedData);
+    static void updateIdentity(IdentityId id, const QVariantMapserializedData);
 
     //! Request removal of the identity with the given ID from the core (and all the clients, of course).
     /** \param id The ID of the identity to be removed.
      */
     static void removeIdentity(IdentityId id);
 
-    static void createNetwork(const NetworkInfo &info, const QStringList &persistentChannels = QStringList());
-    static void updateNetwork(const NetworkInfo &info);
+    static void createNetwork(const NetworkInfo& info, const QStringList& persistentChannels = QStringList());
+    static void updateNetwork(const NetworkInfoinfo);
     static void removeNetwork(NetworkId id);
 
-    static inline NetworkModel *networkModel() { return instance()->_networkModel; }
-    static inline BufferModel *bufferModel() { return instance()->_bufferModel; }
-    static inline MessageModel *messageModel() { return instance()->_messageModel; }
-    static inline AbstractMessageProcessor *messageProcessor() { return instance()->_messageProcessor; }
-    static inline SignalProxy *signalProxy() { return instance()->_signalProxy; }
-
-    static inline ClientAliasManager *aliasManager() { return instance()->_aliasManager; }
-    static inline ClientBacklogManager *backlogManager() { return instance()->_backlogManager; }
-    static inline CoreInfo *coreInfo() { return instance()->_coreInfo; }
-    static inline DccConfig *dccConfig() { return instance()->_dccConfig; }
-    static inline ClientIrcListHelper *ircListHelper() { return instance()->_ircListHelper; }
-    static inline ClientBufferViewManager *bufferViewManager() { return instance()->_bufferViewManager; }
-    static inline BufferViewOverlay *bufferViewOverlay() { return instance()->_bufferViewOverlay; }
-    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 NetworkModelnetworkModel() { return instance()->_networkModel; }
+    static inline BufferModelbufferModel() { return instance()->_bufferModel; }
+    static inline MessageModelmessageModel() { return instance()->_messageModel; }
+    static inline AbstractMessageProcessormessageProcessor() { return instance()->_messageProcessor; }
+    static inline SignalProxysignalProxy() { return instance()->_signalProxy; }
+
+    static inline ClientAliasManageraliasManager() { return instance()->_aliasManager; }
+    static inline ClientBacklogManagerbacklogManager() { return instance()->_backlogManager; }
+    static inline CoreInfocoreInfo() { return instance()->_coreInfo; }
+    static inline DccConfigdccConfig() { return instance()->_dccConfig; }
+    static inline ClientIrcListHelperircListHelper() { return instance()->_ircListHelper; }
+    static inline ClientBufferViewManagerbufferViewManager() { return instance()->_bufferViewManager; }
+    static inline BufferViewOverlaybufferViewOverlay() { return instance()->_bufferViewOverlay; }
+    static inline ClientUserInputHandlerinputHandler() { return instance()->_inputHandler; }
+    static inline NetworkConfignetworkConfig() { return instance()->_networkConfig; }
+    static inline ClientIgnoreListManagerignoreListManager() { return instance()->_ignoreListManager; }
+    static inline HighlightRuleManagerhighlightRuleManager() { return instance()->_highlightRuleManager; }
+    static inline ClientTransferManagertransferManager() { return instance()->_transferManager; }
+    static inline TransferModeltransferModel() { return instance()->_transferModel; }
+
+    static inline BufferSyncerbufferSyncer() { return instance()->_bufferSyncer; }
+
+    static inline CoreAccountModelcoreAccountModel() { return instance()->_coreAccountModel; }
+    static inline CoreConnectioncoreConnection() { return instance()->_coreConnection; }
     static inline CoreAccount currentCoreAccount() { return coreConnection()->currentAccount(); }
     static bool isCoreFeatureEnabled(Quassel::Feature feature);
 
     static bool isConnected();
     static bool internalCore();
 
-    static void userInput(const BufferInfo &bufferInfo, const QString &message);
+    static void userInput(const BufferInfo& bufferInfo, const QString& message);
 
-    static void setBufferLastSeenMsg(BufferId id, const MsgId &msgId); // this is synced to core and other clients
-    static void setMarkerLine(BufferId id, const MsgId &msgId); // this is synced to core and other clients
+    static void setBufferLastSeenMsg(BufferId id, const MsgId& msgId);  // this is synced to core and other clients
+    static void setMarkerLine(BufferId id, const MsgId& msgId);         // this is synced to core and other clients
     static MsgId markerLine(BufferId id);
 
     static void removeBuffer(BufferId id);
-    static void renameBuffer(BufferId bufferId, const QString &newName);
+    static void renameBuffer(BufferId bufferId, const QStringnewName);
     static void mergeBuffersPermanently(BufferId bufferId1, BufferId bufferId2);
     static void purgeKnownBufferIds();
 
@@ -160,12 +165,10 @@ public:
      */
     static void refreshLegacyCoreInfo();
 
-    static void changePassword(const QString &oldPassword, const QString &newPassword);
+    static void changePassword(const QString& oldPassword, const QString& newPassword);
     static void kickClient(int peerId);
 
-    void displayIgnoreList(QString ignoreRule) {
-        emit showIgnoreList(ignoreRule);
-    }
+    void displayIgnoreList(QString ignoreRule) { emit showIgnoreList(ignoreRule); }
 
     /**
      * Request to show the channel list dialog for the network, optionally searching by channel name
@@ -176,8 +179,7 @@ public:
      * @param channelFilters   Partial channel name to search for, or empty to show all
      * @param listImmediately  If true, immediately list channels, otherwise just show dialog
      */
-    void displayChannelList(NetworkId networkId, const QString &channelFilters = {},
-                            bool listImmediately = false)
+    void displayChannelList(NetworkId networkId, const QString& channelFilters = {}, bool listImmediately = false)
     {
         emit showChannelList(networkId, channelFilters, listImmediately);
     }
@@ -185,7 +187,7 @@ public:
 signals:
     void requestNetworkStates();
 
-    void showConfigWizard(const QVariantMap &coredata);
+    void showConfigWizard(const QVariantMapcoredata);
 
     /**
      * Request to show the channel list dialog for the network, optionally searching by channel name
@@ -196,8 +198,7 @@ signals:
      * @param channelFilters   Partial channel name to search for, or empty to show all
      * @param listImmediately  If true, immediately list channels, otherwise just show dialog
      */
-    void showChannelList(NetworkId networkId, const QString &channelFilters = {},
-                         bool listImmediately = false);
+    void showChannelList(NetworkId networkId, const QString& channelFilters = {}, bool listImmediately = false);
 
     void showIgnoreList(QString ignoreRule);
 
@@ -230,14 +231,14 @@ signals:
     void identityRemoved(IdentityId id);
 
     //! Sent to the core when an identity shall be created. Should not be used elsewhere.
-    void requestCreateIdentity(const Identity &, const QVariantMap &);
+    void requestCreateIdentity(const Identity&, const QVariantMap&);
     //! Sent to the core when an identity shall be removed. Should not be used elsewhere.
     void requestRemoveIdentity(IdentityId);
 
     void networkCreated(NetworkId id);
     void networkRemoved(NetworkId id);
 
-    void requestCreateNetwork(const NetworkInfo &info, const QStringList &persistentChannels = QStringList());
+    void requestCreateNetwork(const NetworkInfo& info, const QStringList& persistentChannels = QStringList());
     void requestRemoveNetwork(NetworkId);
 
     //! Emitted when a buffer has been marked as read
@@ -248,7 +249,7 @@ signals:
     void bufferMarkedAsRead(BufferId id);
 
     //! 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 requestPasswordChange(PeerPtr peer, const QString& userName, const QString& oldPassword, const QString& newPassword);
 
     void requestKickClient(int peerId);
     void passwordChanged(bool success);
@@ -257,30 +258,30 @@ signals:
     void dbUpgradeInProgress(bool inProgress);
 
     //! Emitted before an exit request is handled
-    void exitRequested(const QString &reason);
+    void exitRequested(const QStringreason);
 
 public slots:
     void disconnectFromCore();
 
     void bufferRemoved(BufferId bufferId);
-    void bufferRenamed(BufferId bufferId, const QString &newName);
+    void bufferRenamed(BufferId bufferId, const QStringnewName);
     void buffersPermanentlyMerged(BufferId bufferId1, BufferId bufferId2);
 
     void markBufferAsRead(BufferId id);
 
     void onDbUpgradeInProgress(bool inProgress);
-    void onExitRequested(int exitCode, const QString &reason);
+    void onExitRequested(int exitCode, const QStringreason);
 
 private slots:
     void setSyncedToCore();
     void setDisconnectedFromCore();
     void connectionStateChanged(CoreConnection::ConnectionState);
 
-    void recvMessage(const Message &message);
+    void recvMessage(const Messagemessage);
     void recvStatusMsg(QString network, QString message);
 
     void networkDestroyed();
-    void coreIdentityCreated(const Identity &);
+    void coreIdentityCreated(const Identity&);
     void coreIdentityRemoved(IdentityId);
     void coreNetworkCreated(NetworkId);
     void coreNetworkRemoved(NetworkId);
@@ -292,10 +293,6 @@ private slots:
     void sendBufferedUserInput();
 
 private:
-    Client(QObject *parent = 0);
-    virtual ~Client();
-    void init();
-
     void requestInitialBacklog();
 
     /**
@@ -309,43 +306,41 @@ private:
      */
     void requestLegacyCoreInfo();
 
-    static void addNetwork(Network *);
-
-    static QPointer<Client> instanceptr;
-
-    SignalProxy *_signalProxy;
-    AbstractUi *_mainUi;
-    NetworkModel *_networkModel;
-    BufferModel *_bufferModel;
-    BufferSyncer *_bufferSyncer;
-    ClientAliasManager *_aliasManager;
-    ClientBacklogManager *_backlogManager;
-    ClientBufferViewManager *_bufferViewManager;
-    BufferViewOverlay *_bufferViewOverlay;
-    CoreInfo *_coreInfo;
-    DccConfig *_dccConfig;
-    ClientIrcListHelper *_ircListHelper;
-    ClientUserInputHandler *_inputHandler;
-    NetworkConfig *_networkConfig;
-    ClientIgnoreListManager *_ignoreListManager;
-    HighlightRuleManager *_highlightRuleManager;
-    ClientTransferManager *_transferManager;
-    TransferModel *_transferModel;
-
-    MessageModel *_messageModel;
-    AbstractMessageProcessor *_messageProcessor;
-
-    CoreAccountModel *_coreAccountModel;
-    CoreConnection *_coreConnection;
-
-    ClientMode clientMode;
-
-    QHash<NetworkId, Network *> _networks;
-    QHash<IdentityId, Identity *> _identities;
-
-    bool _connected;
-
-    QList<QPair<BufferInfo, QString> > _userInputBuffer;
+    static void addNetwork(Network*);
+
+    SignalProxy* _signalProxy{nullptr};
+    std::unique_ptr<AbstractUi> _mainUi;
+    NetworkModel* _networkModel{nullptr};
+    BufferModel* _bufferModel{nullptr};
+    BufferSyncer* _bufferSyncer{nullptr};
+    ClientAliasManager* _aliasManager{nullptr};
+    ClientBacklogManager* _backlogManager{nullptr};
+    ClientBufferViewManager* _bufferViewManager{nullptr};
+    BufferViewOverlay* _bufferViewOverlay{nullptr};
+    CoreInfo* _coreInfo{nullptr};
+    DccConfig* _dccConfig{nullptr};
+    ClientIrcListHelper* _ircListHelper{nullptr};
+    ClientUserInputHandler* _inputHandler{nullptr};
+    NetworkConfig* _networkConfig{nullptr};
+    ClientIgnoreListManager* _ignoreListManager{nullptr};
+    HighlightRuleManager* _highlightRuleManager{nullptr};
+    ClientTransferManager* _transferManager{nullptr};
+    TransferModel* _transferModel{nullptr};
+
+    MessageModel* _messageModel{nullptr};
+    AbstractMessageProcessor* _messageProcessor{nullptr};
+
+    CoreAccountModel* _coreAccountModel{nullptr};
+    CoreConnection* _coreConnection{nullptr};
+
+    ClientMode clientMode{};
+
+    QHash<NetworkId, Network*> _networks;
+    QHash<IdentityId, Identity*> _identities;
+
+    bool _connected{false};
+
+    QList<QPair<BufferInfo, QString>> _userInputBuffer;
 
     friend class CoreConnection;
 };