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