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 67 68 69 70 71 72 73
use std::cell::UnsafeCell; use std::rc::Rc; use std::os::raw::c_void; use crate::Sender; use crate::priv_traits::*; pub struct Take<'a, T>{ take: usize, taken: usize, sender: Sender<'a,T>, then: Option<T>, } impl<'a, T> Take<'a,T>{ pub fn new(take: usize) -> Take<'a,T>{ Take{ take: take, taken: 0, sender: Sender::new(), then: None, } } pub fn new_with_then(take: usize, then: T) -> Take<'a,T>{ Take{ take: take, taken: 0, sender: Sender::new(), then: Some(then), } } } impl<'a, 'p, T> StreamInner<'a,T> for Take<'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 Take<'a, T>{ fn remove_raw(&mut self, st: *const c_void){ self.sender.remove_raw(st) } } impl<'a,T> SinkInner<'a,T> for Take<'a,T>{ #[inline] fn call(&mut self, t: T) -> Result<(),()>{ if self.taken < self.take { self.sender.send(t); self.taken += 1; Ok(()) }else{ match self.then.take() { Some(then) => self.sender.send(then), _ => (), } Err(()) } } #[inline] fn is_alive(&self) -> bool { self.taken < self.take } }