artiq/artiq/frontend/artiq_gui.py

155 lines
5.2 KiB
Python
Raw Normal View History

#!/usr/bin/env python3.5
2014-12-29 12:48:14 +08:00
import argparse
import asyncio
2015-01-02 14:47:09 +08:00
import atexit
2015-07-17 02:52:53 +08:00
import os
2014-12-29 12:48:14 +08:00
2015-05-22 17:05:15 +08:00
# Quamash must be imported first so that pyqtgraph picks up the Qt binding
# it has chosen.
2015-08-06 22:27:46 +08:00
from quamash import QEventLoop, QtGui, QtCore
from pyqtgraph import dockarea
2014-12-29 12:48:14 +08:00
from artiq.tools import *
2015-05-24 20:24:07 +08:00
from artiq.protocols.pc_rpc import AsyncioClient
2015-11-11 12:13:19 +08:00
from artiq.gui.models import ModelSubscriber
from artiq.gui import (state, experiments, shortcuts, explorer,
2015-11-27 19:30:05 +08:00
moninj, datasets, schedule, log, console)
2015-07-14 04:08:20 +08:00
2015-01-23 00:52:13 +08:00
def get_argparser():
2014-12-29 12:48:14 +08:00
parser = argparse.ArgumentParser(description="ARTIQ GUI client")
parser.add_argument(
"-s", "--server", default="::1",
help="hostname or IP of the master to connect to")
parser.add_argument(
"--port-notify", default=3250, type=int,
2014-12-31 20:13:10 +08:00
help="TCP port to connect to for notifications")
2014-12-29 12:48:14 +08:00
parser.add_argument(
"--port-control", default=3251, type=int,
2014-12-31 20:13:10 +08:00
help="TCP port to connect to for control")
2015-01-23 19:00:09 +08:00
parser.add_argument(
"--db-file", default="artiq_gui.pyon",
help="database file for local GUI settings")
2015-08-05 11:41:43 +08:00
verbosity_args(parser)
2015-01-23 00:52:13 +08:00
return parser
2014-12-29 12:48:14 +08:00
2015-08-06 22:27:46 +08:00
class MainWindow(QtGui.QMainWindow):
2015-08-25 00:37:49 +08:00
def __init__(self, app, server):
2015-07-20 00:27:41 +08:00
QtGui.QMainWindow.__init__(self)
2015-11-04 00:35:03 +08:00
icon = QtGui.QIcon(os.path.join(artiq_dir, "gui", "icon.png"))
self.setWindowIcon(icon)
2015-08-25 00:37:49 +08:00
self.setWindowTitle("ARTIQ - {}".format(server))
2015-07-20 00:27:41 +08:00
self.exit_request = asyncio.Event()
def closeEvent(self, *args):
self.exit_request.set()
2015-08-06 22:27:46 +08:00
def save_state(self):
return bytes(self.saveGeometry())
def restore_state(self, state):
self.restoreGeometry(QtCore.QByteArray(state))
2015-01-23 19:00:09 +08:00
2015-08-01 16:48:44 +08:00
def main():
2015-11-12 01:13:57 +08:00
# initialize application
2015-08-05 11:41:43 +08:00
args = get_argparser().parse_args()
init_logger(args)
2015-05-22 17:05:15 +08:00
app = QtGui.QApplication([])
loop = QEventLoop(app)
asyncio.set_event_loop(loop)
2015-11-01 00:03:46 +08:00
atexit.register(loop.close)
2015-11-12 01:13:57 +08:00
smgr = state.StateManager(args.db_file)
2015-01-02 14:47:09 +08:00
2015-11-12 01:13:57 +08:00
# create connections to master
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))
2015-11-01 00:03:46 +08:00
atexit.register(client.close_rpc)
rpc_clients[target] = client
2015-08-01 16:48:44 +08:00
2015-11-11 12:13:19 +08:00
sub_clients = dict()
for notifier_name, module in (("explist", explorer),
("datasets", datasets),
("schedule", schedule),
("log", log)):
subscriber = ModelSubscriber(notifier_name, module.Model)
loop.run_until_complete(subscriber.connect(
args.server, args.port_notify))
atexit_register_coroutine(subscriber.close)
sub_clients[notifier_name] = subscriber
2015-11-12 01:13:57 +08:00
# initialize main window
2015-08-25 00:37:49 +08:00
win = MainWindow(app, args.server)
2015-11-27 19:30:05 +08:00
dock_area = dockarea.DockArea()
smgr.register(dock_area)
2015-08-06 22:27:46 +08:00
smgr.register(win)
2015-11-27 19:30:05 +08:00
win.setCentralWidget(dock_area)
2015-05-23 01:25:33 +08:00
status_bar = QtGui.QStatusBar()
status_bar.showMessage("Connected to {}".format(args.server))
win.setStatusBar(status_bar)
2015-01-05 19:52:58 +08:00
2015-11-12 01:13:57 +08:00
# create UI components
2015-11-27 19:30:05 +08:00
expmgr = experiments.ExperimentManager(status_bar, dock_area,
sub_clients["explist"],
sub_clients["schedule"],
rpc_clients["schedule"])
2015-11-30 11:40:50 +08:00
smgr.register(expmgr)
2015-12-01 18:22:12 +08:00
d_shortcuts = shortcuts.ShortcutsDock(win, expmgr)
smgr.register(d_shortcuts)
d_explorer = explorer.ExplorerDock(status_bar, expmgr, d_shortcuts,
2015-11-11 12:13:19 +08:00
sub_clients["explist"],
rpc_clients["schedule"],
rpc_clients["repository"])
2015-11-27 19:30:05 +08:00
d_datasets = datasets.DatasetsDock(win, dock_area, sub_clients["datasets"])
smgr.register(d_datasets)
2015-07-14 23:31:18 +08:00
2015-08-24 20:20:33 +08:00
if os.name != "nt":
2015-11-11 12:13:19 +08:00
d_ttl_dds = moninj.MonInj()
2015-08-24 20:20:33 +08:00
loop.run_until_complete(d_ttl_dds.start(args.server, args.port_notify))
2015-11-11 12:13:19 +08:00
atexit_register_coroutine(d_ttl_dds.stop)
2015-11-11 12:13:19 +08:00
d_schedule = schedule.ScheduleDock(
status_bar, rpc_clients["schedule"], sub_clients["schedule"])
2015-01-14 22:22:33 +08:00
2015-11-27 19:30:05 +08:00
logmgr = log.LogDockManager(dock_area, sub_clients["log"])
2015-11-12 01:13:57 +08:00
smgr.register(logmgr)
d_console = console.ConsoleDock(sub_clients["datasets"],
rpc_clients["dataset_db"])
2015-07-25 00:36:16 +08:00
2015-11-12 01:13:57 +08:00
# lay out docks
if os.name != "nt":
2015-11-27 19:30:05 +08:00
dock_area.addDock(d_ttl_dds.dds_dock, "top")
dock_area.addDock(d_ttl_dds.ttl_dock, "above", d_ttl_dds.dds_dock)
dock_area.addDock(d_datasets, "above", d_ttl_dds.ttl_dock)
2015-11-12 01:13:57 +08:00
else:
2015-11-27 19:30:05 +08:00
dock_area.addDock(d_datasets, "top")
dock_area.addDock(d_shortcuts, "above", d_datasets)
dock_area.addDock(d_explorer, "above", d_shortcuts)
2015-11-27 19:30:05 +08:00
dock_area.addDock(d_console, "bottom")
dock_area.addDock(d_schedule, "above", d_console)
2015-11-12 01:13:57 +08:00
# load/initialize state
2015-08-01 16:48:44 +08:00
smgr.load()
smgr.start()
2015-11-11 12:13:19 +08:00
atexit_register_coroutine(smgr.stop)
2015-11-12 01:13:57 +08:00
# create first log dock if not already in state
d_log0 = logmgr.first_log_dock()
if d_log0 is not None:
2015-11-27 19:30:05 +08:00
dock_area.addDock(d_log0, "right", d_explorer)
2015-11-12 01:13:57 +08:00
# run
2015-05-22 17:05:15 +08:00
win.show()
2015-07-20 00:27:41 +08:00
loop.run_until_complete(win.exit_request.wait())
2014-12-29 12:48:14 +08:00
if __name__ == "__main__":
main()