ble: if we connect twice, log the error as debug

We likely get multiple 'udpated' notifications as the RSSI property changes,
all causing a Connect() on the device and an ugly error message (that we used
to catch and print). Make that error message prettier.
This commit is contained in:
Peter Hutterer 2018-01-23 12:10:07 +10:00
parent f9ba9fe6ca
commit 44a2d5e8eb
1 changed files with 7 additions and 1 deletions

View File

@ -209,7 +209,13 @@ class BlueZDevice(GObject.Object):
i.Connect(result_handler=self._on_connect_result)
def _on_connect_result(self, obj, result, user_data):
if isinstance(result, Exception):
if (isinstance(result, GLib.Error) and
result.domain == 'g-io-error-quark' and
result.code == Gio.IOErrorEnum.DBUS_ERROR and
Gio.dbus_error_get_remote_error(result) == 'org.bluez.Error.Failed' and
'Operation already in progress' in result.message):
logger.debug('{}: Already connecting'.format(self.address))
elif isinstance(result, Exception):
logger.error('Connection failed: {}'.format(result))
def disconnect_device(self):