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
40
41
42
43
44
45
46
47
48
49
50
51
52
use crate::can_message::CanMessage;
use crate::can_network::CanNetwork;
use std::collections::hash_map::Entry;
use std::collections::HashMap;
pub struct MultiCan {
networks: HashMap<u8, Box<CanNetwork>>,
}
impl MultiCan {
pub fn new(adapters: &mut Vec<Box<CanNetwork>>) -> Self {
let mut networks = HashMap::new();
networks.insert(2, adapters.pop().unwrap());
networks.insert(1, adapters.pop().unwrap());
networks.insert(0, adapters.pop().unwrap());
MultiCan { networks }
}
pub fn send(&mut self, msg: CanMessage) {
match self.networks.entry(msg.bus) {
Entry::Occupied(n) => {
n.into_mut().send(msg);
}
Entry::Vacant(_) => println!("empty entry for {}", msg.bus),
};
}
pub fn recv(&mut self) -> Vec<CanMessage> {
let mut messages: Vec<CanMessage> = Vec::new();
for (key, value) in &mut self.networks {
if let Some(mut m) = value.recv() {
m.bus = *key;
messages.push(m);
}
}
messages
}
}