#queue #non-blocking #infallible #bulk #ring-buffer #enqueueing #dequeueing

no-std ufotofu_queues

Infallible queues that support bulk enqueueing and dequeueing

7 releases (breaking)

0.6.0 Nov 30, 2024
0.5.0 Aug 8, 2024
0.4.1 Aug 5, 2024
0.4.0 Jul 8, 2024
0.1.0 Jun 24, 2024

#542 in Algorithms

Download history 23/week @ 2024-09-18 42/week @ 2024-09-25 12/week @ 2024-10-02 6/week @ 2024-10-09 28/week @ 2024-10-16 89/week @ 2024-10-23 65/week @ 2024-10-30 11/week @ 2024-11-06 85/week @ 2024-11-13 44/week @ 2024-11-20 124/week @ 2024-11-27 38/week @ 2024-12-04 19/week @ 2024-12-11 4/week @ 2024-12-18 112/week @ 2025-01-01

140 downloads per month

MIT/Apache

32KB
618 lines

UFOTOFU QUEUES

A trait and implementations of non-blocking, infallible queues that support bulk enqueueing and bulk dequeueing via APIs inspired by ufotofu.

Queue Implementations

So far, there is only a single implementation: Fixed, which is a heap-allocated ring-buffer of unchanging capacity.

Future plans include a queue of static (known at compile-time) capacity that can be used in allocator-less environments, and an elastic queue that grows and shrinks its capacity within certain parameters, to free up memory under low load.

License

Licensed under either of Apache License, Version 2.0 or MIT license at your option. Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

No runtime deps

Features