2 releases

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

#1491 in Asynchronous

Download history 163/week @ 2024-11-16 306/week @ 2024-11-23 220/week @ 2024-11-30 154/week @ 2024-12-07 199/week @ 2024-12-14 47/week @ 2024-12-21 48/week @ 2024-12-28 134/week @ 2025-01-04 186/week @ 2025-01-11 156/week @ 2025-01-18 166/week @ 2025-01-25 302/week @ 2025-02-01 233/week @ 2025-02-08 434/week @ 2025-02-15 288/week @ 2025-02-22 166/week @ 2025-03-01

1,214 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

~150KB