Skip to main content

Flows

Struct Flows 

Source
pub struct Flows {
    pub inputs_receivers: Arc<Mutex<HashMap<Uuid, MessageReceiver>>>,
    pub outputs_senders: Arc<Mutex<HashMap<Uuid, Vec<MessageSender>>>>,
    pub queries_senders: Arc<Mutex<HashMap<Uuid, MessageSender>>>,
    pub queries_receivers: Arc<Mutex<HashMap<Uuid, MessageReceiver>>>,
    pub queryables_senders: Arc<Mutex<HashMap<Uuid, HashMap<Uuid, MessageSender>>>>,
    pub queryables_receivers: Arc<Mutex<HashMap<Uuid, MessageReceiver>>>,
}
Expand description

Represents the collection of flows in the system (all the MPSC channels)

Fields§

§inputs_receivers: Arc<Mutex<HashMap<Uuid, MessageReceiver>>>§outputs_senders: Arc<Mutex<HashMap<Uuid, Vec<MessageSender>>>>§queries_senders: Arc<Mutex<HashMap<Uuid, MessageSender>>>§queries_receivers: Arc<Mutex<HashMap<Uuid, MessageReceiver>>>§queryables_senders: Arc<Mutex<HashMap<Uuid, HashMap<Uuid, MessageSender>>>>§queryables_receivers: Arc<Mutex<HashMap<Uuid, MessageReceiver>>>

Implementations§

Source§

impl Flows

Source

pub async fn new( layout: Arc<DataflowLayout>, flows: impl AsyncFnOnce(&mut FlowsBuilder) -> Result<()>, ) -> Result<Self>

Creates a new Flows instance with a Building async closure

Examples found in repository?
examples/service_flows.rs (lines 21-25)
4async fn main() -> Result<()> {
5    let mut layout = DataflowLayout::new();
6
7    let (_service, queryable) = layout
8        .node("service", async |builder: &mut NodeIOBuilder| {
9            builder.queryable("queryable")
10        })
11        .await;
12
13    let (_client, query) = layout
14        .node("client", async |builder: &mut NodeIOBuilder| {
15            builder.query("query")
16        })
17        .await;
18
19    let layout = layout.build();
20
21    let _flows = Flows::new(layout.clone(), async move |builder: &mut FlowsBuilder| {
22        builder.connect(query, queryable, None)?;
23
24        Ok(())
25    })
26    .await?;
27
28    Ok(())
29}
More examples
Hide additional examples
examples/simple_flows.rs (lines 27-32)
4async fn main() -> Result<()> {
5    let mut layout = DataflowLayout::new();
6
7    let (_source, output) = layout
8        .node("source", async |builder: &mut NodeIOBuilder| {
9            builder.output("out")
10        })
11        .await;
12
13    let (_operator, (op_in, op_out)) = layout
14        .node("operator", async |builder: &mut NodeIOBuilder| {
15            (builder.input("in"), builder.output("out"))
16        })
17        .await;
18
19    let (_sink, input) = layout
20        .node("sink", async |builder: &mut NodeIOBuilder| {
21            builder.input("in")
22        })
23        .await;
24
25    let layout = layout.build();
26
27    let _flows = Flows::new(layout.clone(), async move |builder: &mut FlowsBuilder| {
28        builder.connect(op_in, output, None)?;
29        builder.connect(input, op_out, None)?;
30
31        Ok(())
32    })
33    .await?;
34
35    Ok(())
36}
Source

pub fn node_io( &self, clock: Arc<HLC>, source: NodeLayout, ) -> (Inputs, Outputs, Queries, Queryables)

This is intended to be used only by the Runtime when loading nodes

Trait Implementations§

Source§

impl Clone for Flows

Source§

fn clone(&self) -> Flows

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for Flows

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl Freeze for Flows

§

impl !RefUnwindSafe for Flows

§

impl Send for Flows

§

impl Sync for Flows

§

impl Unpin for Flows

§

impl UnsafeUnpin for Flows

§

impl !UnwindSafe for Flows

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> 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, dest: *mut u8)

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

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

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

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> Same for T

Source§

type Output = T

Should always be Self
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<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

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

fn with_current_subscriber(self) -> WithDispatch<Self>

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

impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<T> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,