diff options
author | Matthias P. Braendli <matthias.braendli@mpb.li> | 2016-10-30 12:18:14 +0100 |
---|---|---|
committer | Matthias P. Braendli <matthias.braendli@mpb.li> | 2016-10-30 12:18:14 +0100 |
commit | 7512c84d0cd7d9b1a3733e84280864f5a989b51e (patch) | |
tree | 4f1b078e3ebad93b02f888796d07cf574aaafa5b /src | |
parent | 5aa8118d99b104402bf044e57c473a7156dc2314 (diff) | |
download | dabmux-7512c84d0cd7d9b1a3733e84280864f5a989b51e.tar.gz dabmux-7512c84d0cd7d9b1a3733e84280864f5a989b51e.tar.bz2 dabmux-7512c84d0cd7d9b1a3733e84280864f5a989b51e.zip |
Catch runtime_error in TCPDataDispatcher thread
Diffstat (limited to 'src')
-rw-r--r-- | src/dabOutput/dabOutputTcp.cpp | 20 |
1 files changed, 13 insertions, 7 deletions
diff --git a/src/dabOutput/dabOutputTcp.cpp b/src/dabOutput/dabOutputTcp.cpp index 8696bec..6485d15 100644 --- a/src/dabOutput/dabOutputTcp.cpp +++ b/src/dabOutput/dabOutputTcp.cpp @@ -126,17 +126,23 @@ class TCPDataDispatcher private: void process(long) { - m_listener_socket.listen(); + try { + m_listener_socket.listen(); - const int timeout_ms = 1000; + const int timeout_ms = 1000; - while (m_running) { - // Add a new TCPConnection to the list, constructing it from the client socket - auto optional_sock = m_listener_socket.accept(timeout_ms); - if (optional_sock) { - m_connections.emplace(m_connections.begin(), std::move(*optional_sock)); + while (m_running) { + // Add a new TCPConnection to the list, constructing it from the client socket + auto optional_sock = m_listener_socket.accept(timeout_ms); + if (optional_sock) { + m_connections.emplace(m_connections.begin(), std::move(*optional_sock)); + } } } + catch (std::runtime_error& e) { + etiLog.level(error) << "TCPDataDispatcher caught runtime error: " << e.what(); + m_running = false; + } } atomic<bool> m_running; |