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
pub mod stdio;

use std::error::Error;
use events::Event;
use pipeline::chain::{Propagate,Emit};

pub trait AcceptEvents {
    fn accept_events(&self, events: &[Event<'static>]) -> Result<(), Box<Error>>;
}

pub struct CollectorElement<T: AcceptEvents + Sync> {
    collector: T
}

impl<T: AcceptEvents + Sync> CollectorElement<T> {
    pub fn new(collector: T) -> CollectorElement<T> {
         CollectorElement {collector: collector}
    }
}

impl<T: AcceptEvents + Sync> Propagate for CollectorElement<T> {
    #[allow(unused_must_use)]
    fn propagate(&self, event: Event<'static>, next: &Emit) {
        let mut batch = vec![event];
        // TODO - self-log
        self.collector.accept_events(&batch);
        next.emit(batch.pop().unwrap());
    }
}