type-equalities

Crates.iotype-equalities
lib.rstype-equalities
version0.3.1
sourcesrc
created_at2021-05-06 03:24:08.048948
updated_at2022-01-04 17:15:50.330083
descriptionObserving type equality with zero-sized proofs
homepagehttps://github.com/WorldSEnder/type-equalities-rs
repositoryhttps://github.com/WorldSEnder/type-equalities-rs
max_upload_size
id393668
size33,654
(WorldSEnder)

documentation

README

type-equalities

Documentation Further crate info

The central type, TypeEq<_, _>, allows for zero-overhead, safe value coercions and is itself zero-sized. Further, naming TypeEq<T, U> is well-formed for any types, but an inhabitant is available only if the equality holds. For trait-level type equality, T: IsEqual<U> can be used.

The zero overhead claim can be seen in the provided benchmarks:

let eq = refl::<u32>().lift_through::<SliceF<BENCH_LEN>>();
b.iter(|| [0; BENCH_LEN]);            // bench_no_coerce
b.iter(|| eq.coerce([0; BENCH_LEN])); // bench_coerce_array_refl

> running 2 tests
test benches::bench_no_coerce         ... bench:      10,570 ns/iter (+/- 569)
test benches::bench_coerce_array_refl ... bench:      10,557 ns/iter (+/- 605)

This crate is no-std and has a (default: enabled) feature for alloc features, i.e. coercing Box.

License

Licensed under either of

Contribution

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you shall be dual licensed as above, without any additional terms or conditions.

Commit count: 29

cargo fmt