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
use std::cell::UnsafeCell; use std::rc::Rc; use std::os::raw::c_void; use std::collections::VecDeque; use crate::Sender; use crate::priv_traits::*; pub struct Delay<'a, T>{ last_values: VecDeque<T>, delay: usize, sender: Sender<'a,T>, } impl<'a,T> Delay<'a,T>{ pub fn new(delay: usize) -> Delay<'a,T>{ Delay{ last_values: VecDeque::new(), delay: delay, sender: Sender::new(), } } } impl<'a,T> StreamInner<'a,T> for Delay<'a,T>{ #[inline] fn push(&mut self, st: Rc<UnsafeCell<dyn SinkInner<'a,T>+'a>>){ self.sender.push(st) } #[inline] fn send(&mut self, t: T){ self.sender.send(t) } } impl<'a,T> Remove for Delay<'a,T>{ fn remove_raw(&mut self, st: *const c_void){ self.sender.remove_raw(st) } } impl<'a, T> SinkInner<'a, T> for Delay<'a,T>{ #[inline] fn call(&mut self, t: T) -> Result<(),()>{ self.last_values.push_back(t); if self.last_values.len() > self.delay{ self.sender.send(self.last_values.pop_front().unwrap()); } Ok(()) } #[inline] fn is_alive(&self) -> bool { true } }