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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
pub use adsb_deku::{Frame, DF};
pub use mavlink::common::{MavMessage, ADSB_VEHICLE_DATA};
pub use mavlink::{MavFrame, MavHeader, MavlinkVersion, Message};
pub trait Keys {
fn primary_key(&self) -> u32;
fn secondary_key(&self) -> u32;
fn hashed_key(&self) -> u32 {
let p = self.primary_key();
(p << 4) + p + self.secondary_key()
}
}
impl Keys for MavHeader {
fn primary_key(&self) -> u32 {
self.system_id as u32
}
fn secondary_key(&self) -> u32 {
self.sequence as u32
}
}
impl Keys for Frame {
fn primary_key(&self) -> u32 {
let bytes: [u8; 4] = match &self.df {
adsb_deku::DF::ADSB(adsb) => {
let mut bytes = [0; 4];
bytes[1..4].copy_from_slice(&adsb.icao.0);
bytes
}
_ => [0; 4],
};
u32::from_be_bytes(bytes)
}
fn secondary_key(&self) -> u32 {
self.crc
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_hashed_key_mavheader() {
let mav_header = MavHeader {
system_id: 42,
component_id: 10,
sequence: 20,
};
let hashed_key = mav_header.hashed_key();
let expected_hashed_key = (42 << 4) + 42 + 20;
assert_eq!(hashed_key, expected_hashed_key);
}
}