forked from M-Labs/kirdy
gui: handle hard reset in _on_connection_changed()
- Ensure correct gui disconnection seq during Kirdy hard reset
This commit is contained in:
parent
9524601cb6
commit
4a06a7579f
@ -70,6 +70,8 @@ class KirdyDataWatcher(QObject):
|
|||||||
if task.done():
|
if task.done():
|
||||||
task = asyncio.create_task(self.signal_emitter())
|
task = asyncio.create_task(self.signal_emitter())
|
||||||
await asyncio.sleep(self._update_s)
|
await asyncio.sleep(self._update_s)
|
||||||
|
except asyncio.CancelledError:
|
||||||
|
pass
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
logging.error(f"Encountered an error: {e}. disconnecting.", exc_info=True)
|
logging.error(f"Encountered an error: {e}. disconnecting.", exc_info=True)
|
||||||
self._kirdy.stop_report_mode()
|
self._kirdy.stop_report_mode()
|
||||||
@ -81,6 +83,7 @@ class KirdyDataWatcher(QObject):
|
|||||||
async def stop_watching(self):
|
async def stop_watching(self):
|
||||||
if self._watch_task is not None:
|
if self._watch_task is not None:
|
||||||
self._watch_task.cancel()
|
self._watch_task.cancel()
|
||||||
|
await self._watch_task
|
||||||
self._watch_task = None
|
self._watch_task = None
|
||||||
await self.set_report_mode(False)
|
await self.set_report_mode(False)
|
||||||
|
|
||||||
@ -89,9 +92,9 @@ class KirdyDataWatcher(QObject):
|
|||||||
if enabled:
|
if enabled:
|
||||||
self._report_mode_task = asyncio.create_task(self.report_mode())
|
self._report_mode_task = asyncio.create_task(self.report_mode())
|
||||||
else:
|
else:
|
||||||
self._kirdy.stop_report_mode()
|
|
||||||
if self._report_mode_task is not None:
|
if self._report_mode_task is not None:
|
||||||
self._report_mode_task.cancel()
|
self._kirdy.stop_report_mode()
|
||||||
|
await self._report_mode_task
|
||||||
self._report_mode_task = None
|
self._report_mode_task = None
|
||||||
|
|
||||||
async def report_mode(self):
|
async def report_mode(self):
|
||||||
@ -610,7 +613,7 @@ class MainWindow(QtWidgets.QMainWindow, Ui_MainWindow):
|
|||||||
tree.setParameters(self.params[3], showTop=False)
|
tree.setParameters(self.params[3], showTop=False)
|
||||||
self.params[3].sigTreeStateChanged.connect(self.send_command)
|
self.params[3].sigTreeStateChanged.connect(self.send_command)
|
||||||
|
|
||||||
async def _on_connection_changed(self, result):
|
async def _on_connection_changed(self, result, hard_reset=False):
|
||||||
def ctrl_panel_setEnable(result):
|
def ctrl_panel_setEnable(result):
|
||||||
self.ld_status.setEnabled(result)
|
self.ld_status.setEnabled(result)
|
||||||
self.ld_tree.setEnabled(result)
|
self.ld_tree.setEnabled(result)
|
||||||
@ -659,8 +662,10 @@ class MainWindow(QtWidgets.QMainWindow, Ui_MainWindow):
|
|||||||
self.status_lbl.setText("Disconnected")
|
self.status_lbl.setText("Disconnected")
|
||||||
self.clear_graphs()
|
self.clear_graphs()
|
||||||
self.report_box.setChecked(False)
|
self.report_box.setChecked(False)
|
||||||
await self.kirdy_data_watcher.set_report_mode(False)
|
await self.kirdy_data_watcher.stop_watching()
|
||||||
self.kirdy_data_watcher.stop_watching()
|
if hard_reset:
|
||||||
|
await self.kirdy.device.hard_reset()
|
||||||
|
await self.kirdy.end_session()
|
||||||
self.status_lbl.setText("Disconnected")
|
self.status_lbl.setText("Disconnected")
|
||||||
|
|
||||||
def _status(self):
|
def _status(self):
|
||||||
|
Loading…
Reference in New Issue
Block a user