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
73
74
75
76
use hex;
use sanakirja::{Alignment, Representable};
use std;
pub const INODE_SIZE: usize = 8;
#[derive(Clone, Copy, PartialEq, PartialOrd, Eq, Ord, Hash)]
pub struct Inode([u8; INODE_SIZE]);
pub const ROOT_INODE: Inode = Inode([0; INODE_SIZE]);
impl std::ops::Deref for Inode {
type Target = [u8];
fn deref(&self) -> &[u8] {
&self.0
}
}
impl std::ops::DerefMut for Inode {
fn deref_mut(&mut self) -> &mut [u8] {
&mut self.0
}
}
impl std::fmt::Debug for Inode {
fn fmt(&self, fmt: &mut std::fmt::Formatter) -> std::fmt::Result {
write!(fmt, "Inode({})", hex::encode(&self.0))
}
}
impl Inode {
pub fn to_hex(&self) -> String {
use hex::ToHex;
let mut s = String::new();
self.0.write_hex(&mut s).unwrap();
s
}
pub fn is_root(&self) -> bool {
*self == ROOT_INODE
}
pub fn from_hex(hex: &str) -> Option<Inode> {
let mut i = Inode([0; INODE_SIZE]);
if super::from_hex(hex, &mut i) {
Some(i)
} else {
None
}
}
}
impl Representable for Inode {
fn alignment() -> Alignment {
Alignment::B1
}
fn onpage_size(&self) -> u16 {
std::mem::size_of::<Inode>() as u16
}
unsafe fn write_value(&self, p: *mut u8) {
trace!("write_value {:?}", p);
std::ptr::copy(self.0.as_ptr(), p, INODE_SIZE)
}
unsafe fn read_value(p: *const u8) -> Self {
trace!("read_value {:?}", p);
let mut i: Inode = std::mem::uninitialized();
std::ptr::copy(p, i.0.as_mut_ptr(), INODE_SIZE);
i
}
unsafe fn cmp_value<T>(&self, _: &T, x: Self) -> std::cmp::Ordering {
self.cmp(&x)
}
type PageOffsets = std::iter::Empty<u64>;
fn page_offsets(&self) -> Self::PageOffsets {
std::iter::empty()
}
}