logo
pub struct SplitOperator<D1> where
    D1: Data + for<'a> Deserialize<'a>, 
{ /* private fields */ }
Expand description

Splits an incoming stream of type D1 into two different streams of type D1 using the provided condition function. When evaluated to true, sends messages to left stream, and right stream otherwise.

Example

The below example shows how to use a SplitOperator to split an incoming stream of usize messages into two different streams one with messages > 10 (left stream) and one with messages <= 10 (right stream), and send them.

// Add the mapping function as an argument to the operator via the OperatorConfig.
let split_config = OperatorConfig::new().name("SplitOperator");
let (left_stream, right_stream) = erdos::connect_one_in_two_out(
    || -> SplitOperator<usize> { SplitOperator::new(|a: &usize| -> bool { a > &10 }) },
    || {},
    split_config,
    &source_stream,
);

Implementations

Trait Implementations

Auto Trait Implementations

Blanket Implementations

Gets the TypeId of self. Read more

Immutably borrows from an owned value. Read more

Mutably borrows from an owned value. Read more

Returns the argument unchanged.

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more

Instruments this type with the current Span, returning an Instrumented wrapper. Read more

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

The type returned in the event of a conversion error.

Performs the conversion.

The type returned in the event of a conversion error.

Performs the conversion.

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more