Skip to content

Commit

Permalink
tools/upload_files.py: improve usability and logging
Browse files Browse the repository at this point in the history
  • Loading branch information
josuah committed Oct 12, 2023
1 parent cca3953 commit 23febdb
Showing 1 changed file with 17 additions and 15 deletions.
32 changes: 17 additions & 15 deletions tools/upload_file.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@

import asyncio
import sys
import os

from bleak import BleakClient, BleakScanner
from bleak.backends.characteristic import BleakGATTCharacteristic
Expand All @@ -28,6 +29,7 @@ def __init__(self):
self.DATA_TX_CHAR_UUID: "Monocle Data RX",
self.DATA_RX_CHAR_UUID: "Monocle Data TX",
})
self.debug = "DEBUG" in os.environ

@classmethod
async def run(cls, *args):
Expand All @@ -37,7 +39,6 @@ async def run(cls, *args):
if device is None:
print("no matching device found\n")
exit(1)
print("Connected to the Monocle")

async with BleakClient(device, disconnected_callback=self.handle_disconnect) as c:
self.client = c
Expand All @@ -47,13 +48,18 @@ async def run(cls, *args):
await self.script(*args)
await self.client.write_gatt_char(self.uart_rx_char, b"\x02")

def log(self, msg):
if self.debug:
print(msg)

def match_uart_uuid(self, device:BLEDevice, adv:AdvertisementData):
print(f"uuids={adv.service_uuids}")
self.log(f"uuids={adv.service_uuids}")
return self.UART_SERVICE_UUID.lower() in adv.service_uuids

def handle_disconnect(self, _:BleakClient):
print("\nDevice was disconnected.")
exit(0)
self.log("Device was disconnected.")
for task in asyncio.all_tasks():
task.cancel()

def handle_uart_rx(self, _:BleakGATTCharacteristic, data:bytearray):
# Here, handle data sent by the Monocle with `print()`
Expand Down Expand Up @@ -120,22 +126,18 @@ class UploadFileScript(MonocleScript):
Example application: upload a file to the Monocle
"""
async def script(self, file):

print(">>> opening a file to write to")
print(f"uploading {file} ", end="")
await self.send_command(f"f = open('{file}', 'wb')")

print(">>> writing the data to the file")
with open(file, "rb") as f:
while data := f.read(100):
print(end=".", flush=True)
await self.send_command(f"f.write({bytes(data).__repr__()})")
print("")

print(">>> closing the file")
await self.send_command("f.close()")

print(">>> script done")

print(" done")

if __name__ == "__main__":
asyncio.run(UploadFileScript.run(sys.argv[1]))
for file in sys.argv[1:]:
try:
asyncio.run(UploadFileScript.run(file))
except asyncio.exceptions.CancelledError:
pass

0 comments on commit 23febdb

Please sign in to comment.