X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=blobdiff_plain;f=src%2Fcommon%2Fsignalproxy.h;h=1c2d1da8c88088b1f5dc143b6de4dbe09d411fe7;hp=557e8dd3203fb10e531c089c7ab4b1f9b8f87679;hb=6fec875b14593ce6c83a9095fa5334afac6b6777;hpb=9c4a633cfff4b7b14199b6488fc39ffc31d62dfd diff --git a/src/common/signalproxy.h b/src/common/signalproxy.h index 557e8dd3..1c2d1da8 100644 --- a/src/common/signalproxy.h +++ b/src/common/signalproxy.h @@ -48,7 +48,8 @@ public: RpcCall, InitRequest, InitData, - HeartBeat + HeartBeat, + HeartBeatReply }; SignalProxy(QObject *parent); @@ -57,7 +58,7 @@ public: virtual ~SignalProxy(); void setProxyMode(ProxyMode mode); - ProxyMode proxyMode() const; + inline ProxyMode proxyMode() const { return _proxyMode; } bool addPeer(QIODevice *iodev); void removePeer(QIODevice *iodev = 0); @@ -120,13 +121,15 @@ private slots: void objectRenamed(const QString &newname, const QString &oldname); void objectRenamed(const QByteArray &classname, const QString &newname, const QString &oldname); void sendHeartBeat(); - void receiveHeartBeat(QIODevice *dev); - + void receiveHeartBeat(QIODevice *dev, const QVariantList ¶ms); + void receiveHeartBeatReply(QIODevice *dev, const QVariantList ¶ms); + signals: void peerRemoved(QIODevice *dev); void connected(); void disconnected(); void objectInitialized(SyncableObject *); + void lagUpdated(int lag); private: void init(); @@ -160,6 +163,8 @@ private: QVariantMap initData(SyncableObject *obj) const; void setInitData(SyncableObject *obj, const QVariantMap &properties); + void updateLag(QIODevice *dev, float lag); + public: void dumpSyncMap(SyncableObject *object); inline int peerCount() const { return _peers.size(); } @@ -170,6 +175,7 @@ private: quint32 byteCount; bool usesCompression; int sentHeartBeats; + float lag; peerInfo() : byteCount(0), usesCompression(false), sentHeartBeats(0) {} }; //QHash _peerByteCount;