Const equivalents of many [bytemuck
] functions.
constmuck
uses [bytemuck
's traits],
any type that implements those traits can be used with the
relevant functions from this crate.
Because the *_alt
functions are const fn
s,
they can't inspect the address of the reference parameter.
This differs from their [bytemuck
] equivalents,
which use the address to determine alignment.
These examples use bytemuck's derives to show how users don't need to
write unsafe
to use this crate,
and use the [konst
] crate to make writing the const functions easier.
This example demonstrates constructing an enum from its representation.
```rust
use constmuck::Contiguous;
use konst::{array, try_opt};
fn main() { const COLORS: Option<[Color; 5]> = Color::fromarray([3, 4, 1, 0, 2]); asserteq!( COLORS, Some([Color::White, Color::Black, Color::Blue, Color::Red, Color::Green]), );
const NONE_COLORS: Option<[Color; 4]> = Color::from_array([1, 2, 3, 5]);
assert_eq!(NONE_COLORS, None);
}
pub enum Color { Red = 0, Blue, Green, White, Black, }
impl Color {
pub const fn fromint(n: u8) -> Optiontry_opt
returns from from_array
on None
,
// because konst::array::map
allows the passed-in expression
// to return from the surrounding named function.
Some(array::map!(input, |n| try
```
This example demonstrates a type that wraps a [T]
, constructed by reference.
```rust
use constmuck::TransparentWrapper;
fn main() {
const SLICE: &[u32] = &[3, 5, 8, 13, 21];
const WRAPPER: &SliceWrapper
const SUM: u64 = WRAPPER.sum();
assert_eq!(SUM, 50);
const FIRST_EVEN: Option<(usize, u32)> = WRAPPER.find_first_even();
assert_eq!(FIRST_EVEN, Some((2, 8)));
}
pub struct SliceWrapper
implconstmuck
allows safely defining this function as a const fn
pub const fn new(reff: &[T]) -> &Self {
constmuck::wrapper::wrap_ref!(reff)
}
}
impl SliceWrapper
```
The "debug_checks"
crate feature (which is disabled by default)
enables additional assertions in constmuck
functions,
these assertions panic in some cases where unsound impls of [bytemuck
] traits
would have caused Undefined Behavior.
These are the features of this crate:
"derive"
(disabled by default):
Enables bytemuck
's "derive"
feature and reexports its derives.
"debug_checks"
(disabled by default):
Enables additional safety checks for detecting some
Undefined Behavior.
"rust_latest_stable"
(disabled by default):
enables all "rust_1_*"
features, there's currently none.
constmuck
is #![no_std]
, it can be used anywhere Rust can be used.
constmuck
requires Rust 1.65.0.
You can use the "rust_latest_stable"
crate feature to get
all items and functionality that requires stable Rust versions after 1.65.0.