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
use crate::{
traits::{Emitable, Parseable},
DecodeError,
};
#[derive(Debug, PartialEq, Eq, Clone, Copy)]
pub struct Stats {
pub bytes: u64,
pub packets: u32,
pub drops: u32,
pub overlimits: u32,
pub bps: u32,
pub pps: u32,
pub qlen: u32,
pub backlog: u32,
}
pub const STATS_LEN: usize = 36;
buffer!(StatsBuffer(STATS_LEN) {
bytes: (u64, 0..8),
packets: (u32, 8..12),
drops: (u32, 12..16),
overlimits: (u32, 16..20),
bps: (u32, 20..24),
pps: (u32, 24..28),
qlen: (u32, 28..32),
backlog: (u32, 32..36),
});
impl<T: AsRef<[u8]>> Parseable<StatsBuffer<T>> for Stats {
fn parse(buf: &StatsBuffer<T>) -> Result<Self, DecodeError> {
Ok(Self {
bytes: buf.bytes(),
packets: buf.packets(),
drops: buf.drops(),
overlimits: buf.overlimits(),
bps: buf.bps(),
pps: buf.pps(),
qlen: buf.qlen(),
backlog: buf.backlog(),
})
}
}
impl Emitable for Stats {
fn buffer_len(&self) -> usize {
STATS_LEN
}
fn emit(&self, buffer: &mut [u8]) {
let mut buffer = StatsBuffer::new(buffer);
buffer.set_bytes(self.bytes);
buffer.set_packets(self.packets);
buffer.set_drops(self.drops);
buffer.set_overlimits(self.overlimits);
buffer.set_bps(self.bps);
buffer.set_pps(self.pps);
buffer.set_qlen(self.qlen);
buffer.set_backlog(self.backlog);
}
}