diff options
author | louiz’ <louiz@louiz.org> | 2017-04-17 14:45:19 +0200 |
---|---|---|
committer | louiz’ <louiz@louiz.org> | 2017-04-17 14:47:21 +0200 |
commit | 32384047537ed7c63cf3099b247777ed6035af49 (patch) | |
tree | e9a1277d0e567b794fbcc9b37663c6b90240714a /src/main.cpp | |
parent | dc5ad49b4011bb637373c6088efaf219fed4a016 (diff) | |
download | biboumi-32384047537ed7c63cf3099b247777ed6035af49.tar.gz biboumi-32384047537ed7c63cf3099b247777ed6035af49.tar.bz2 biboumi-32384047537ed7c63cf3099b247777ed6035af49.tar.xz biboumi-32384047537ed7c63cf3099b247777ed6035af49.zip |
Avoid adding more that one “XMPP reconnection” timed event at the same time
Fix a semblance of infinite and busy loop, that could occur if biboumi’s
poller is woken up multiple times while the XMPP server is not reachable.
Diffstat (limited to 'src/main.cpp')
-rw-r--r-- | src/main.cpp | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/src/main.cpp b/src/main.cpp index 2db89cc..1a9b065 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -179,19 +179,20 @@ int main(int ac, char** av) { if (xmpp_component->ever_auth) { + static const std::string reconnect_name{"XMPP reconnection"}; if (xmpp_component->first_connection_try == true) { // immediately re-try to connect xmpp_component->reset(); xmpp_component->start(); } - else + else if (!TimedEventsManager::instance().find_event(reconnect_name)) { // Re-connecting failed, we now try only each few seconds auto reconnect_later = [xmpp_component]() { xmpp_component->reset(); xmpp_component->start(); }; - TimedEvent event(std::chrono::steady_clock::now() + 2s, reconnect_later, "XMPP reconnection"); + TimedEvent event(std::chrono::steady_clock::now() + 2s, reconnect_later, reconnect_name); TimedEventsManager::instance().add_event(std::move(event)); } } |