[![crates.io](https://img.shields.io/crates/v/alignconstr.svg)][align_constr] [![crates.io](https://img.shields.io/crates/d/alignconstr.svg)][align_constr]

Alignment-constrained [newtype]

Newtype whose [alignment] is constrained not only by the inherent alignment requirements of the underlying type but also by the alignment requirements of the "alignment constraint archetype". Within this context, "alignment constraint archetype" AlignConstrArchetype is a type whose alignment constraint is imposed on the underlying type T to produce [AlignConstr<T, AlignConstrArchetype>][AlignConstr].

Notes

Resources on alignment

Example

```rust use alignconstr::{AlignConstr, nzst::ZST128};

let overalignedu8 = AlignConstr::::new(3); assert!(overalignedu8.value == 3); // requires non-const context assert!(&overaligned_u8 as *const _ as usize % 128 == 0); ```

[align_constr] vs [aligned]

[aligned] is a popular library that served as a prototype for [align_constr]. At the time of writing, [align_constr] is featurewise and idiomatically superior and provides not only more extensive documentation but also a selection of resources on the subject. To pay respect to the contributors of [aligned] crate, the quality of their creation's [CI] is still unmatched by [align_constr]. However, the limited [scope] of both libraries nonetheless makes [align_constr] arguably better for any use case.

Note: Unlike in [aligned], the dependency on as_slice is optional.

About [align_constr]

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.