From 1489728cd358f6bf7151bcdd87b9ea2cbdff7bec Mon Sep 17 00:00:00 2001 From: Sebastian Goth Date: Mon, 24 Aug 2009 18:01:27 +0200 Subject: [PATCH] Handle very short netsplits --- src/core/netsplit.cpp | 7 ++++++- src/core/netsplit.h | 2 +- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/src/core/netsplit.cpp b/src/core/netsplit.cpp index 89d27a4e..d824d9b4 100644 --- a/src/core/netsplit.cpp +++ b/src/core/netsplit.cpp @@ -23,7 +23,7 @@ #include Netsplit::Netsplit() - : _quitMsg("") + : _quitMsg(""), _sentQuit(false) { _discardTimer.setSingleShot(true); _joinTimer.setSingleShot(true); @@ -84,6 +84,10 @@ bool Netsplit::isNetsplit(const QString &quitMessage) void Netsplit::joinTimeout() { + if(!_sentQuit) { + _quitTimer.stop(); + quitTimeout(); + } QHash::iterator it; for(it = _joins.begin(); it != _joins.end(); ++it) emit netsplitJoin(it.key(), it.value(),_quitMsg); @@ -97,4 +101,5 @@ void Netsplit::quitTimeout() QHash::iterator it; for(it = _quits.begin(); it != _quits.end(); ++it) emit netsplitQuit(it.key(), it.value(),_quitMsg); + _sentQuit = true; } diff --git a/src/core/netsplit.h b/src/core/netsplit.h index 135a3f00..d9b2cf22 100644 --- a/src/core/netsplit.h +++ b/src/core/netsplit.h @@ -93,7 +93,7 @@ private: QString _quitMsg; QHash _joins; QHash _quits; - + bool _sentQuit; QTimer _joinTimer; QTimer _quitTimer; QTimer _discardTimer; -- 2.20.1