#observable #events #delegates #reactive #no-std

no-std squeak

Library providing types allowing execution of callbacks in response to values being broadcast or mutated

2 unstable releases

0.2.0 Dec 26, 2023
0.1.0 Dec 4, 2022

#958 in Rust patterns

MIT/Apache

15KB
132 lines

Squeak

build_badge crates.io_badge docs_badge

Squeak is a zero-dependency Rust library to facilitate event-driven programming.

Examples

use squeak::{Delegate, Response};

let on_damage_received = Delegate::new();
on_damage_received.subscribe(|amount| {
    println!("Received {amount} damage");
    Response::StaySubscribed
});

on_damage_received.broadcast(16); // Prints "Received 16 damage"
on_damage_received.broadcast(14); // Prints "Received 14 damage"
on_damage_received.broadcast(28); // Prints "Received 28 damage"
use squeak::{Observable, Response};

let mut health = Observable::new(100);
health.subscribe(|updated_health| {
    println!("Health is now {updated_health}");
    Response::StaySubscribed
});

health.mutate(|h| *h -= 10); // Prints "Health is now 90"
health.mutate(|h| *h -= 5);  // Prints "Health is now 85"
health.mutate(|h| *h += 25); // Prints "Health is now 110"

No runtime deps