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
use super::prelude::*;
#[derive(Debug)]
pub struct Entry {
header: RecordHeader,
meta: Option<Meta>,
blob_file: File,
}
impl Entry {
pub async fn load(self) -> Result<Record> {
let meta_size = self.header.meta_size().try_into()?;
let data_size: usize = self.header.data_size().try_into()?;
let mut buf = vec![0; data_size + meta_size];
self.blob_file
.read_at(&mut buf, self.header.meta_offset())
.await
.with_context(|| "blob load failed")?;
let data_buf = buf.split_off(meta_size);
let meta = Meta::from_raw(&buf)?;
let record = Record::new(self.header.clone(), meta, data_buf);
record.validate()
}
pub async fn load_data(&self) -> Result<Vec<u8>> {
let data_offset = self.header.data_offset();
let mut buf = vec![0; self.header.data_size().try_into()?];
self.blob_file.read_at(&mut buf, data_offset).await?;
Ok(buf)
}
pub async fn load_meta(&mut self) -> Result<Option<&Meta>> {
let meta_offset = self.header.meta_offset();
let mut buf = vec![0; self.header.meta_size().try_into()?];
self.blob_file.read_at(&mut buf, meta_offset).await?;
self.meta = Some(Meta::from_raw(&buf)?);
Ok(self.meta.as_ref())
}
pub(crate) fn new(header: RecordHeader, blob_file: File) -> Self {
Self {
meta: None,
header,
blob_file,
}
}
}