From 55363e2ff9e041fd488ed88ab763722d6bac2f1c Mon Sep 17 00:00:00 2001 From: Sebastien Bourdeauducq Date: Wed, 14 Sep 2016 10:45:00 +0800 Subject: [PATCH] dashboard: save/restore MDI window states when they are closed. Closes #559 --- artiq/dashboard/experiments.py | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/artiq/dashboard/experiments.py b/artiq/dashboard/experiments.py index 9fcba20d5..5acfc6f9b 100644 --- a/artiq/dashboard/experiments.py +++ b/artiq/dashboard/experiments.py @@ -462,6 +462,7 @@ class ExperimentManager: self.schedule_ctl = schedule_ctl self.experiment_db_ctl = experiment_db_ctl + self.dock_states = dict() self.submission_scheduling = dict() self.submission_options = dict() self.submission_arguments = dict() @@ -556,9 +557,13 @@ class ExperimentManager: self.main_window.centralWidget().addSubWindow(dock) dock.show() dock.sigClosed.connect(partial(self.on_dock_closed, expurl)) + if expurl in self.dock_states: + dock.restore_state(self.dock_states[expurl]) return dock def on_dock_closed(self, expurl): + dock = self.open_experiments[expurl] + self.dock_states[expurl] = dock.save_state() del self.open_experiments[expurl] async def _submit_task(self, expurl, *args): @@ -639,13 +644,13 @@ class ExperimentManager: self.open_experiment(expurl) def save_state(self): - docks = {expurl: dock.save_state() - for expurl, dock in self.open_experiments.items()} + for expurl, dock in self.open_experiments.items(): + self.dock_states[expurl] = dock.save_state() return { "scheduling": self.submission_scheduling, "options": self.submission_options, "arguments": self.submission_arguments, - "docks": docks + "docks": self.dock_states } def restore_state(self, state):