use super::key::*;
use super::patch_id::*;
use byteorder::{ByteOrder, LittleEndian};
use sanakirja::*;
use std;
bitflags! {
#[derive(Serialize, Deserialize)]
pub struct EdgeFlags: u8 {
const PSEUDO_EDGE = 1;
const FOLDER_EDGE = 2;
const EPSILON_EDGE = 4;
const PARENT_EDGE = 8;
const DELETED_EDGE = 16;
}
}
#[derive(Clone, Copy, Debug, PartialEq, PartialOrd, Eq, Ord, Hash)]
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(),
}
}
}
impl Representable for Edge {
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);
let s = std::slice::from_raw_parts_mut(p, 25);
s[0] = (*self).flag.bits();
LittleEndian::write_u64(&mut s[1..], (*self).dest.patch.0);
LittleEndian::write_u64(&mut s[9..], (*self).dest.line.0);
LittleEndian::write_u64(&mut s[17..], (*self).introduced_by.0);
}
unsafe fn read_value(p: *const u8) -> Self {
trace!("read_value {:?}", p);
let s = std::slice::from_raw_parts(p, 25);
Edge {
flag: EdgeFlags::from_bits(s[0]).unwrap(),
dest: Key {
patch: PatchId(LittleEndian::read_u64(&s[1..])),
line: LineId(LittleEndian::read_u64(&s[9..])),
},
introduced_by: PatchId(LittleEndian::read_u64(&s[17..])),
}
}
unsafe fn cmp_value<T>(&self, _: &T, x: Self) -> std::cmp::Ordering {
let a: &Edge = self;
let b: &Edge = &x;
a.cmp(b)
}
type PageOffsets = std::iter::Empty<u64>;
fn page_offsets(&self) -> Self::PageOffsets {
std::iter::empty()
}
}