Node

Struct Node 

Source
pub struct Node { /* private fields */ }

Implementations§

Source§

impl Node

Source

pub async fn create_publisher<T: Sendable>( &self, topic: String, ) -> Result<Publisher<T>>

Examples found in repository?
examples/sub.rs (line 13)
5async fn main() -> anyhow::Result<()> {
6    env_logger::init();
7
8    let node = Node::create("node2".to_owned()).await?;
9    let mut subber = node
10        .create_subscriber::<msg::String>("/some_topic".to_owned(), 10)
11        .await?;
12    let pubber = node
13        .create_publisher::<msg::String>("/another_topic".to_owned())
14        .await?;
15    let pubber2 = node
16        .create_publisher::<msg::String>("/boring_topic".to_owned())
17        .await?;
18
19    let msg_out = msg::String {
20        data: "sup".to_owned(),
21    };
22
23    let boring_msg = msg::String {
24        data: "🙄".to_owned(),
25    };
26
27    let mut pubbing = tokio::time::interval(std::time::Duration::from_millis(4320));
28
29    tokio::spawn(async move {
30        loop {
31            pubbing.tick().await;
32            pubber2.publish(&boring_msg).await.unwrap();
33        }
34    });
35
36    while let Some(msg) = subber.next().await {
37        println!("Got: {}", &msg.data);
38        pubber.publish(&msg_out).await.unwrap();
39    }
40
41    Ok(())
42}
More examples
Hide additional examples
examples/pub.rs (line 10)
5async fn main() -> anyhow::Result<()> {
6    env_logger::init();
7
8    let node = Node::create("node1".to_owned()).await?;
9    let pubber = node
10        .create_publisher::<msg::String>("/some_topic".to_owned())
11        .await?;
12    let mut subber = node
13        .create_subscriber::<msg::String>("/another_topic".to_owned(), 10)
14        .await?;
15    let mut subber2 = node
16        .create_subscriber::<msg::String>("/boring_topic".to_owned(), 10)
17        .await?;
18    let mut useless_subber = node
19        .create_subscriber::<msg::String>("/nothing_here".to_owned(), 10)
20        .await?;
21
22    let msg = msg::String {
23        data: "heyhio".to_owned(),
24    };
25
26    tokio::spawn(async move {
27        while let Some(_) = useless_subber.next().await {
28            log::error!("ehh.. no?");
29        }
30    });
31
32    let mut pubbing = tokio::time::interval(std::time::Duration::from_secs(1));
33    loop {
34        tokio::select! {
35            _ = pubbing.tick() => {
36                pubber.publish(&msg).await?;
37            }
38            msg_in = subber.next() => {
39                match msg_in {
40                    Some(msg_in) => {
41                        println!("Got: {}", msg_in.data);
42                    },
43                    None => {
44                        break;
45                    },
46                }
47            }
48            msg_in = subber2.next() => {
49                match msg_in {
50                    Some(msg_in) => {
51                        println!("Got: {}", msg_in.data);
52                    },
53                    None => {
54                        break;
55                    },
56                }
57            }
58        }
59    }
60
61    Ok(())
62}
Source

pub async fn create_subscriber<T>( &self, topic: String, queue_size: usize, ) -> Result<Subscriber<T>>
where T: Send + Sync + 'static + Archive, T::Archived: for<'a> CheckBytes<HighValidator<'a, Error>> + Deserialize<T, Strategy<Pool, Error>>,

Examples found in repository?
examples/sub.rs (line 10)
5async fn main() -> anyhow::Result<()> {
6    env_logger::init();
7
8    let node = Node::create("node2".to_owned()).await?;
9    let mut subber = node
10        .create_subscriber::<msg::String>("/some_topic".to_owned(), 10)
11        .await?;
12    let pubber = node
13        .create_publisher::<msg::String>("/another_topic".to_owned())
14        .await?;
15    let pubber2 = node
16        .create_publisher::<msg::String>("/boring_topic".to_owned())
17        .await?;
18
19    let msg_out = msg::String {
20        data: "sup".to_owned(),
21    };
22
23    let boring_msg = msg::String {
24        data: "🙄".to_owned(),
25    };
26
27    let mut pubbing = tokio::time::interval(std::time::Duration::from_millis(4320));
28
29    tokio::spawn(async move {
30        loop {
31            pubbing.tick().await;
32            pubber2.publish(&boring_msg).await.unwrap();
33        }
34    });
35
36    while let Some(msg) = subber.next().await {
37        println!("Got: {}", &msg.data);
38        pubber.publish(&msg_out).await.unwrap();
39    }
40
41    Ok(())
42}
More examples
Hide additional examples
examples/pub.rs (line 13)
5async fn main() -> anyhow::Result<()> {
6    env_logger::init();
7
8    let node = Node::create("node1".to_owned()).await?;
9    let pubber = node
10        .create_publisher::<msg::String>("/some_topic".to_owned())
11        .await?;
12    let mut subber = node
13        .create_subscriber::<msg::String>("/another_topic".to_owned(), 10)
14        .await?;
15    let mut subber2 = node
16        .create_subscriber::<msg::String>("/boring_topic".to_owned(), 10)
17        .await?;
18    let mut useless_subber = node
19        .create_subscriber::<msg::String>("/nothing_here".to_owned(), 10)
20        .await?;
21
22    let msg = msg::String {
23        data: "heyhio".to_owned(),
24    };
25
26    tokio::spawn(async move {
27        while let Some(_) = useless_subber.next().await {
28            log::error!("ehh.. no?");
29        }
30    });
31
32    let mut pubbing = tokio::time::interval(std::time::Duration::from_secs(1));
33    loop {
34        tokio::select! {
35            _ = pubbing.tick() => {
36                pubber.publish(&msg).await?;
37            }
38            msg_in = subber.next() => {
39                match msg_in {
40                    Some(msg_in) => {
41                        println!("Got: {}", msg_in.data);
42                    },
43                    None => {
44                        break;
45                    },
46                }
47            }
48            msg_in = subber2.next() => {
49                match msg_in {
50                    Some(msg_in) => {
51                        println!("Got: {}", msg_in.data);
52                    },
53                    None => {
54                        break;
55                    },
56                }
57            }
58        }
59    }
60
61    Ok(())
62}
Source

