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 TakeWhile<'a, T, F: FnMut(&T) -> bool>{ f: F, sender: Sender<'a,T>, then: Option<T>, is_alive: bool, } impl<'a, T, F: FnMut(&T) -> bool> TakeWhile<'a,T,F>{ pub fn new(f: F) -> TakeWhile<'a,T,F>{ TakeWhile{ f: f, sender: Sender::new(), then: None, is_alive: true, } } pub fn new_with_then(f: F, then: T) -> TakeWhile<'a,T,F>{ TakeWhile{ f: f, sender: Sender::new(), then: Some(then), is_alive: true, } } } impl<'a,T, F: FnMut(&T) -> bool> StreamInner<'a,T> for TakeWhile<'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: FnMut(&T) -> bool> Remove for TakeWhile<'a, T,F>{ fn remove_raw(&mut self, st: *const c_void){ self.sender.remove_raw(st) } } impl<'a, T, F: FnMut(&T) -> bool> SinkInner<'a,T> for TakeWhile<'a,T,F>{ #[inline] fn call(&mut self, t: T) -> Result<(),()>{ if (self.f)(&t) { self.sender.send(t); Ok(()) }else{ match self.then.take(){ Some(then) => self.sender.send(then), None => () } self.is_alive = false; Err(()) } } #[inline] fn is_alive(&self) -> bool { self.is_alive } }