2 unstable releases

Uses old Rust 2015

0.1.0 Jun 10, 2017
0.0.1 May 28, 2017

#9 in #sender-receiver

Download history 61/week @ 2024-08-26 14/week @ 2024-09-02 9/week @ 2024-09-09 17/week @ 2024-09-16 46/week @ 2024-09-23 10/week @ 2024-09-30 7/week @ 2024-10-07 17/week @ 2024-10-14 14/week @ 2024-10-21 10/week @ 2024-10-28 20/week @ 2024-11-04 17/week @ 2024-11-18 22/week @ 2024-11-25 20/week @ 2024-12-02 36/week @ 2024-12-09

95 downloads per month
Used in 10 crates (4 directly)

MPL-2.0 license

52KB
884 lines

dharma crate provides high-level multi-threading support.

bridge module

bridge module provides similar functionality as standard spmc but instead of producing fixed pairs Sender-Receiver it allows to connect them freely, so we can have many one Sender sending to many Receivers and one Receiver listening to many senders in flexible, configurable way.

signaler module

On to of that we add Signaler which can subscribe receivers for signals (application defined events) creating notification mechanism.

event_loop module

On top of Signaler we add EventLoop, which is event queue assigned to thread. EventLoop has assigned Modules constituting separate application components. Modules can be assigned to EventLoops in flexible way making it easy to control tasks processed in threads. Modules do not share memory and communicate with signals.

dispatcher module

Every threading framework should provide mechanism for listening on system events. Dispatcher allows to register EventHandlers (wrapping file descriptors) and invokes them when system events they are assigned are ready to be processed.

system module

Last module contains helper code for and handling system signals.

Dependencies

~1.5MB
~37K SLoC