forked from M-Labs/artiq
gui: support triggering repository rescan
This commit is contained in:
parent
d1ad2f1918
commit
f57145c4f3
@ -69,12 +69,15 @@ def main():
|
|||||||
asyncio.set_event_loop(loop)
|
asyncio.set_event_loop(loop)
|
||||||
atexit.register(lambda: loop.close())
|
atexit.register(lambda: loop.close())
|
||||||
|
|
||||||
smgr = StateManager(args.db_file)
|
rpc_clients = dict()
|
||||||
|
for target in "schedule", "repository", "dataset_db":
|
||||||
|
client = AsyncioClient()
|
||||||
|
loop.run_until_complete(client.connect_rpc(
|
||||||
|
args.server, args.port_control, "master_" + target))
|
||||||
|
atexit.register(lambda: client.close_rpc())
|
||||||
|
rpc_clients[target] = client
|
||||||
|
|
||||||
schedule_ctl = AsyncioClient()
|
smgr = StateManager(args.db_file)
|
||||||
loop.run_until_complete(schedule_ctl.connect_rpc(
|
|
||||||
args.server, args.port_control, "master_schedule"))
|
|
||||||
atexit.register(lambda: schedule_ctl.close_rpc())
|
|
||||||
|
|
||||||
win = MainWindow(app, args.server)
|
win = MainWindow(app, args.server)
|
||||||
area = dockarea.DockArea()
|
area = dockarea.DockArea()
|
||||||
@ -85,7 +88,9 @@ def main():
|
|||||||
status_bar.showMessage("Connected to {}".format(args.server))
|
status_bar.showMessage("Connected to {}".format(args.server))
|
||||||
win.setStatusBar(status_bar)
|
win.setStatusBar(status_bar)
|
||||||
|
|
||||||
d_explorer = ExplorerDock(win, status_bar, schedule_ctl)
|
d_explorer = ExplorerDock(win, status_bar,
|
||||||
|
rpc_clients["schedule"],
|
||||||
|
rpc_clients["repository"])
|
||||||
smgr.register(d_explorer)
|
smgr.register(d_explorer)
|
||||||
loop.run_until_complete(d_explorer.sub_connect(
|
loop.run_until_complete(d_explorer.sub_connect(
|
||||||
args.server, args.port_notify))
|
args.server, args.port_notify))
|
||||||
@ -110,7 +115,7 @@ def main():
|
|||||||
area.addDock(d_datasets, "top")
|
area.addDock(d_datasets, "top")
|
||||||
area.addDock(d_explorer, "above", d_datasets)
|
area.addDock(d_explorer, "above", d_datasets)
|
||||||
|
|
||||||
d_schedule = ScheduleDock(status_bar, schedule_ctl)
|
d_schedule = ScheduleDock(status_bar, rpc_clients["schedule"])
|
||||||
loop.run_until_complete(d_schedule.sub_connect(
|
loop.run_until_complete(d_schedule.sub_connect(
|
||||||
args.server, args.port_notify))
|
args.server, args.port_notify))
|
||||||
atexit.register(lambda: loop.run_until_complete(d_schedule.sub_close()))
|
atexit.register(lambda: loop.run_until_complete(d_schedule.sub_close()))
|
||||||
@ -121,14 +126,10 @@ def main():
|
|||||||
args.server, args.port_notify))
|
args.server, args.port_notify))
|
||||||
atexit.register(lambda: loop.run_until_complete(d_log.sub_close()))
|
atexit.register(lambda: loop.run_until_complete(d_log.sub_close()))
|
||||||
|
|
||||||
dataset_db = AsyncioClient()
|
|
||||||
loop.run_until_complete(dataset_db.connect_rpc(
|
|
||||||
args.server, args.port_control, "master_dataset_db"))
|
|
||||||
atexit.register(lambda: dataset_db.close_rpc())
|
|
||||||
def _set_dataset(k, v):
|
def _set_dataset(k, v):
|
||||||
asyncio.ensure_future(dataset_db.set(k, v))
|
asyncio.ensure_future(rpc_clients["dataset_db"].set(k, v))
|
||||||
def _del_dataset(k):
|
def _del_dataset(k):
|
||||||
asyncio.ensure_future(dataset_db.delete(k))
|
asyncio.ensure_future(rpc_clients["dataset_db"].delete(k))
|
||||||
d_console = ConsoleDock(
|
d_console = ConsoleDock(
|
||||||
d_datasets.get_dataset,
|
d_datasets.get_dataset,
|
||||||
_set_dataset,
|
_set_dataset,
|
||||||
|
@ -216,7 +216,7 @@ class _ArgumentEditor(QtGui.QTreeWidget):
|
|||||||
|
|
||||||
|
|
||||||
class ExplorerDock(dockarea.Dock):
|
class ExplorerDock(dockarea.Dock):
|
||||||
def __init__(self, main_window, status_bar, schedule_ctl):
|
def __init__(self, main_window, status_bar, schedule_ctl, repository_ctl):
|
||||||
dockarea.Dock.__init__(self, "Explorer", size=(1500, 500))
|
dockarea.Dock.__init__(self, "Explorer", size=(1500, 500))
|
||||||
|
|
||||||
self.main_window = main_window
|
self.main_window = main_window
|
||||||
@ -279,6 +279,13 @@ class ExplorerDock(dockarea.Dock):
|
|||||||
edit_shortcuts_action = QtGui.QAction("Edit shortcuts", self.el)
|
edit_shortcuts_action = QtGui.QAction("Edit shortcuts", self.el)
|
||||||
edit_shortcuts_action.triggered.connect(self.edit_shortcuts)
|
edit_shortcuts_action.triggered.connect(self.edit_shortcuts)
|
||||||
self.el.addAction(edit_shortcuts_action)
|
self.el.addAction(edit_shortcuts_action)
|
||||||
|
scan_repository_action = QtGui.QAction("(Re)scan repository HEAD",
|
||||||
|
self.el)
|
||||||
|
def scan_repository():
|
||||||
|
asyncio.ensure_future(repository_ctl.scan_async())
|
||||||
|
self.status_bar.showMessage("Requested repository scan")
|
||||||
|
scan_repository_action.triggered.connect(scan_repository)
|
||||||
|
self.el.addAction(scan_repository_action)
|
||||||
|
|
||||||
def update_selection(self, selected, deselected):
|
def update_selection(self, selected, deselected):
|
||||||
if deselected:
|
if deselected:
|
||||||
|
Loading…
Reference in New Issue
Block a user