1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
use log::info;
fn run<S>(stack: &mut S)
where
S: embedded_nal::TcpFullStack + embedded_nal_tcpextensions::TcpExactStack,
{
let mut sock = stack.socket().expect("Can't create a socket");
let log = Some(coap_message_demos::log::Log::start_once());
let mut handler = coap_message_demos::full_application_tree(log);
stack.bind(&mut sock, 5683).expect("Can't bind to port");
info!("Server is ready.");
let mut pool = embedded_nal_minimal_coaptcpserver::ServerPool::<S, 4, 1152>::new(sock);
loop {
pool.poll(stack, &mut handler)
.expect("Actual error in polling (accepting?)");
std::thread::sleep(std::time::Duration::from_millis(50));
}
}
fn main() {
let mut stack = std_embedded_nal::Stack::default();
run(&mut stack);
}