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 58 59 60 61 62 63 64 65 66
use std::cell::UnsafeCell; use std::rc::Rc; use std::os::raw::c_void; use crate::Sender; use crate::priv_traits::*; use crate::Property; pub struct DedupOr<'a, T>{ last_value: Option<T>, sender: Sender<'a,T>, or: Property<'a, bool>, } impl<'a,T> DedupOr<'a,T>{ pub fn new(or: Property<'a, bool>) -> DedupOr<'a,T>{ DedupOr{ or, last_value: None, sender: Sender::new(), } } } impl<'a,T> StreamInner<'a,T> for DedupOr<'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 DedupOr<'a,T>{ fn remove_raw(&mut self, st: *const c_void){ self.sender.remove_raw(st) } } impl<'a, T: PartialEq + Clone> SinkInner<'a, T> for DedupOr<'a,T>{ #[inline] fn call(&mut self, t: T) -> Result<(),()>{ if let Some(prev) = self.last_value.as_ref(){ if *prev == t { return Ok(()) } } self.last_value = Some(t.clone()); if !*self.or.as_ref() { return Ok(()) } self.sender.send(t); Ok(()) } #[inline] fn is_alive(&self) -> bool { true } }