1 unstable release

0.1.0 Feb 1, 2020

#1985 in Rust patterns

Download history 3/week @ 2024-07-27 4/week @ 2024-09-21 7/week @ 2024-09-28 21/week @ 2024-10-05 18/week @ 2024-10-12 18/week @ 2024-10-19 61/week @ 2024-10-26 127/week @ 2024-11-02 605/week @ 2024-11-09

812 downloads per month

Unlicense

5KB

type-equals

crates.io crates.io docs.rs GitHub

A trait for checking type equality.

This crate implements the TypeEquals trick described in rust-lang/rust#20041.

The following compiles:

use type_equals::TypeEquals;

pub trait Owner {
    type Child1: Child;
    type Child2: Child;
}

pub trait Child {
    type Owner: Owner;
}

pub struct A;
impl Owner for A {
    type Child1 = B;
    type Child2 = C;
}

pub struct B;
impl Child for B {
    type Owner = A;
}

pub struct C;
impl Child for C {
    type Owner = A;
}

pub fn want_child_one<T: Child>()
where
    <T::Owner as Owner>::Child1: TypeEquals<Other = T>,
{}

pub fn want_child_two<T: Child>()
where
    <T::Owner as Owner>::Child2: TypeEquals<Other = T>,
{}

pub fn this_works() {
    want_child_one::<B>();
    want_child_two::<C>();
}

Meanwhile, the following does not compile:

// A, B, C, want_child_one and want_child_two are declared identically.

pub fn this_does_not_work() {
    want_child_one::<C>();
    want_child_two::<B>();
}

No runtime deps