pub mod cursor_list;
pub use self::cursor_list::CursorList;
use crate::trace::implementations::LayoutExt;
pub trait Cursor : LayoutExt {
type Storage;
fn key_valid(&self, storage: &Self::Storage) -> bool;
fn val_valid(&self, storage: &Self::Storage) -> bool;
fn key<'a>(&self, storage: &'a Self::Storage) -> Self::Key<'a>;
fn val<'a>(&self, storage: &'a Self::Storage) -> Self::Val<'a>;
fn get_key<'a>(&self, storage: &'a Self::Storage) -> Option<Self::Key<'a>>;
fn get_val<'a>(&self, storage: &'a Self::Storage) -> Option<Self::Val<'a>>;
fn map_times<L: FnMut(Self::TimeGat<'_>, Self::DiffGat<'_>)>(&mut self, storage: &Self::Storage, logic: L);
fn step_key(&mut self, storage: &Self::Storage);
fn seek_key(&mut self, storage: &Self::Storage, key: Self::Key<'_>);
fn step_val(&mut self, storage: &Self::Storage);
fn seek_val(&mut self, storage: &Self::Storage, val: Self::Val<'_>);
fn rewind_keys(&mut self, storage: &Self::Storage);
fn rewind_vals(&mut self, storage: &Self::Storage);
fn to_vec<K, IK, V, IV>(&mut self, storage: &Self::Storage, into_key: IK, into_val: IV) -> Vec<((K, V), Vec<(Self::Time, Self::Diff)>)>
where
IK: for<'a> Fn(Self::Key<'a>) -> K,
IV: for<'a> Fn(Self::Val<'a>) -> V,
{
let mut out = Vec::new();
self.rewind_keys(storage);
while let Some(key) = self.get_key(storage) {
self.rewind_vals(storage);
while let Some(val) = self.get_val(storage) {
let mut kv_out = Vec::new();
self.map_times(storage, |ts, r| {
kv_out.push((Self::owned_time(ts), Self::owned_diff(r)));
});
out.push(((into_key(key), into_val(val)), kv_out));
self.step_val(storage);
}
self.step_key(storage);
}
out
}
}