async_injector_derive/lib.rs
1//! [<img alt="github" src="https://img.shields.io/badge/github-udoprog/async--injector-8da0cb?style=for-the-badge&logo=github" height="20">](https://github.com/udoprog/async-injector)
2//! [<img alt="crates.io" src="https://img.shields.io/crates/v/async-injector-derive.svg?style=for-the-badge&color=fc8d62&logo=rust" height="20">](https://crates.io/crates/async-injector-derive)
3//! [<img alt="docs.rs" src="https://img.shields.io/badge/docs.rs-async--injector--derive-66c2a5?style=for-the-badge&logoColor=white&logo=" height="20">](https://docs.rs/async-injector-derive)
4//!
5//! Macros for [async-injector](https://docs.rs/async-injector).
6//!
7//! This provides the [Provider] derive, which can be used to automatically
8//! construct and inject dependencies. See its documentation for how to use.
9//!
10//! [Provider]: https://docs.rs/async-injector/latest/async_injector/derive.Provider.html
11
12mod implement;
13
14#[proc_macro_derive(Provider, attributes(dependency))]
15pub fn provider_derive(input: proc_macro::TokenStream) -> proc_macro::TokenStream {
16 let ast = syn::parse_macro_input!(input as syn::DeriveInput);
17
18 let cx = implement::Ctxt::default();
19
20 if let Ok(tokens) = implement::implement(&cx, &ast) {
21 return tokens.into();
22 }
23
24 cx.into_errors().into()
25}