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
extern crate chrono;
extern crate futures;
#[macro_use]
extern crate serde_derive;
pub mod async_reader;
pub mod file_reader;
pub mod model;
mod parser;
pub mod sync_reader;
use std::mem::transmute;
use model::EDFHeader;
use std::io::{Error, ErrorKind};
fn get_sample(data: &Vec<u8>, index: usize) -> i16 {
unsafe { transmute::<[u8; 2], i16>([data[2 * index].to_le(), data[2 * index + 1].to_le()]) }
}
fn check_bounds(start_time: u64, duration: u64, edf_header: &EDFHeader) -> Result<(), Error> {
if start_time + duration > edf_header.block_duration * edf_header.number_of_blocks {
return Err(Error::new(
ErrorKind::InvalidInput,
"Window is out of bounds",
));
} else {
Ok(())
}
}
#[cfg(test)]
mod tests {
use super::get_sample;
#[test]
fn convert_byte_array_to_u16() {
assert_eq!(456, get_sample(&vec![200, 1], 0));
assert_eq!(-4564, get_sample(&vec![44, 238], 0));
}
}