BasicMediator

Struct BasicMediator 

Source
pub struct BasicMediator<Ev>
where Ev: Debug,
{ /* private fields */ }
Expand description

Basic mediator for synchronous environments with events of type Ev.

A BasicMediator is constructed through its builder. It receives requests through its SyncMediatorInternalHandle::send() interface, which are processed by the user-defined RequestHandler implementation. From within this handler, events of type Ev can be published using the BasicMediator::publish() functionality. Listeners injected with super::BasicBuilder::add_listener() are invoked when the user calls BasicMediator::next().

§Examples

Basic usage:

use mediator_sys::synchronous::basic::*;

#[derive(Debug, Clone)]
enum MyEvent {
    One,
    Two
}

struct Request(u32);

impl RequestHandler<Request, MyEvent> for BasicMediator<MyEvent> {
    fn handle(&self, req: Request) {
        match req.0 {
            1 => self.publish(MyEvent::One),
            2 => self.publish(MyEvent::Two),
            _ => ()
        };
    }
}

let mediator = BasicMediator::<MyEvent>::builder()
    .add_listener(move |ev| {
        /* Your listening logic */
    })
    .add_listener(move |ev| {
        /* Your listening logic */
    })
    .build();

    mediator.send(Request(1));
    mediator.next().ok();

Trait Implementations§

Source§

impl<Ev> BuilderFlow<BasicMediator<Ev>> for BasicBuilder<Ev>
where Ev: Debug,

Source§

fn build(self) -> BasicMediator<Ev>

Builds the BasicMediator and returns it.

Because BasicMediator implements BuilderInternal, which in turn means, that the BasicBuilder implements BuilderFlow and not crate::builder::TryBuilderFlow, this method will always return a BasicMediator as stated by the return type.

Source§

impl<Ev> BuilderInternal<BasicMediator<Ev>, BasicBuilder<Ev>> for BasicMediator<Ev>
where Ev: Debug,

Source§

fn builder() -> BasicBuilder<Ev>

Creates a BasicBuilder with the goal of producing a BasicMediator.

Source§

impl<Ev> Debug for BasicMediator<Ev>
where Ev: Debug + Debug,

Source§

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

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

impl<Ev> SyncMediatorInternal<Ev> for BasicMediator<Ev>
where Ev: Debug,

Source§

fn publish(&self, event: Ev)

Publishes an event Ev.

This method should be used within RequestHandler::handle() to publish a user-defined event.

§Examples

Basic usage:

use mediator_sys::synchronous::basic::*;

#[derive(Debug, Clone)]
enum MyEvent {
    One,
    Two
}

struct Request(u32);

impl RequestHandler<Request, MyEvent> for BasicMediator<MyEvent> {
    fn handle(&self, req: Request) {
        match req.0 {
            1 => self.publish(MyEvent::One),
            2 => self.publish(MyEvent::Two),
            _ => ()
        };
    }
}
Source§

impl<Ev> SyncMediatorInternalHandle<Ev> for BasicMediator<Ev>
where Ev: Debug,

Source§

fn send<Req>(&self, req: Req)
where Self: RequestHandler<Req, Ev>,

Send a request of type Req to the mediator.

The request will be processed internally by RequestHandler::handle(). This is why it is required to implement RequestHandler for BasicMediator.

Source§

impl<Ev> SyncMediatorInternalNext for BasicMediator<Ev>
where Ev: Debug + Clone,

Source§

fn next(&self) -> Result<(), TryRecvError>

Process the next published event Ev.

SyncMediatorInternalNext::next() invokes registered listeners with a cloned value of the published event.

Auto Trait Implementations§

§

impl<Ev> Freeze for BasicMediator<Ev>

§

impl<Ev> !RefUnwindSafe for BasicMediator<Ev>

§

impl<Ev> Send for BasicMediator<Ev>
where Ev: Send,

§

impl<Ev> !Sync for BasicMediator<Ev>

§

impl<Ev> Unpin for BasicMediator<Ev>

§

impl<Ev> !UnwindSafe for BasicMediator<Ev>

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<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.