blob: 8846ed723bca756653f763dece85bc3dc8cd4338 [file] [log] [blame]
#![no_std]
use futures::future;
use libtock::ble_parser;
use libtock::result::TockResult;
use libtock::simple_ble;
use libtock::simple_ble::BleCallback;
use libtock::simple_ble::BleDriver;
use libtock::Hardware;
use serde::Deserialize;
#[derive(Deserialize)]
struct LedCommand {
pub nr: u8,
pub st: bool,
}
#[libtock::main]
async fn main() -> TockResult<()> {
let mut shared_buffer = BleDriver::create_scan_buffer();
let mut my_buffer = BleDriver::create_scan_buffer();
let shared_memory = BleDriver::share_memory(&mut shared_buffer)?;
let Hardware { mut led_driver, .. } = libtock::retrieve_hardware()?;
let mut callback = BleCallback::new(|_: usize, _: usize| {
shared_memory.read_bytes(&mut my_buffer[..]);
ble_parser::find(&my_buffer, simple_ble::gap_data::SERVICE_DATA as u8)
.and_then(|service_data| ble_parser::extract_for_service([91, 79], service_data))
.and_then(|payload| corepack::from_bytes::<LedCommand>(&payload).ok())
.and_then(|msg| {
led_driver
.get(msg.nr as usize)
.map(|mut led| led.set_state(msg.st))
});
});
let _subscription = BleDriver::start(&mut callback)?;
future::pending().await
}