pub async fn create(name: String) -> Result<Self>

Examples found in repository?
examples/sub.rs (line 8)
5async fn main() -> anyhow::Result<()> {
6    env_logger::init();
7
8    let node = Node::create("node2".to_owned()).await?;
9    let mut subber = node
10        .create_subscriber::<msg::String>("/some_topic".to_owned(), 10)
11        .await?;
12    let pubber = node
13        .create_publisher::<msg::String>("/another_topic".to_owned())
14        .await?;
15    let pubber2 = node
16        .create_publisher::<msg::String>("/boring_topic".to_owned())
17        .await?;
18
19    let msg_out = msg::String {
20        data: "sup".to_owned(),
21    };
22
23    let boring_msg = msg::String {
24        data: "🙄".to_owned(),
25    };
26
27    let mut pubbing = tokio::time::interval(std::time::Duration::from_millis(4320));
28
29    tokio::spawn(async move {
30        loop {
31            pubbing.tick().await;
32            pubber2.publish(&boring_msg).await.unwrap();
33        }
34    });
35
36    while let Some(msg) = subber.next().await {
37        println!("Got: {}", &msg.data);
38        pubber.publish(&msg_out).await.unwrap();
39    }
40
41    Ok(())
42}
More examples
Hide additional examples
examples/pub.rs (line 8)
5async fn main() -> anyhow::Result<()> {
6    env_logger::init();
7
8    let node = Node::create("node1".to_owned()).await?;
9    let pubber = node
10        .create_publisher::<msg::String>("/some_topic".to_owned())
11        .await?;
12    let mut subber = node
13        .create_subscriber::<msg::String>("/another_topic".to_owned(), 10)
14        .await?;
15    let mut subber2 = node
16        .create_subscriber::<msg::String>("/boring_topic".to_owned(), 10)
17        .await?;
18    let mut useless_subber = node
19        .create_subscriber::<msg::String>("/nothing_here".to_owned(), 10)
20        .await?;
21
22    let msg = msg::String {
23        data: "heyhio".to_owned(),
24    };
25
26    tokio::spawn(async move {
27        while let Some(_) = useless_subber.next().await {
28            log::error!("ehh.. no?");
29        }
30    });
31
32    let mut pubbing = tokio::time::interval(std::time::Duration::from_secs(1));
33    loop {
34        tokio::select! {
35            _ = pubbing.tick() => {
36                pubber.publish(&msg).await?;
37            }
38            msg_in = subber.next() => {
39                match msg_in {
40                    Some(msg_in) => {
41                        println!("Got: {}", msg_in.data);
42                    },
43                    None => {
44                        break;
45                    },
46                }
47            }
48            msg_in = subber2.next() => {
49                match msg_in {
50                    Some(msg_in) => {
51                        println!("Got: {}", msg_in.data);
52                    },
53                    None => {
54                        break;
55                    },
56                }
57            }
58        }
59    }
60
61    Ok(())
62}

Trait Implementations§

Source§

impl Debug for Node

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl Freeze for Node

§

impl !RefUnwindSafe for Node

§

impl Send for Node

§

impl Sync for Node

§

impl Unpin for Node

§

impl !UnwindSafe for Node

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> ArchivePointee for T

Source§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
Source§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
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> 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> LayoutRaw for T

Source§

fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>

Returns the layout of the type.
Source§

impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
where T: SharedNiching<N1, N2>, N1: Niching<T>, N2: Niching<T>,

Source§

unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool

Returns whether the given value has been niched. Read more
Source§

fn resolve_niched(out: Place<NichedOption<T, N1>>)

Writes data to out indicating that a T is niched.
Source§

impl<T> Pointee for T

Source§

type Metadata = ()

The metadata type for pointers and references to this type.
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<SS, SP> SupersetOf<SS> for SP
where SS: SubsetOf<SP>,

Source§

fn to_subset(&self) -> Option<SS>

The inverse inclusion map: attempts to construct self from the equivalent element of its superset. Read more
Source§

fn is_in_subset(&self) -> bool

Checks if self is actually part of its subset T (and can be converted to it).
Source§

fn to_subset_unchecked(&self) -> SS

Use with care! Same as self.to_subset but without any property checks. Always succeeds.
Source§

fn from_subset(element: &SS) -> SP

The inclusion map: converts self to the equivalent element of its superset.
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

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