2017-01-30 09:24:43 +08:00
|
|
|
#!/usr/bin/env python3
|
2015-12-24 18:51:11 +08:00
|
|
|
|
|
|
|
import argparse
|
|
|
|
|
|
|
|
from artiq.tools import verbosity_args, init_logger
|
|
|
|
from artiq.master.databases import DeviceDB
|
|
|
|
from artiq.master.worker_db import DeviceManager
|
2017-03-29 11:35:45 +08:00
|
|
|
from artiq.coredevice.comm_mgmt import CommMgmt
|
2015-12-24 18:51:11 +08:00
|
|
|
|
|
|
|
|
|
|
|
def get_argparser():
|
|
|
|
parser = argparse.ArgumentParser(description="ARTIQ core device "
|
|
|
|
"log download tool")
|
|
|
|
verbosity_args(parser)
|
|
|
|
parser.add_argument("--device-db", default="device_db.pyon",
|
|
|
|
help="device database file (default: '%(default)s')")
|
2017-03-03 14:06:26 +08:00
|
|
|
|
|
|
|
subparsers = parser.add_subparsers(dest="action")
|
|
|
|
|
2017-03-29 11:35:45 +08:00
|
|
|
p_clear = subparsers.add_parser("clear",
|
|
|
|
help="clear log buffer")
|
|
|
|
|
2017-03-03 14:06:26 +08:00
|
|
|
p_set_level = subparsers.add_parser("set_level",
|
|
|
|
help="set minimum level for messages to be logged")
|
|
|
|
p_set_level.add_argument("level", metavar="LEVEL", type=str,
|
|
|
|
help="log level (one of: OFF ERROR WARN INFO DEBUG TRACE)")
|
|
|
|
|
2015-12-24 18:51:11 +08:00
|
|
|
return parser
|
|
|
|
|
|
|
|
|
|
|
|
def main():
|
|
|
|
args = get_argparser().parse_args()
|
|
|
|
init_logger(args)
|
|
|
|
device_mgr = DeviceManager(DeviceDB(args.device_db))
|
|
|
|
try:
|
2017-03-29 11:35:45 +08:00
|
|
|
core_addr = device_mgr.get_desc("comm")["arguments"]["host"]
|
|
|
|
mgmt = CommMgmt(device_mgr, core_addr)
|
2017-03-03 14:06:26 +08:00
|
|
|
if args.action == "set_level":
|
2017-03-29 11:35:45 +08:00
|
|
|
mgmt.set_log_level(args.level)
|
|
|
|
elif args.action == "clear":
|
|
|
|
mgmt.clear_log()
|
2017-03-03 14:06:26 +08:00
|
|
|
else:
|
2017-03-29 11:35:45 +08:00
|
|
|
print(mgmt.get_log(), end="")
|
2015-12-24 18:51:11 +08:00
|
|
|
finally:
|
|
|
|
device_mgr.close_devices()
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
main()
|