#traits #expose #proc-macro #hidden #exposing

macro hidden-trait

Proc macro for exposing a trait implementation

3 releases

0.1.2 Dec 11, 2022
0.1.1 Dec 11, 2022
0.1.0 Dec 10, 2022

#11 in #exposing

Download history 7/week @ 2023-12-18 3/week @ 2023-12-25 19/week @ 2024-01-08 25/week @ 2024-01-29 266/week @ 2024-02-05 469/week @ 2024-02-12 1945/week @ 2024-02-19 1764/week @ 2024-02-26 1248/week @ 2024-03-04 1157/week @ 2024-03-11 1195/week @ 2024-03-18 1073/week @ 2024-03-25 1043/week @ 2024-04-01

4,608 downloads per month
Used in 5 crates (via blade-graphics)

MIT license

5KB
66 lines

hidden-trait

Build Status Docs Crates.io

This library is a proc macro to expose a trait implementation.

The case we are trying to solve here: a library exposes some concrete structure for people to use. There can be multiple of them (e.g. Vector2, Vector3, Vector4 in a math library), or maybe it's one per platform (Vulkan vs Metal). Important part is - internally the library would like to have a trait implemented by this public type, but it doesn't want to expose the trait itself because of ergonomic reasons. Hence, "hidden-trait" to rescue.

mod hidden {
    trait Foo {
        fn foo(&self) -> u32;
    }

    pub struct Bar;

    #[hidden_trait::expose]
    impl Foo for Bar {
        fn foo(&self) -> u32 {
            42
        }
    }
}

fn main() {
    let bar = hidden::Bar;
    // calling the trait method as if it's ours
    bar.foo();
}

Dependencies

~1.5MB
~33K SLoC