Fix RFCOMM connect under uvloop and bump version to 0.1.4
This commit is contained in:
@@ -155,13 +155,18 @@ class RFCOMMClient:
|
||||
sock = _socket.socket(
|
||||
_socket.AF_BLUETOOTH, _socket.SOCK_STREAM, _socket.BTPROTO_RFCOMM
|
||||
)
|
||||
sock.setblocking(False)
|
||||
loop = asyncio.get_running_loop()
|
||||
try:
|
||||
await asyncio.wait_for(
|
||||
loop.sock_connect(sock, (self._address, self._channel)),
|
||||
timeout=10.0,
|
||||
# uvloop's sock_connect path goes through getaddrinfo and doesn't
|
||||
# support AF_BLUETOOTH addresses reliably. Use direct socket connect
|
||||
# in a thread instead.
|
||||
sock.settimeout(10.0)
|
||||
await loop.run_in_executor(
|
||||
None,
|
||||
sock.connect,
|
||||
(self._address, self._channel),
|
||||
)
|
||||
sock.setblocking(False)
|
||||
except asyncio.TimeoutError as exc:
|
||||
sock.close()
|
||||
raise PrinterTimeout(
|
||||
|
||||
Reference in New Issue
Block a user