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
use std::cell::UnsafeCell; use std::rc::Rc; use std::marker::PhantomData; use std::os::raw::c_void; use crate::Sender; use crate::priv_traits::*; pub struct Inspect<'a, T, F: Fn(&T)>{ inspect: F, sender: Sender<'a,T>, _marker: PhantomData<T>, } impl<'a,T, F: Fn(&T)> Inspect<'a,T,F>{ pub fn new(inspect: F) -> Inspect<'a,T,F>{ Inspect{ inspect, sender: Sender::new(), _marker: PhantomData, } } } impl<'a,T, F: Fn(&T)> StreamInner<'a,T> for Inspect<'a,T,F>{ #[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, F: Fn(&T)> Remove for Inspect<'a,T,F>{ fn remove_raw(&mut self, st: *const c_void){ self.sender.remove_raw(st) } } impl<'a,T, F: Fn(&T)> SinkInner<'a, T> for Inspect<'a,T,F>{ #[inline] fn call(&mut self, t: T) -> Result<(),()>{ (self.inspect)(&t); self.sender.send(t); Ok(()) } #[inline] fn is_alive(&self) -> bool { true } }