Struct protoflow_blocks::ReadDir

source ·
pub struct ReadDir {
    pub path: InputPort<String>,
    pub output: OutputPort<String>,
}
Expand description

A block that reads file names from a file system directory.

§Block Diagram

block-beta
    columns 4
    Config space:3
    space:4
    space:4
    ReadDir space:2 Sink
    Config-- "path" -->ReadDir
    ReadDir-- "output" -->Sink

    classDef block height:48px,padding:8px;
    classDef hidden visibility:none;
    class ReadDir block
    class Config hidden
    class Sink hidden

§Sequence Diagram

sequenceDiagram
    autonumber
    participant BlockA as Another block
    participant ReadDir.path as ReadDir.path port
    participant ReadDir as ReadDir block
    participant ReadDir.output as ReadDir.output port
    participant BlockB as Another block

    BlockA-->>ReadDir: Connect

    BlockA->>ReadDir: Message (e.g. "/tmp")
    ReadDir-->>ReadDir.path: Close
    ReadDir-->>BlockA: Disconnect
    ReadDir-->>BlockB: Connect

    loop ReadDir process
        ReadDir->>ReadDir: Read directory entries
        ReadDir->>BlockB: Message (e.g. "/tmp/file.txt")
    end

    ReadDir-->>ReadDir.output: Close
    ReadDir-->>BlockB: Disconnect

§Examples

§Using the block in a system

System::build(|s| {
    let path_param = s.const_string("/tmp");
    let dir_reader = s.read_dir();
    let line_encoder = s.encode_lines();
    let stdout = s.write_stdout();
    s.connect(&path_param.output, &dir_reader.path);
    s.connect(&dir_reader.output, &line_encoder.input);
    s.connect(&line_encoder.output, &stdout.input);
});

§Running the block via the CLI

$ protoflow execute ReadDir path=/tmp

Fields§

§path: InputPort<String>

The path to the directory to read.

§output: OutputPort<String>

The output message stream.

Implementations§

source§

impl ReadDir

source

pub fn new(path: InputPort<String>, output: OutputPort<String>) -> Self

Trait Implementations§

source§

impl Block for ReadDir

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 BlockDescriptor for ReadDir

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 Clone for ReadDir

source§

fn clone(&self) -> ReadDir

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 Definition for ReadDir

source§

impl Element for ReadDir

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 MaybeLabeled for ReadDir

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 MaybeNamed for ReadDir

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 Namespace for ReadDir

source§

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

source§

impl OccurrenceDefinition for ReadDir

source§

impl StdioSystem for ReadDir

source§

impl Type for ReadDir

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 BlockDefinition for ReadDir

source§

impl Class for ReadDir

source§

impl Classifier for ReadDir

source§

impl ItemDefinition for ReadDir

source§

impl PartDefinition for ReadDir

source§

impl Structure for ReadDir

Auto Trait Implementations§

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