diff options
| author | HampusM <hampus@hampusmat.com> | 2022-10-01 21:03:17 +0200 | 
|---|---|---|
| committer | HampusM <hampus@hampusmat.com> | 2022-10-01 21:06:16 +0200 | 
| commit | 344dff10f8ac2e176239e10190bdb627bf58156b (patch) | |
| tree | 8a84cd60356b05358e597e90255af2df60395daa /src | |
| parent | f48f647393e1784ab06e219a2ef51a9d6edf3827 (diff) | |
docs: add async binding builder examples
Diffstat (limited to 'src')
| -rw-r--r-- | src/async_di_container.rs | 197 | 
1 files changed, 197 insertions, 0 deletions
| diff --git a/src/async_di_container.rs b/src/async_di_container.rs index 0a092d6..f8ce92d 100644 --- a/src/async_di_container.rs +++ b/src/async_di_container.rs @@ -227,6 +227,37 @@ where      /// # Errors      /// Will return Err if the associated [`AsyncDIContainer`] already have a binding for      /// the interface. +    /// +    /// # Examples +    /// ``` +    /// # use std::error::Error; +    /// # +    /// # use syrette::{AsyncDIContainer, injectable}; +    /// # +    /// # trait Foo: Send + Sync {} +    /// # +    /// # struct Bar {} +    /// # +    /// # #[injectable(Foo, async = true)] +    /// # impl Bar { +    /// #   fn new() -> Self +    /// #   { +    /// #       Self {} +    /// #   } +    /// # } +    /// # +    /// # impl Foo for Bar {} +    /// # +    /// # #[tokio::main] +    /// # async fn main() -> Result<(), Box<dyn Error>> +    /// # { +    /// # let mut di_container = AsyncDIContainer::new(); +    /// # +    /// di_container.bind::<dyn Foo>().to::<Bar>().await?; +    /// # +    /// # Ok(()) +    /// # } +    /// ```      pub async fn to<Implementation>(          &self,      ) -> Result< @@ -263,6 +294,46 @@ where      /// # Errors      /// Will return Err if the associated [`AsyncDIContainer`] already have a binding for      /// the interface. +    /// +    /// # Examples +    /// ``` +    /// # use std::error::Error; +    /// # +    /// # use syrette::{AsyncDIContainer, factory}; +    /// # use syrette::ptr::TransientPtr; +    /// # +    /// # trait Foo: Send + Sync {} +    /// # +    /// # struct Bar +    /// # { +    /// #   num: i32, +    /// #   some_str: String +    /// # } +    /// # +    /// # impl Foo for Bar {} +    /// # +    /// # #[factory(threadsafe = true)] +    /// # type FooFactory = dyn Fn(i32, String) -> dyn Foo; +    /// # +    /// # #[tokio::main] +    /// # async fn main() -> Result<(), Box<dyn Error>> +    /// # { +    /// # let mut di_container = AsyncDIContainer::new(); +    /// # +    /// di_container +    ///     .bind::<FooFactory>() +    ///     .to_factory(&|_| { +    ///         Box::new(|num, some_str| { +    ///             let bar = TransientPtr::new(Bar { num, some_str }); +    /// +    ///             bar as TransientPtr<dyn Foo> +    ///         }) +    ///     }) +    ///     .await?; +    /// # +    /// # Ok(()) +    /// # } +    /// ```      #[cfg(feature = "factory")]      pub async fn to_factory<Args, Return, FactoryFunc>(          &self, @@ -307,6 +378,49 @@ where      /// # Errors      /// Will return Err if the associated [`AsyncDIContainer`] already have a binding for      /// the interface. +    /// +    /// # Examples +    /// ``` +    /// # use std::error::Error; +    /// # use std::time::Duration; +    /// # +    /// # use syrette::{AsyncDIContainer, factory, async_closure}; +    /// # use syrette::ptr::TransientPtr; +    /// # +    /// # trait Foo: Send + Sync {} +    /// # +    /// # struct Bar +    /// # { +    /// #   num: i32, +    /// #   some_str: String +    /// # } +    /// # +    /// # impl Foo for Bar {} +    /// # +    /// # #[factory(async = true)] +    /// # type FooFactory = dyn Fn(i32, String) -> dyn Foo; +    /// # +    /// # #[tokio::main] +    /// # async fn main() -> Result<(), Box<dyn Error>> +    /// # { +    /// # let mut di_container = AsyncDIContainer::new(); +    /// # +    /// di_container +    ///     .bind::<FooFactory>() +    ///     .to_async_factory(&|_| { +    ///         async_closure!(|num, some_str| { +    ///             let bar = TransientPtr::new(Bar { num, some_str }); +    /// +    ///             tokio::time::sleep(Duration::from_secs(2)).await; +    /// +    ///             bar as TransientPtr<dyn Foo> +    ///         }) +    ///     }) +    ///     .await?; +    /// # +    /// # Ok(()) +    /// # } +    /// ```      #[cfg(all(feature = "factory", feature = "async"))]      pub async fn to_async_factory<Args, Return, FactoryFunc>(          &self, @@ -355,6 +469,46 @@ where      /// # Errors      /// Will return Err if the associated [`AsyncDIContainer`] already have a binding for      /// the interface. +    /// +    /// # Examples +    /// ``` +    /// # use std::error::Error; +    /// # +    /// # use syrette::AsyncDIContainer; +    /// # use syrette::ptr::TransientPtr; +    /// # +    /// # trait Foo: Send + Sync {} +    /// # +    /// # struct Bar +    /// # { +    /// #   num: i32, +    /// #   some_str: String +    /// # } +    /// # +    /// # impl Foo for Bar {} +    /// # +    /// # #[tokio::main] +    /// # async fn main() -> Result<(), Box<dyn Error>> +    /// # { +    /// # let mut di_container = AsyncDIContainer::new(); +    /// # +    /// di_container +    ///     .bind::<dyn Foo>() +    ///     .to_default_factory(&|_| { +    ///         Box::new(|| { +    ///             let bar = TransientPtr::new(Bar { +    ///                 num: 42, +    ///                 some_str: "hello".to_string(), +    ///             }); +    /// +    ///             bar as TransientPtr<dyn Foo> +    ///         }) +    ///     }) +    ///     .await?; +    /// # +    /// # Ok(()) +    /// # } +    /// ```      #[cfg(feature = "factory")]      pub async fn to_default_factory<Return, FactoryFunc>(          &self, @@ -400,6 +554,49 @@ where      /// # Errors      /// Will return Err if the associated [`AsyncDIContainer`] already have a binding for      /// the interface. +    /// +    /// # Examples +    /// ``` +    /// # use std::error::Error; +    /// # use std::time::Duration; +    /// # +    /// # use syrette::{AsyncDIContainer, async_closure}; +    /// # use syrette::ptr::TransientPtr; +    /// # +    /// # trait Foo: Send + Sync {} +    /// # +    /// # struct Bar +    /// # { +    /// #   num: i32, +    /// #   some_str: String +    /// # } +    /// # +    /// # impl Foo for Bar {} +    /// # +    /// # #[tokio::main] +    /// # async fn main() -> Result<(), Box<dyn Error>> +    /// # { +    /// # let mut di_container = AsyncDIContainer::new(); +    /// # +    /// di_container +    ///     .bind::<dyn Foo>() +    ///     .to_async_default_factory(&|_| { +    ///         async_closure!(|| { +    ///             let bar = TransientPtr::new(Bar { +    ///                 num: 42, +    ///                 some_str: "hello".to_string(), +    ///             }); +    /// +    ///             tokio::time::sleep(Duration::from_secs(1)).await; +    /// +    ///             bar as TransientPtr<dyn Foo> +    ///         }) +    ///     }) +    ///     .await?; +    /// # +    /// # Ok(()) +    /// # } +    /// ```      #[cfg(all(feature = "factory", feature = "async"))]      pub async fn to_async_default_factory<Return, FactoryFunc>(          &self, | 
