//! This project provides an ipc server and client implementation using //! messagepack. All calls are asynchronous and event based. //! Client Example: //! ```no_run //! use rmp_ipc::prelude::*; //! //! /// Callback ping function //! async fn handle_ping(ctx: &Context, event: Event) -> IPCResult<()> { //! println!("Received ping event."); //! ctx.emitter.emit_response(event.id(), "pong", ()).await?; //! //! Ok(()) //! } //! //! pub struct MyNamespace; //! //! impl MyNamespace { //! async fn ping(_ctx: &Context, _event: Event) -> IPCResult<()> { //! println!("My namespace received a ping"); //! Ok(()) //! } //! } //! //! impl NamespaceProvider for MyNamespace { //! fn name() -> &'static str {"my_namespace"} //! //! fn register(handler: &mut EventHandler) { //! events!(handler, //! "ping" => Self::ping, //! "ping2" => Self::ping //! ); //! } //!} //! //! #[tokio::main] //! async fn main() { //! // create the client //! let ctx = IPCBuilder::new() //! .address("127.0.0.1:2020") //! // register callback //! .on("ping", callback!(handle_ping)) //! .namespace("mainspace-client") //! // register callback inline //! .on("something", callback!(ctx, event, async move { //! println!("I think the server did something"); //! ctx.emitter.emit_response_to(event.id(), "mainspace-server", "ok", ()).await?; //! Ok(()) //! })) //! .build() //! .add_namespace(namespace!(MyNamespace)) //! .build_client().await.unwrap(); //! //! // emit an initial event //! let response = ctx.emitter.emit("ping", ()).await.unwrap().await_reply(&ctx).await.unwrap(); //! assert_eq!(response.name(), "pong"); //! } //! ``` //! //! Server Example: //! ```no_run //! use typemap_rev::TypeMapKey; //! use rmp_ipc::IPCBuilder; //! use rmp_ipc::callback; //! //! struct MyKey; //! //! impl TypeMapKey for MyKey { //! type Value = u32; //! } //! //! // create the server //!# async fn a() { //! IPCBuilder::new() //! .address("127.0.0.1:2020") //! // register callback //! .on("ping", callback!(ctx, event, async move { //! println!("Received ping event."); //! ctx.emitter.emit_response(event.id(), "pong", ()).await?; //! Ok(()) //! })) //! .namespace("mainspace-server") //! .on("do-something", callback!(ctx, event, async move { //! println!("Doing something"); //! { //! // access data //! let mut data = ctx.data.write().await; //! let mut my_key = data.get_mut::().unwrap(); //! *my_key += 1; //! } //! ctx.emitter.emit_response_to(event.id(), "mainspace-client", "something", ()).await?; //! Ok(()) //! })) //! .build() //! // store additional data //! .insert::(3) //! .build_server().await.unwrap(); //! # } //! ``` #[cfg(test)] mod tests; pub mod error; mod events; pub mod ipc; mod macros; mod namespaces; pub use events::error_event; pub use events::event; pub use events::event_handler; pub use ipc::builder::IPCBuilder; pub use macros::*; pub use namespaces::builder::NamespaceBuilder; pub use namespaces::namespace; pub use namespaces::provider_trait; pub mod prelude { pub use crate::error::Error as IPCError; pub use crate::error::Result as IPCResult; pub use crate::event::Event; pub use crate::event_handler::EventHandler; pub use crate::ipc::context::Context; pub use crate::ipc::*; pub use crate::macros::*; pub use crate::namespace::Namespace; pub use crate::namespaces::builder::NamespaceBuilder; pub use crate::namespaces::provider_trait::*; pub use crate::*; }