forked from M-Labs/kirdy
gui: Fix a bug which GUI may recv two msgs at once
This commit is contained in:
parent
92f6b83b16
commit
9002ca6992
@ -654,7 +654,7 @@ class Kirdy:
|
|||||||
self._reader = None
|
self._reader = None
|
||||||
self._writer = None
|
self._writer = None
|
||||||
|
|
||||||
async def _read_response(self, buffer_size=16384):
|
async def _read_response(self, buffer_size=16384, report=False):
|
||||||
"""
|
"""
|
||||||
Decode newline delimited Json objects and return the latest json received inside the buffer.
|
Decode newline delimited Json objects and return the latest json received inside the buffer.
|
||||||
- buffer_size: Integer
|
- buffer_size: Integer
|
||||||
@ -663,16 +663,21 @@ class Kirdy:
|
|||||||
raw_response = await asyncio.wait_for(self._reader.read(buffer_size), self.timeout)
|
raw_response = await asyncio.wait_for(self._reader.read(buffer_size), self.timeout)
|
||||||
|
|
||||||
response = raw_response.decode('utf-8', errors='ignore').split("\n")
|
response = raw_response.decode('utf-8', errors='ignore').split("\n")
|
||||||
print()
|
items = []
|
||||||
print(response)
|
|
||||||
for item in reversed(response):
|
for item in reversed(response):
|
||||||
try:
|
try:
|
||||||
return json.loads(item)
|
items.append(json.loads(item))
|
||||||
except json.decoder.JSONDecodeError as e:
|
except json.decoder.JSONDecodeError as e:
|
||||||
pass
|
pass
|
||||||
return { "msg_type": "Exception"}
|
if len(items) > 0 :
|
||||||
|
if report:
|
||||||
|
return items[0]
|
||||||
|
else:
|
||||||
|
return items
|
||||||
|
else:
|
||||||
|
return { "msg_type": "EmptyResponse"}
|
||||||
except TimeoutError:
|
except TimeoutError:
|
||||||
return { "msg_type": "Exception"}
|
return { "msg_type": "RecvTimeout"}
|
||||||
|
|
||||||
async def _send_raw_cmd_handler(self, cmd, lock=True, msg_type="Acknowledge"):
|
async def _send_raw_cmd_handler(self, cmd, lock=True, msg_type="Acknowledge"):
|
||||||
if lock:
|
if lock:
|
||||||
@ -689,11 +694,12 @@ class Kirdy:
|
|||||||
try:
|
try:
|
||||||
self._writer.write(bytes(json.dumps(cmd), "UTF-8"))
|
self._writer.write(bytes(json.dumps(cmd), "UTF-8"))
|
||||||
await self._writer.drain()
|
await self._writer.drain()
|
||||||
response = await self._read_response()
|
responses = await self._read_response()
|
||||||
if response["msg_type"] == msg_type:
|
for response in responses:
|
||||||
return response
|
if response["msg_type"] == msg_type:
|
||||||
if response["msg_type"] == "InvalidCmd":
|
return response
|
||||||
return InvalidCmd
|
if response["msg_type"] == "InvalidCmd":
|
||||||
|
return InvalidCmd
|
||||||
except asyncio.exceptions.CancelledError:
|
except asyncio.exceptions.CancelledError:
|
||||||
return None
|
return None
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
@ -737,10 +743,10 @@ class Kirdy:
|
|||||||
try:
|
try:
|
||||||
self._writer.write(bytes(json.dumps(cmd_dict), "UTF-8"))
|
self._writer.write(bytes(json.dumps(cmd_dict), "UTF-8"))
|
||||||
await self._writer.drain()
|
await self._writer.drain()
|
||||||
response = await self._read_response()
|
responses = await self._read_response()
|
||||||
print(f'retry attempts: {retry} msg_type: {msg_type}')
|
for response in responses:
|
||||||
if response["msg_type"] == msg_type:
|
if response["msg_type"] == msg_type:
|
||||||
return response
|
return response
|
||||||
retry += 1
|
retry += 1
|
||||||
|
|
||||||
await asyncio.sleep(0.1)
|
await asyncio.sleep(0.1)
|
||||||
@ -761,7 +767,7 @@ class Kirdy:
|
|||||||
while self._report_mode_on:
|
while self._report_mode_on:
|
||||||
await asyncio.sleep(report_interval)
|
await asyncio.sleep(report_interval)
|
||||||
async with self._cmd_lock:
|
async with self._cmd_lock:
|
||||||
yield await self._read_response(buffer_size)
|
yield await self._read_response(buffer_size, report=True)
|
||||||
|
|
||||||
await self.device.set_active_report_mode(False)
|
await self.device.set_active_report_mode(False)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user