-
-
Notifications
You must be signed in to change notification settings - Fork 54
/
Copy pathdeku_input.rs
49 lines (43 loc) · 1.2 KB
/
deku_input.rs
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
//! Example of a close replacement for deku::input
use deku::prelude::*;
use std::io::{self, Cursor, Read, Seek, SeekFrom};
/// Every read to this struct will be saved into an internal cache. This is to keep the cache
/// around for the crc without reading from the buffer twice
struct ReaderCrc<R: Read + Seek> {
reader: R,
pub cache: Vec<u8>,
}
impl<R: Read + Seek> ReaderCrc<R> {
pub fn new(reader: R) -> Self {
Self {
reader,
cache: vec![],
}
}
}
impl<R: Read + Seek> Read for ReaderCrc<R> {
fn read(&mut self, buf: &mut [u8]) -> io::Result<usize> {
let n = self.reader.read(buf);
self.cache.extend_from_slice(buf);
n
}
}
impl<R: Read + Seek> Seek for ReaderCrc<R> {
fn seek(&mut self, pos: SeekFrom) -> std::io::Result<u64> {
self.reader.seek(pos)
}
}
#[derive(Debug, DekuRead)]
pub struct DekuStruct {
pub a: u8,
pub b: u8,
}
fn main() {
let data = vec![0x01, 0x02];
let input = Cursor::new(&data);
let mut reader = ReaderCrc::new(input);
let (_, s) = DekuStruct::from_reader((&mut reader, 0)).unwrap();
assert_eq!(reader.cache, data);
assert_eq!(s.a, 1);
assert_eq!(s.b, 2);
}