A flexible event bus crate enables decoupling between different components of an application through the event-driven pattern.
Basu provides support for both asynchronous and synchronous event handling.
Make sure you disable default-features
of the basu crate on Cargo.toml:
toml
[dependencies]
basu = { version = "0.1.0", default-features = false, features = ["sync"] }
To use Basu in your Rust project, add the following line to your Cargo.toml
file:
toml
[dependencies]
basu = "0.1.0"
```rust use basu::{BasuError, Event, EventBus, Handle};
struct MyEventHandler;
// Implement the Handle trait for your event handler structs
impl Handle
struct Data { message: String }
async fn main() { let event_bus = EventBus::new();
let eveny_type = "my_event";
// Subscribe to events by providing an event name and the corresponding event handler
let handler = Box::new(MyEventHandler);
let handler_id = event_bus.subscribe(eveny_type, handler)?;
// Publish events
let event = Event::new(Data {
message: "hello".to_owned(),
});
event_bus.publish(eveny_type, &event)?;
// Unsubscribe from events
event_bus.unsubscribe(eveny_type, &handler_id)?;
} ```
This project is licensed under the MIT license.