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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
use super::key::*;
use super::patch_id::*;
use sanakirja::*;
use std;
bitflags! {
#[derive(Serialize, Deserialize)]
pub struct EdgeFlags: u8 {
const PSEUDO_EDGE = 1;
const FOLDER_EDGE = 2;
const PARENT_EDGE = 4;
const DELETED_EDGE = 8;
}
}
#[derive(Clone, Copy, Debug, PartialEq, PartialOrd, Eq, Ord, Hash)]
#[repr(packed)]
pub struct Edge {
pub flag: EdgeFlags,
pub dest: Key<PatchId>,
pub introduced_by: PatchId,
}
impl Edge {
pub fn zero(flag: EdgeFlags) -> Edge {
Edge {
flag: flag,
dest: ROOT_KEY.clone(),
introduced_by: ROOT_PATCH_ID.clone(),
}
}
#[doc(hidden)]
pub fn to_unsafe(&self) -> UnsafeEdge {
UnsafeEdge(self)
}
#[doc(hidden)]
pub unsafe fn from_unsafe<'a>(p: UnsafeEdge) -> &'a Edge {
&*p.0
}
}
#[derive(Clone, Copy)]
pub struct UnsafeEdge(*const Edge);
impl std::fmt::Debug for UnsafeEdge {
fn fmt(&self, fmt: &mut std::fmt::Formatter) -> std::fmt::Result {
unsafe {
Edge::from_unsafe(*self).fmt(fmt)
}
}
}
impl Representable for UnsafeEdge {
fn alignment() -> Alignment {
Alignment::B1
}
fn onpage_size(&self) -> u16 {
std::mem::size_of::<Edge>() as u16
}
unsafe fn write_value(&self, p: *mut u8) {
trace!("write_value {:?}", p);
std::ptr::copy(self.0, p as *mut Edge, 1)
}
unsafe fn read_value(p: *const u8) -> Self {
trace!("read_value {:?}", p);
UnsafeEdge(p as *const Edge)
}
unsafe fn cmp_value<T>(&self, _: &T, x: Self) -> std::cmp::Ordering {
let a: &Edge = &*self.0;
let b: &Edge = &*x.0;
a.cmp(b)
}
type PageOffsets = std::iter::Empty<u64>;
fn page_offsets(&self) -> Self::PageOffsets { std::iter::empty() }
}