# `auto_impl` [![CI](https://github.com/auto-impl-rs/auto_impl/actions/workflows/ci.yml/badge.svg)](https://github.com/auto-impl-rs/auto_impl/actions/workflows/ci.yml) [![Crates.io](https://img.shields.io/crates/v/auto_impl.svg)](https://crates.io/crates/auto_impl) [![docs](https://docs.rs/auto_impl/badge.svg)](https://docs.rs/auto_impl) A proc-macro attribute for automatically implementing a trait for references, some common smart pointers and closures. # Usage This library requires Rust 1.56.0 or newer. This library doesn't leave any public API in your code. Add `auto_impl` to your `Cargo.toml` and just use it in your crate: ```rust // In Rust 2015 you still need `extern crate auto_impl;` at your crate root use auto_impl::auto_impl; ``` Add an `auto_impl` attribute to traits you want to automatically implement for wrapper types. Here is a small example: ```rust // This will generate two additional impl blocks: one for `&T` and one // for `Box` where `T: Foo`. #[auto_impl(&, Box)] trait Foo { fn foo(&self); } impl Foo for i32 { fn foo(&self) {} } fn requires_foo(_: impl Foo) {} requires_foo(0i32); // works: through the impl we defined above requires_foo(&0i32); // works: through the generated impl requires_foo(Box::new(0i32)); // works: through the generated impl ``` For more explanations, please see [**the documentation**](https://docs.rs/auto_impl) and for more examples, see [the examples folder](https://github.com/auto-impl-rs/auto_impl/tree/master/examples). # Alternatives This library implements a fraction of a very broad and complex usecase. It's mostly useful for applications that define traits for components, and want to be able to abstract over the storage for those traits. If it doesn't offer some functionality you need, check out the [`impl-tools`](https://github.com/kas-gui/impl-tools/) project. --- ## License Licensed under either of * Apache License, Version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0) * MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT) at your option. ### Contribution Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.