protoflow_blocks

Struct Count

source
pub struct Count<T: Message> {
    pub input: InputPort<T>,
    pub output: OutputPort<T>,
    pub count: OutputPort<u64>,
    /* private fields */
}
Expand description

A block that counts the number of messages it receives, while optionally passing them through.

§Block Diagram

block-beta
    columns 7
    Source space:2 Count space:2 Sink
    space:7
    space:7
    space:3 Result space:3
    Source-- "input" -->Count
    Count-- "output" -->Sink
    Count-- "count" -->Result

    classDef block height:48px,padding:8px;
    classDef hidden visibility:none;
    class Count block
    class Source hidden
    class Sink hidden
    class Result hidden

§Sequence Diagram

sequenceDiagram
    autonumber
    participant BlockA as Another block
    participant Count.input as Count.input port
    participant Count as Count block
    participant Count.output as Count.output port
    participant BlockB as Another block
    participant Count.count as Count.count port
    participant BlockC as Another block

    BlockA-->>Count: Connect
    Count-->>BlockB: Connect

    loop Count process
        BlockA->>Count: Message
        Count->>Count: Increment counter
        Count->>BlockB: Message
    end

    BlockA-->>Count: Disconnect
    Count-->>Count.input: Close
    Count-->>Count.output: Close
    Count-->>BlockB: Disconnect

    Count-->>BlockC: Connect
    Count->>BlockC: Counter
    Count-->>Count.count: Close
    Count-->>BlockC: Disconnect

    %% TODO

§Examples

§Using the block in a system

System::build(|s| {
    let stdin = s.read_stdin();
    let line_decoder = s.decode_lines();
    let counter = s.count::<String>();
    let count_encoder = s.encode_lines();
    let stdout = s.write_stdout();
    s.connect(&stdin.output, &line_decoder.input);
    s.connect(&line_decoder.output, &counter.input);
    s.connect(&counter.count, &count_encoder.input);
    s.connect(&count_encoder.output, &stdout.input);
});

§Running the block via the CLI

$ protoflow execute Count

Fields§

§input: InputPort<T>

The input message stream.

§output: OutputPort<T>

The (optional) output target for the stream being passed through.

§count: OutputPort<u64>

The output port for the message count.

Implementations§

source§

impl<T: Message> Count<T>

source

pub fn new( input: InputPort<T>, output: OutputPort<T>, count: OutputPort<u64>, ) -> Self

Trait Implementations§

source§

impl<T: Message> Block for Count<T>

source§

fn execute(&mut self, runtime: &dyn BlockRuntime) -> BlockResult

Executes this block’s computation.
source§

fn prepare(&mut self, _runtime: &dyn BlockRuntime) -> Result<(), BlockError>

Prepares this block for execution. Read more
source§

impl<T: Message> BlockDescriptor for Count<T>

source§

fn inputs(&self) -> Vec<PortDescriptor>

A description of this block’s input ports.
source§

fn outputs(&self) -> Vec<PortDescriptor>

A description of this block’s output ports.
source§

fn parameters(&self) -> Vec<ParameterDescriptor>

A description of this block’s parameters.
source§

impl<T: Clone + Message> Clone for Count<T>

source§

fn clone(&self) -> Count<T>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<T: Message> Definition for Count<T>

source§

impl<T: Message> Element for Count<T>

source§

fn id(&self) -> Option<&str>

The unique element ID, if any.
source§

fn alias_ids(&self) -> Vec<&str>

Various alternative identifiers for this Element.
source§

fn name(&self) -> Option<&str>

The name of the element.
source§

fn short_name(&self) -> Option<&str>

The short name of the element, if any.
source§

fn is_library_element(&self) -> bool

Whether this Element is contained in the ownership tree of a library model.
source§

fn owner(&self) -> Option<&dyn Element>

The owner of this Element, if any.
source§

fn owning_namespace(&self) -> Option<&dyn Namespace>

The Namespace that owns this Element, if any.
source§

fn owning_relationship(&self) -> Option<&dyn Relationship>

The Relationship for which this Element is an owned_related_element, if any.
source§

fn qualified_name(&self) -> Option<QualifiedName>

source§

impl<T: Message> MaybeLabeled for Count<T>

source§

fn label(&self) -> Option<Cow<'_, str>>

Returns the human-readable label, if any, of the object.
source§

fn is_labeled(&self) -> bool

Checks whether the object has a human-readable label.
source§

impl<T: Message> MaybeNamed for Count<T>

source§

fn name(&self) -> Option<Cow<'_, str>>

Returns the name, if any, of the object.
source§

fn is_named(&self) -> bool

Checks whether the object has a name.
source§

impl<T: Message> Namespace for Count<T>

source§

fn names_of(&self, _element: &dyn Element) -> Vec<String>

source§

impl<T: Message> OccurrenceDefinition for Count<T>

source§

impl<T: Message + FromStr + ToString + 'static> StdioSystem for Count<T>

source§

impl<T: Message> Type for Count<T>

source§

fn is_abstract(&self) -> bool

source§

fn is_sufficient(&self) -> bool

source§

fn is_conjugated(&self) -> bool

source§

fn specializes(&self, _supertype: &Self) -> bool

source§

impl<T: Message> BlockDefinition for Count<T>

source§

impl<T: Message> Class for Count<T>

source§

impl<T: Message> Classifier for Count<T>

source§

impl<T: Message> ItemDefinition for Count<T>

source§

impl<T: Message> PartDefinition for Count<T>

source§

impl<T: Message> Structure for Count<T>

Auto Trait Implementations§

§

impl<T> Freeze for Count<T>

§

impl<T> !RefUnwindSafe for Count<T>

§

impl<T> Send for Count<T>

§

impl<T> Sync for Count<T>

§

impl<T> Unpin for Count<T>
where T: Unpin,

§

impl<T> !UnwindSafe for Count<T>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> AsBlock for T
where T: Block,

source§

fn as_block(&self) -> &dyn Block

source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

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

source§

impl<T> ToOwned for T
where T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

source§

fn vzip(self) -> V