| Crates.io | atomic_enum |
| lib.rs | atomic_enum |
| version | 0.3.0 |
| created_at | 2018-12-06 22:18:02.563972+00 |
| updated_at | 2024-02-21 16:56:02.874321+00 |
| description | An attribute to create an atomic wrapper around a C-style enum |
| homepage | |
| repository | https://github.com/brain0/atomic_enum |
| max_upload_size | |
| id | 100463 |
| size | 21,268 |
An attribute to create an atomic wrapper around a C-style enum.
Internally, the generated wrapper uses an AtomicUsize to store the value.
The atomic operations have the same semantics as the equivalent operations
of AtomicUsize.
# use atomic_enum::atomic_enum;
# use std::sync::atomic::Ordering;
#[atomic_enum]
#[derive(PartialEq)]
enum CatState {
Dead = 0,
BothDeadAndAlive,
Alive,
}
let state = AtomicCatState::new(CatState::Dead);
state.store(CatState::Alive, Ordering::Relaxed);
assert_eq!(state.load(Ordering::Relaxed), CatState::Alive);
This attribute does not use or generate any unsafe code.
The crate can be used in a #[no_std] environment.
This crate is passively maintained.