X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcore%2Fserver.h;h=32060859df1579590229d2960ba3b5a35c0e58b6;hp=c99174cd5c1fe7b55152a3cae47e1e91e38f1418;hb=9ac6ae4ee26819874d8843ba09f38a24088d663d;hpb=45d9ea6ed5d64eec3ca351fdcf7610c7cff3529d diff --git a/src/core/server.h b/src/core/server.h index c99174cd..32060859 100644 --- a/src/core/server.h +++ b/src/core/server.h @@ -48,7 +48,7 @@ class Server : public QThread { Q_OBJECT public: - Server(UserId uid, uint networkId, QString network); + Server(UserId uid, NetworkId networkId, QString network, const QVariant &previousState = QVariant()); ~Server(); UserId userId() const { return _userId; } @@ -56,13 +56,15 @@ public: // serverState state(); bool isConnected() const { return socket.state() == QAbstractSocket::ConnectedState; } - uint networkId() const; - QString networkName(); // hasbeen getNetwork() + NetworkId networkId() const; + QString networkName() const; // hasbeen getNetwork() - NetworkInfo *networkInfo() { return _networkInfo; } - IrcServerHandler *ircServerHandler() {return _ircServerHandler; } - UserInputHandler *userInputHandler() {return _userInputHandler; } - CtcpHandler *ctcpHandler() {return _ctcpHandler; } + NetworkInfo *networkInfo() const { return _networkInfo; } + IrcServerHandler *ircServerHandler() const { return _ircServerHandler; } + UserInputHandler *userInputHandler() const { return _userInputHandler; } + CtcpHandler *ctcpHandler() const { return _ctcpHandler; } + + QVariant state(); ///< Return data necessary to restore the server's state upon core restart public slots: // void setServerOptions(); @@ -76,6 +78,7 @@ public slots: private slots: void threadFinished(); + void sendPerform(); signals: void serverState(QString net, QVariantMap data); @@ -86,6 +89,8 @@ signals: void connected(uint networkId); void disconnected(uint networkId); + void connectionInitialized(); ///< Emitted after receipt of 001 to indicate that we can now send data to the IRC server + void synchronizeClients(); void queryRequested(QString network, QString nick); @@ -100,7 +105,7 @@ private slots: private: UserId _userId; - uint _networkId; + NetworkId _networkId; QTcpSocket socket; @@ -113,6 +118,8 @@ private: QVariantMap networkSettings; QVariantMap identity; + QVariant _previousState; + CoreSession *coreSession() const; class ParseError : public Exception {