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
use progress::Timestamp;
use progress::nested::{Source, Target};
use progress::ChangeBatch;
#[derive(Default)]
pub struct PointstampCounter<T:Timestamp> {
pub source: Vec<Vec<ChangeBatch<T>>>,
pub target: Vec<Vec<ChangeBatch<T>>>,
pub pushed: Vec<Vec<ChangeBatch<T>>>,
}
impl<T:Timestamp> PointstampCounter<T> {
pub fn update_target(&mut self, target: Target, time: T, value: i64) {
self.target[target.index][target.port].update(time, value);
}
pub fn update_source(&mut self, source: Source, time: T, value: i64) {
self.source[source.index][source.port].update(time, value);
}
pub fn clear(&mut self) {
for vec in &mut self.source { for map in vec.iter_mut() { map.clear(); } }
for vec in &mut self.target { for map in vec.iter_mut() { map.clear(); } }
for vec in &mut self.pushed { for map in vec.iter_mut() { map.clear(); } }
}
pub fn allocate_for_operator(&mut self, inputs: usize, outputs: usize) {
self.pushed.push(vec![ChangeBatch::new(); inputs]);
self.target.push(vec![ChangeBatch::new(); inputs]);
self.source.push(vec![ChangeBatch::new(); outputs]);
}
}