From a32d3576c696e3f3fd07ac6fc919e468bcb27818 Mon Sep 17 00:00:00 2001 From: Victor Zarubkin Date: Wed, 4 Oct 2017 22:37:46 +0300 Subject: [PATCH] #66 [GUI] fixed disconnection problem when hitting cancel-button while receiving data and there is no need to restart GUI after unexpected disconnect --- profiler_gui/main_window.cpp | 30 +++++++++++++++++++++++++----- profiler_gui/main_window.h | 7 +++++-- 2 files changed, 30 insertions(+), 7 deletions(-) diff --git a/profiler_gui/main_window.cpp b/profiler_gui/main_window.cpp index 916e50b..984018e 100644 --- a/profiler_gui/main_window.cpp +++ b/profiler_gui/main_window.cpp @@ -1411,6 +1411,7 @@ void EasyMainWindow::onFrameTimeRequestTimeout() } else if (!m_listener.connected()) { + m_listener.closeSocket(); setDisconnected(); } } @@ -1518,10 +1519,11 @@ void EasyMainWindow::onListenerDialogClose(int _result) if (m_listener.connected()) { // make reconnect to clear socket buffers - std::string address = m_listener.address(); + const std::string address = m_listener.address(); + const auto port = m_listener.port(); profiler::net::EasyProfilerStatus reply(false, false, false); - if (m_listener.connect(address.c_str(), m_listener.port(), reply)) + if (m_listener.reconnect(address.c_str(), port, reply)) { disconnect(m_eventTracingEnableAction, &QAction::triggered, this, &This::onEventTracingEnableChange); disconnect(m_eventTracingPriorityAction, &QAction::triggered, this, &This::onEventTracingPriorityChange); @@ -1570,6 +1572,7 @@ void EasyMainWindow::onListenerDialogClose(int _result) if (!m_listener.connected()) { + m_listener.closeSocket(); setDisconnected(); } } @@ -1925,7 +1928,10 @@ void EasyMainWindow::onConnectClicked(bool) { QMessageBox::warning(this, "Warning", QString("Cannot connect to %1").arg(address), QMessageBox::Close); if (EASY_GLOBALS.connected) + { + m_listener.closeSocket(); setDisconnected(false); + } if (!isSameAddress) { @@ -2001,12 +2007,14 @@ void EasyMainWindow::onCaptureClicked(bool) profiler::net::EasyProfilerStatus reply(false, false, false); if (!m_listener.connect(m_lastAddress.toStdString().c_str(), m_lastPort, reply)) { + m_listener.closeSocket(); setDisconnected(); return; } if (!m_listener.startCapture()) { + m_listener.closeSocket(); setDisconnected(); return; } @@ -2164,6 +2172,7 @@ void EasyMainWindow::onGetBlockDescriptionsClicked(bool) if (!m_listener.connected()) { + m_listener.closeSocket(); setDisconnected(); } } @@ -2254,11 +2263,16 @@ void EasySocketListener::disconnect() m_address.clear(); m_port = 0; + closeSocket(); +} + +void EasySocketListener::closeSocket() +{ m_easySocket.flush(); m_easySocket.init(); } -bool EasySocketListener::connect(const char* _ipaddress, uint16_t _port, profiler::net::EasyProfilerStatus& _reply) +bool EasySocketListener::connect(const char* _ipaddress, uint16_t _port, profiler::net::EasyProfilerStatus& _reply, bool _disconnectFirst) { if (connected()) { @@ -2275,8 +2289,9 @@ bool EasySocketListener::connect(const char* _ipaddress, uint16_t _port, profile m_address.clear(); m_port = 0; - //m_easySocket.flush(); - //m_easySocket.init(); + if (_disconnectFirst) + closeSocket(); + int res = m_easySocket.setAddress(_ipaddress, _port); res = m_easySocket.connect(); @@ -2337,6 +2352,11 @@ bool EasySocketListener::connect(const char* _ipaddress, uint16_t _port, profile return isConnected; } +bool EasySocketListener::reconnect(const char* _ipaddress, uint16_t _port, ::profiler::net::EasyProfilerStatus& _reply) +{ + return connect(_ipaddress, _port, _reply, true); +} + bool EasySocketListener::startCapture() { //if (m_thread.joinable()) diff --git a/profiler_gui/main_window.h b/profiler_gui/main_window.h index 55eeba0..cb769b8 100644 --- a/profiler_gui/main_window.h +++ b/profiler_gui/main_window.h @@ -167,7 +167,9 @@ public: void clearData(); void disconnect(); - bool connect(const char* _ipaddress, uint16_t _port, ::profiler::net::EasyProfilerStatus& _reply); + void closeSocket(); + bool connect(const char* _ipaddress, uint16_t _port, ::profiler::net::EasyProfilerStatus& _reply, bool _disconnectFirst = false); + bool reconnect(const char* _ipaddress, uint16_t _port, ::profiler::net::EasyProfilerStatus& _reply); bool startCapture(); void stopCapture(); @@ -178,7 +180,8 @@ public: bool requestFrameTime(); template - inline void send(const T& _message) { + inline void send(const T& _message) + { m_easySocket.send(&_message, sizeof(T)); }