blob: 893e1284b84cc366b260bb730d36ef9e8c01a32c [file] [log] [blame]
#![no_std]
use futures::future;
use libtock::ble_parser;
use libtock::led;
use libtock::simple_ble;
use libtock::simple_ble::BleCallback;
use libtock::simple_ble::BleDriver;
use libtock_support_macros::libtock_main;
use serde::Deserialize;
#[derive(Deserialize)]
struct LedCommand {
pub nr: u8,
pub st: bool,
}
#[libtock_main]
async fn main() -> libtock::result::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 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::get(msg.nr as usize).map(|led| led.set_state(msg.st)));
});
let _subscription = BleDriver::start(&mut callback)?;
future::pending().await
}