2 releases

0.1.5 Jun 20, 2022
0.1.4 Nov 13, 2020
0.1.2 Sep 10, 2020

#1098 in Asynchronous

Download history 93/week @ 2024-07-22 101/week @ 2024-07-29 71/week @ 2024-08-05 90/week @ 2024-08-12 56/week @ 2024-08-19 203/week @ 2024-08-26 199/week @ 2024-09-02 121/week @ 2024-09-09 126/week @ 2024-09-16 210/week @ 2024-09-23 136/week @ 2024-09-30 99/week @ 2024-10-07 159/week @ 2024-10-14 118/week @ 2024-10-21 177/week @ 2024-10-28 133/week @ 2024-11-04

589 downloads per month
Used in 6 crates (2 directly)

Apache-2.0

10KB
83 lines

catty

a picture of a slingshot

Send a value synchronously and asynchronously wait for it. Catty is faster, simpler, and more lightweight than futures::oneshot, which is slightly more flexible.

Example

let (tx, rx) = catty::oneshot();
tx.send("Hello!");
assert_eq!(rx.await, Ok("Hello!"));

Benchmarks

To run the benchmarks with Criterion, simply do cargo bench. On my machine, the results are as follows:

create-futures          time:   [70.934 ns 70.979 ns 71.045 ns]
create-catty            time:   [32.549 ns 32.594 ns 32.650 ns]
oneshot-futures         time:   [146.45 ns 146.76 ns 147.09 ns]
oneshot-catty           time:   [98.497 ns 99.065 ns 99.686 ns]
send-futures            time:   [80.163 ns 80.384 ns 80.680 ns]
send-catty              time:   [39.064 ns 39.206 ns 39.354 ns]

lib.rs:

Send a value and asynchronously wait for it.

Example

let (tx, rx) = catty::oneshot();
tx.send("Hello!");
assert_eq!(rx.await, Ok("Hello!"));

Dependencies

~145KB