artiq/artiq/frontend/artiq_gui.py

106 lines
3.6 KiB
Python
Raw Normal View History

2014-12-29 12:48:14 +08:00
#!/usr/bin/env python3
import argparse
import asyncio
2015-01-02 14:47:09 +08:00
import atexit
2014-12-29 12:48:14 +08:00
import gbulb
from gi.repository import Gtk
2015-01-23 19:00:09 +08:00
from artiq.protocols.file_db import FlatFileDB
from artiq.protocols.pc_rpc import AsyncioClient
from artiq.protocols.sync_struct import Subscriber
2015-01-23 19:00:09 +08:00
from artiq.gui.tools import LayoutManager
2014-12-30 18:18:23 +08:00
from artiq.gui.scheduler import SchedulerWindow
2014-12-31 11:11:38 +08:00
from artiq.gui.parameters import ParametersWindow
2015-01-14 22:22:33 +08:00
from artiq.gui.rt_results import RTResults
from artiq.gui.explorer import ExplorerWindow
2014-12-29 12:48:14 +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-01-23 00:52:13 +08:00
return parser
2014-12-29 12:48:14 +08:00
def main():
2015-01-23 00:52:13 +08:00
args = get_argparser().parse_args()
2014-12-29 12:48:14 +08:00
2015-01-23 19:00:09 +08:00
db = FlatFileDB(args.db_file, default_data=dict())
lmgr = LayoutManager(db)
2014-12-29 12:48:14 +08:00
asyncio.set_event_loop_policy(gbulb.GtkEventLoopPolicy())
loop = asyncio.get_event_loop()
2015-01-02 14:47:09 +08:00
atexit.register(lambda: loop.close())
2015-01-26 23:37:33 +08:00
# share the schedule control and repository connections
2015-01-05 19:52:58 +08:00
schedule_ctl = AsyncioClient()
loop.run_until_complete(schedule_ctl.connect_rpc(
args.server, args.port_control, "master_schedule"))
2015-01-06 17:50:15 +08:00
atexit.register(lambda: schedule_ctl.close_rpc())
2015-01-26 23:37:33 +08:00
repository = AsyncioClient()
loop.run_until_complete(repository.connect_rpc(
args.server, args.port_control, "master_repository"))
atexit.register(lambda: repository.close_rpc())
2015-01-05 19:52:58 +08:00
2015-01-23 19:00:09 +08:00
scheduler_win = lmgr.create_window(SchedulerWindow,
"scheduler",
schedule_ctl)
2015-01-02 14:47:09 +08:00
loop.run_until_complete(scheduler_win.sub_connect(
args.server, args.port_notify))
atexit.register(
lambda: loop.run_until_complete(scheduler_win.sub_close()))
parameters_win = lmgr.create_window(ParametersWindow, "parameters")
2015-01-02 14:47:09 +08:00
loop.run_until_complete(parameters_win.sub_connect(
args.server, args.port_notify))
atexit.register(
lambda: loop.run_until_complete(parameters_win.sub_close()))
2015-01-27 23:51:23 +08:00
def exit(*args):
lmgr.save()
Gtk.main_quit(*args)
explorer_win = lmgr.create_window(ExplorerWindow,
"explorer",
2015-01-27 23:51:23 +08:00
exit,
2015-01-26 23:37:33 +08:00
schedule_ctl,
repository)
2015-01-29 19:59:44 +08:00
loop.run_until_complete(explorer_win.sub_connect(
args.server, args.port_notify))
atexit.register(
lambda: loop.run_until_complete(explorer_win.sub_close()))
parameters_sub = Subscriber("parameters",
[parameters_win.init_parameters_store,
explorer_win.init_parameters_dict])
loop.run_until_complete(
parameters_sub.connect(args.server, args.port_notify))
atexit.register(
lambda: loop.run_until_complete(parameters_sub.close()))
scheduler_win.show_all()
parameters_win.show_all()
explorer_win.show_all()
2015-01-14 22:22:33 +08:00
rtr = RTResults()
loop.run_until_complete(rtr.sub_connect(
args.server, args.port_notify))
atexit.register(
lambda: loop.run_until_complete(rtr.sub_close()))
2015-01-02 14:47:09 +08:00
loop.run_forever()
2014-12-29 12:48:14 +08:00
if __name__ == "__main__":
main()