forked from e-sr/moonboard
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathrun.py
executable file
·72 lines (56 loc) · 2.05 KB
/
run.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
# -*- coding: utf-8 -*-
import argparse
from led.moonboard import MoonBoard,LED_LAYOUT
from gi.repository import GLib
import dbus
from dbus.mainloop.glib import DBusGMainLoop
from functools import partial
import json
def new_problem_cb(mb,holds_string):
holds = json.loads(holds_string)
mb.show_problem(holds)
logger.debug('new_problem: '+holds_string)
if __name__ == "__main__":
import logging
import sys
parser = argparse.ArgumentParser(description='')
parser.add_argument('--driver_type',
help='driver type, depends on leds and device controlling the led.',
choices=["WS281X", 'WS2801', 'SimPixel'],
default='WS2801')
parser.add_argument('--brightness', default=100, type=int)
parser.add_argument('--led_layout',
default=None,
choices=list(LED_LAYOUT.keys())
)
parser.add_argument('--debug', action = "store_true")
args = parser.parse_args()
argsd=vars(args)
logger = logging.getLogger('run')
logger.setLevel(logging.DEBUG)
logger.addHandler(logging.StreamHandler())
if args.debug:
logger.setLevel(logging.DEBUG)
else:
logger.setLevel(logging.INFO)
#problems
led_layout = LED_LAYOUT.get(args.led_layout) if args.led_layout is not None else None
MOONBOARD = MoonBoard(args.driver_type, led_layout)
MOONBOARD.start_show_leds()
# connect to dbus signal new problem
dbml = DBusGMainLoop(set_as_default=True)
bus = dbus.SystemBus()
proxy = bus.get_object('com.moonboard','/com/moonboard')
proxy.connect_to_signal('new_problem', partial(new_problem_cb, MOONBOARD))
loop = GLib.MainLoop()
dbus.set_default_main_loop(dbml)
# Run the loop
try:
loop.run()
except KeyboardInterrupt:
print("keyboard interrupt received")
except Exception as e:
logger.error(str(e))
print("Unexpected exception occurred: '{}'".format(str(e)))
finally:
loop.quit()