3 releases (stable)

new 1.0.1 Jul 4, 2025
1.0.0 Aug 10, 2024
0.999.0 Jul 22, 2024

#187 in Embedded development

Download history 273/week @ 2025-03-14 281/week @ 2025-03-21 222/week @ 2025-03-28 378/week @ 2025-04-04 758/week @ 2025-04-11 1828/week @ 2025-04-18 1257/week @ 2025-04-25 829/week @ 2025-05-02 758/week @ 2025-05-09 1024/week @ 2025-05-16 612/week @ 2025-05-23 893/week @ 2025-05-30 756/week @ 2025-06-06 1197/week @ 2025-06-13 972/week @ 2025-06-20 1466/week @ 2025-06-27

4,605 downloads per month
Used in 8 crates (3 directly)

MIT/Apache

12KB
51 lines

mutex

When a mutex and a closure love each other very much.

Crates.io Version Crates.io License docs.rs GitHub Release CI

Traits abstracting over mutex implementations.

Compared to the more general traits provided by the lock_api crate, these traits are aimed at being more compatible with implementations based on critical sections, are easier to work with in a nested or strictly LIFO pattern.

Versioning, and which crate to use?

The mutex-traits crate should be used by library crates that want to be generic over different ways of exclusive access.

The mutex crate should be used by applications that need to select which implementation is appropriate for their use case. The mutex crate also re-exports the mutex-traits crate for convenience, so applications only need to pull in one direct dependency.

While both crates are >= 1.0, it should be expected that it is MUCH more likely that mutex crate will make breaking changes someday. The hope is that mutex-traits NEVER releases a 2.0 version, which means that even if there are 1.x, 2.x, 3.x, etc. versions of the mutex crate, they all can be used interchangably since they implement the 1.x mutex-traits interfaces.

If you are a library crate, consider ONLY relying on the mutex-traits crate directly, and put any use of the mutex crate behind a feature flag or in the dev-dependencies section.

Provenance

Portions of this code are forked from the embassy-sync crate.

The RawMutex trait is adapted from the trait of the same name in the lock_api crate, by Amanieu d'Antras.

License

Licensed under either of

at your option.

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work 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