differential_dataflow/trace/cursor/
mod.rs1pub mod cursor_list;
9
10pub use self::cursor_list::CursorList;
11
12use crate::trace::implementations::LayoutExt;
13
14pub trait Cursor : LayoutExt {
16
17 type Storage;
19
20 fn key_valid(&self, storage: &Self::Storage) -> bool;
24 fn val_valid(&self, storage: &Self::Storage) -> bool;
28
29 fn key<'a>(&self, storage: &'a Self::Storage) -> Self::Key<'a>;
31 fn val<'a>(&self, storage: &'a Self::Storage) -> Self::Val<'a>;
33
34 fn get_key<'a>(&self, storage: &'a Self::Storage) -> Option<Self::Key<'a>>;
36 fn get_val<'a>(&self, storage: &'a Self::Storage) -> Option<Self::Val<'a>>;
38
39 fn map_times<L: FnMut(Self::TimeGat<'_>, Self::DiffGat<'_>)>(&mut self, storage: &Self::Storage, logic: L);
42
43 fn step_key(&mut self, storage: &Self::Storage);
45 fn seek_key(&mut self, storage: &Self::Storage, key: Self::Key<'_>);
47
48 fn step_val(&mut self, storage: &Self::Storage);
50 fn seek_val(&mut self, storage: &Self::Storage, val: Self::Val<'_>);
52
53 fn rewind_keys(&mut self, storage: &Self::Storage);
55 fn rewind_vals(&mut self, storage: &Self::Storage);
57
58 fn populate_key<'a>(&mut self, storage: &'a Self::Storage, key: Self::Key<'a>, meet: Option<&Self::Time>, target: &mut crate::operators::EditList<Self::Val<'a>, Self::Time, Self::Diff>) {
63 target.clear();
64 self.seek_key(storage, key);
65 if self.get_key(storage) == Some(key) {
66 self.rewind_vals(storage);
67 while let Some(val) = self.get_val(storage) {
68 self.map_times(storage, |time, diff| {
69 use crate::lattice::Lattice;
70 let mut time = Self::owned_time(time);
71 if let Some(meet) = meet { time.join_assign(meet); }
72 target.push(time, Self::owned_diff(diff))
73 });
74 target.seal(val);
75 self.step_val(storage);
76 }
77 }
78 }
79
80 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)>)>
82 where
83 IK: for<'a> Fn(Self::Key<'a>) -> K,
84 IV: for<'a> Fn(Self::Val<'a>) -> V,
85 {
86 let mut out = Vec::new();
87 self.rewind_keys(storage);
88 while let Some(key) = self.get_key(storage) {
89 self.rewind_vals(storage);
90 while let Some(val) = self.get_val(storage) {
91 let mut kv_out = Vec::new();
92 self.map_times(storage, |ts, r| {
93 kv_out.push((Self::owned_time(ts), Self::owned_diff(r)));
94 });
95 out.push(((into_key(key), into_val(val)), kv_out));
96 self.step_val(storage);
97 }
98 self.step_key(storage);
99 }
100 out
101 }
102}