dbus: pass the bus name lost signal up to tuhi

If we're losing the bus name (i.e. we can't get it on startup) there really
isn't much we can do other than fail miserably. But in passing signals around
we can't do exceptions, so we have to move the mainloop to Tuhi so we can
quit() it on error.

Fixes #25
This commit is contained in:
Peter Hutterer 2018-01-24 21:23:09 +10:00
parent cae296e030
commit 2fd781974f
2 changed files with 13 additions and 3 deletions

View File

@ -203,6 +203,7 @@ class Tuhi(GObject.Object):
GObject.Object.__init__(self) GObject.Object.__init__(self)
self.server = TuhiDBusServer() self.server = TuhiDBusServer()
self.server.connect('bus-name-acquired', self._on_tuhi_bus_name_acquired) self.server.connect('bus-name-acquired', self._on_tuhi_bus_name_acquired)
self.server.connect('bus-name-lost', self._on_tuhi_bus_name_lost)
self.server.connect('search-start-requested', self._on_start_search_requested) self.server.connect('search-start-requested', self._on_start_search_requested)
self.server.connect('search-stop-requested', self._on_stop_search_requested) self.server.connect('search-stop-requested', self._on_stop_search_requested)
self.bluez = BlueZDeviceManager() self.bluez = BlueZDeviceManager()
@ -216,10 +217,14 @@ class Tuhi(GObject.Object):
self.devices = {} self.devices = {}
self._search_stop_handler = None self._search_stop_handler = None
self.mainloop = GObject.MainLoop()
def _on_tuhi_bus_name_acquired(self, dbus_server): def _on_tuhi_bus_name_acquired(self, dbus_server):
self.bluez.connect_to_bluez() self.bluez.connect_to_bluez()
def _on_tuhi_bus_name_lost(self, dbus_server):
self.mainloop.quit()
def _on_start_search_requested(self, dbus_server, stop_handler): def _on_start_search_requested(self, dbus_server, stop_handler):
self._search_stop_handler = stop_handler self._search_stop_handler = stop_handler
self.bluez.start_discovery() self.bluez.start_discovery()
@ -306,6 +311,9 @@ class Tuhi(GObject.Object):
else: else:
self.bluez.stop_discovery() self.bluez.stop_discovery()
def run(self):
self.mainloop.run()
def main(args=sys.argv): def main(args=sys.argv):
desc = "Daemon to extract the pen stroke data from Wacom SmartPad devices" desc = "Daemon to extract the pen stroke data from Wacom SmartPad devices"
@ -319,9 +327,8 @@ def main(args=sys.argv):
if ns.verbose: if ns.verbose:
logger.setLevel(logging.DEBUG) logger.setLevel(logging.DEBUG)
Tuhi()
try: try:
GObject.MainLoop().run() Tuhi().run()
except KeyboardInterrupt: except KeyboardInterrupt:
pass pass
finally: finally:

View File

@ -309,6 +309,8 @@ class TuhiDBusServer(_TuhiDBus):
__gsignals__ = { __gsignals__ = {
"bus-name-acquired": "bus-name-acquired":
(GObject.SIGNAL_RUN_FIRST, None, ()), (GObject.SIGNAL_RUN_FIRST, None, ()),
"bus-name-lost":
(GObject.SIGNAL_RUN_FIRST, None, ()),
# Signal arguments: # Signal arguments:
# search_stop_handler(status) # search_stop_handler(status)
@ -361,7 +363,8 @@ class TuhiDBusServer(_TuhiDBus):
self.emit('bus-name-acquired') self.emit('bus-name-acquired')
def _bus_name_lost(self, connection, name): def _bus_name_lost(self, connection, name):
pass logger.error('Bus not available, is there another Tuhi process running?')
self.emit('bus-name-lost')
def _method_cb(self, connection, sender, objpath, interface, methodname, args, invocation): def _method_cb(self, connection, sender, objpath, interface, methodname, args, invocation):
if interface != self.interface: if interface != self.interface: