RawPooledReceiver

Struct RawPooledReceiver 

Source
pub struct RawPooledReceiver<T: Send + 'static> { /* private fields */ }
Expand description

Receives a single value from the sender connected to the same event.

Awaiting the receiver will yield either the payload of type T or a Disconnected error.

This kind of endpoint is used for events stored in a raw event pool or event lake.

Implementations§

Source§

impl<T: Send + 'static> RawPooledReceiver<T>

Source

pub fn is_ready(&self) -> bool

Checks whether a value is ready to be received.

§Panics

Panics if called after poll() has returned Ready.

Source

pub fn into_value(self) -> Result<T, IntoValueError<Self>>

Consumes the receiver and transforms it into the received value, if the value is available.

This method provides an alternative to awaiting the receiver when you want to check for an immediately available value without blocking. It returns Ok(value) if a value has already been sent, or returns the receiver if no value is currently available.

§Panics

Panics if the value has already been received via Future::poll().

§Examples
use events_once::{Event, IntoValueError};

#[tokio::main]
async fn main() {
    let (sender, receiver) = Event::<String>::boxed();

    // into_value() is designed for synchronous scenarios where you do not want to wait but
    // simply want to either obtain the received value or do nothing. First, we do nothing.
    //
    // If no value has been sent yet, into_value() returns Err(IntoValueError::Pending(self)).
    let Err(IntoValueError::Pending(receiver)) = receiver.into_value() else {
        panic!(
            "Expected receiver to indicate that it is still waiting for a payload to be sent."
        );
    };

    sender.send("Hello, world!".to_string());

    let message = receiver.into_value().unwrap();

    println!("Received message: {message}");
}

Trait Implementations§

Source§

impl<T: Send + 'static> Debug for RawPooledReceiver<T>

Source§

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

Formats the value using the given formatter. Read more
Source§

impl<T: Send + 'static> Future for RawPooledReceiver<T>

Source§

type Output = Result<T, Disconnected>

The type of value produced on completion.
Source§

fn poll(self: Pin<&mut Self>, cx: &mut Context<'_>) -> Poll<Self::Output>

Attempts to resolve the future to a final value, registering the current task for wakeup if the value is not yet available. Read more

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> 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, 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<F> IntoFuture for F
where F: Future,

Source§

type Output = <F as Future>::Output

The output that the future will produce on completion.
Source§

type IntoFuture = F

Which kind of future are we turning this into?
Source§

fn into_future(self) -> <F as IntoFuture>::IntoFuture

Creates a future from a value. 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.