diff options
Diffstat (limited to 'src/di_container/blocking')
| -rw-r--r-- | src/di_container/blocking/binding/builder.rs | 78 | ||||
| -rw-r--r-- | src/di_container/blocking/binding/scope_configurator.rs | 79 | ||||
| -rw-r--r-- | src/di_container/blocking/binding/when_configurator.rs | 17 | ||||
| -rw-r--r-- | src/di_container/blocking/mod.rs | 43 | 
4 files changed, 81 insertions, 136 deletions
diff --git a/src/di_container/blocking/binding/builder.rs b/src/di_container/blocking/binding/builder.rs index 27151d7..991961c 100644 --- a/src/di_container/blocking/binding/builder.rs +++ b/src/di_container/blocking/binding/builder.rs @@ -5,40 +5,39 @@ use std::any::type_name;  use std::marker::PhantomData;  use std::rc::Rc; -use crate::dependency_history::IDependencyHistory;  use crate::di_container::blocking::binding::scope_configurator::BindingScopeConfigurator;  #[cfg(feature = "factory")]  use crate::di_container::blocking::binding::when_configurator::BindingWhenConfigurator;  use crate::di_container::blocking::IDIContainer;  use crate::errors::di_container::BindingBuilderError;  use crate::interfaces::injectable::Injectable; +use crate::util::use_dependency_history; + +use_dependency_history!();  /// Binding builder for type `Interface` inside a [`IDIContainer`].  ///  /// [`IDIContainer`]: crate::di_container::blocking::IDIContainer  #[must_use = "No binding will be created if you don't use the binding builder"] -pub struct BindingBuilder<Interface, DIContainerType, DependencyHistoryType> +pub struct BindingBuilder<Interface, DIContainerType>  where      Interface: 'static + ?Sized, -    DIContainerType: IDIContainer<DependencyHistoryType>, -    DependencyHistoryType: IDependencyHistory, +    DIContainerType: IDIContainer,  {      di_container: Rc<DIContainerType>, -    dependency_history_factory: fn() -> DependencyHistoryType, +    dependency_history_factory: fn() -> DependencyHistory,      interface_phantom: PhantomData<Interface>,  } -impl<Interface, DIContainerType, DependencyHistoryType> -    BindingBuilder<Interface, DIContainerType, DependencyHistoryType> +impl<Interface, DIContainerType> BindingBuilder<Interface, DIContainerType>  where      Interface: 'static + ?Sized, -    DIContainerType: IDIContainer<DependencyHistoryType>, -    DependencyHistoryType: IDependencyHistory + 'static, +    DIContainerType: IDIContainer,  {      pub(crate) fn new(          di_container: Rc<DIContainerType>, -        dependency_history_factory: fn() -> DependencyHistoryType, +        dependency_history_factory: fn() -> DependencyHistory,      ) -> Self      {          Self { @@ -93,16 +92,11 @@ where      pub fn to<Implementation>(          self,      ) -> Result< -        BindingScopeConfigurator< -            Interface, -            Implementation, -            DIContainerType, -            DependencyHistoryType, -        >, +        BindingScopeConfigurator<Interface, Implementation, DIContainerType>,          BindingBuilderError,      >      where -        Implementation: Injectable<DIContainerType, DependencyHistoryType>, +        Implementation: Injectable<DIContainerType>,      {          {              if self.di_container.has_binding::<Interface>(None) { @@ -194,10 +188,7 @@ where      pub fn to_factory<Args, Return, Func>(          self,          factory_func: &'static Func, -    ) -> Result< -        BindingWhenConfigurator<Interface, DIContainerType, DependencyHistoryType>, -        BindingBuilderError, -    > +    ) -> Result<BindingWhenConfigurator<Interface, DIContainerType>, BindingBuilderError>      where          Args: std::marker::Tuple + 'static,          Return: 'static + ?Sized, @@ -283,10 +274,7 @@ where      pub fn to_default_factory<Return, FactoryFunc>(          self,          factory_func: &'static FactoryFunc, -    ) -> Result< -        BindingWhenConfigurator<Interface, DIContainerType, DependencyHistoryType>, -        BindingBuilderError, -    > +    ) -> Result<BindingWhenConfigurator<Interface, DIContainerType>, BindingBuilderError>      where          Return: 'static + ?Sized,          FactoryFunc: Fn< @@ -326,6 +314,7 @@ mod tests      use mockall::predicate::eq;      use super::*; +    use crate::dependency_history::MockDependencyHistory;      use crate::test_utils::{mocks, subjects};      #[test] @@ -345,14 +334,11 @@ mod tests              .return_once(|_name, _provider| ())              .once(); -        let binding_builder = BindingBuilder::< -            dyn subjects::INumber, -            mocks::blocking_di_container::MockDIContainer<mocks::MockDependencyHistory>, -            mocks::MockDependencyHistory, -        >::new( -            Rc::new(mock_di_container), -            mocks::MockDependencyHistory::new, -        ); +        let binding_builder = +            BindingBuilder::< +                dyn subjects::INumber, +                mocks::blocking_di_container::MockDIContainer, +            >::new(Rc::new(mock_di_container), MockDependencyHistory::new);          binding_builder.to::<subjects::Number>()?; @@ -384,14 +370,11 @@ mod tests              .return_once(|_name, _provider| ())              .once(); -        let binding_builder = BindingBuilder::< -            IUserManagerFactory, -            mocks::blocking_di_container::MockDIContainer<mocks::MockDependencyHistory>, -            mocks::MockDependencyHistory, -        >::new( -            Rc::new(mock_di_container), -            mocks::MockDependencyHistory::new, -        ); +        let binding_builder = +            BindingBuilder::< +                IUserManagerFactory, +                mocks::blocking_di_container::MockDIContainer, +            >::new(Rc::new(mock_di_container), MockDependencyHistory::new);          binding_builder.to_factory(&|_| {              Box::new(move |_num, _text| { @@ -430,14 +413,11 @@ mod tests              .return_once(|_name, _provider| ())              .once(); -        let binding_builder = BindingBuilder::< -            dyn subjects::IUserManager, -            mocks::blocking_di_container::MockDIContainer<mocks::MockDependencyHistory>, -            mocks::MockDependencyHistory, -        >::new( -            Rc::new(mock_di_container), -            mocks::MockDependencyHistory::new, -        ); +        let binding_builder = +            BindingBuilder::< +                dyn subjects::IUserManager, +                mocks::blocking_di_container::MockDIContainer, +            >::new(Rc::new(mock_di_container), MockDependencyHistory::new);          binding_builder.to_default_factory(&|_| {              Box::new(move || { diff --git a/src/di_container/blocking/binding/scope_configurator.rs b/src/di_container/blocking/binding/scope_configurator.rs index f318dd6..0e2437f 100644 --- a/src/di_container/blocking/binding/scope_configurator.rs +++ b/src/di_container/blocking/binding/scope_configurator.rs @@ -4,51 +4,42 @@  use std::marker::PhantomData;  use std::rc::Rc; -use crate::dependency_history::IDependencyHistory;  use crate::di_container::blocking::binding::when_configurator::BindingWhenConfigurator;  use crate::di_container::blocking::IDIContainer;  use crate::errors::di_container::BindingScopeConfiguratorError;  use crate::interfaces::injectable::Injectable;  use crate::provider::blocking::{SingletonProvider, TransientTypeProvider};  use crate::ptr::SingletonPtr; +use crate::util::use_dependency_history; + +use_dependency_history!();  /// Scope configurator for a binding for type `Interface` inside a [`IDIContainer`].  ///  /// [`IDIContainer`]: crate::di_container::blocking::IDIContainer -pub struct BindingScopeConfigurator< -    Interface, -    Implementation, -    DIContainerType, -    DependencyHistoryType, -> where +pub struct BindingScopeConfigurator<Interface, Implementation, DIContainerType> +where      Interface: 'static + ?Sized, -    Implementation: Injectable<DIContainerType, DependencyHistoryType>, -    DIContainerType: IDIContainer<DependencyHistoryType>, -    DependencyHistoryType: IDependencyHistory, +    Implementation: Injectable<DIContainerType>, +    DIContainerType: IDIContainer,  {      di_container: Rc<DIContainerType>, -    dependency_history_factory: fn() -> DependencyHistoryType, +    dependency_history_factory: fn() -> DependencyHistory,      interface_phantom: PhantomData<Interface>,      implementation_phantom: PhantomData<Implementation>,  } -impl<Interface, Implementation, DIContainerType, DependencyHistoryType> -    BindingScopeConfigurator< -        Interface, -        Implementation, -        DIContainerType, -        DependencyHistoryType, -    > +impl<Interface, Implementation, DIContainerType> +    BindingScopeConfigurator<Interface, Implementation, DIContainerType>  where      Interface: 'static + ?Sized, -    Implementation: Injectable<DIContainerType, DependencyHistoryType>, -    DIContainerType: IDIContainer<DependencyHistoryType>, -    DependencyHistoryType: IDependencyHistory + 'static, +    Implementation: Injectable<DIContainerType>, +    DIContainerType: IDIContainer,  {      pub(crate) fn new(          di_container: Rc<DIContainerType>, -        dependency_history_factory: fn() -> DependencyHistoryType, +        dependency_history_factory: fn() -> DependencyHistory,      ) -> Self      {          Self { @@ -63,9 +54,8 @@ where      ///      /// This is the default.      #[allow(clippy::must_use_candidate)] -    pub fn in_transient_scope( -        self, -    ) -> BindingWhenConfigurator<Interface, DIContainerType, DependencyHistoryType> +    pub fn in_transient_scope(self) +        -> BindingWhenConfigurator<Interface, DIContainerType>      {          self.set_in_transient_scope(); @@ -79,7 +69,7 @@ where      pub fn in_singleton_scope(          self,      ) -> Result< -        BindingWhenConfigurator<Interface, DIContainerType, DependencyHistoryType>, +        BindingWhenConfigurator<Interface, DIContainerType>,          BindingScopeConfiguratorError,      >      { @@ -101,11 +91,7 @@ where      {          self.di_container.set_binding::<Interface>(              None, -            Box::new(TransientTypeProvider::< -                Implementation, -                DIContainerType, -                DependencyHistoryType, -            >::new()), +            Box::new(TransientTypeProvider::<Implementation, DIContainerType>::new()),          );      }  } @@ -114,6 +100,7 @@ where  mod tests  {      use super::*; +    use crate::dependency_history::MockDependencyHistory;      use crate::test_utils::{mocks, subjects};      #[test] @@ -127,15 +114,12 @@ mod tests              .return_once(|_name, _provider| ())              .once(); -        let binding_scope_configurator = BindingScopeConfigurator::< -            dyn subjects::IUserManager, -            subjects::UserManager, -            mocks::blocking_di_container::MockDIContainer<mocks::MockDependencyHistory>, -            mocks::MockDependencyHistory, -        >::new( -            Rc::new(di_container_mock), -            mocks::MockDependencyHistory::new, -        ); +        let binding_scope_configurator = +            BindingScopeConfigurator::< +                dyn subjects::IUserManager, +                subjects::UserManager, +                mocks::blocking_di_container::MockDIContainer, +            >::new(Rc::new(di_container_mock), MockDependencyHistory::new);          binding_scope_configurator.in_transient_scope();      } @@ -151,15 +135,12 @@ mod tests              .return_once(|_name, _provider| ())              .once(); -        let binding_scope_configurator = BindingScopeConfigurator::< -            dyn subjects::IUserManager, -            subjects::UserManager, -            mocks::blocking_di_container::MockDIContainer<mocks::MockDependencyHistory>, -            mocks::MockDependencyHistory, -        >::new( -            Rc::new(di_container_mock), -            mocks::MockDependencyHistory::new, -        ); +        let binding_scope_configurator = +            BindingScopeConfigurator::< +                dyn subjects::IUserManager, +                subjects::UserManager, +                mocks::blocking_di_container::MockDIContainer, +            >::new(Rc::new(di_container_mock), MockDependencyHistory::new);          assert!(binding_scope_configurator.in_singleton_scope().is_ok());      } diff --git a/src/di_container/blocking/binding/when_configurator.rs b/src/di_container/blocking/binding/when_configurator.rs index 31b1b48..fcef377 100644 --- a/src/di_container/blocking/binding/when_configurator.rs +++ b/src/di_container/blocking/binding/when_configurator.rs @@ -5,38 +5,32 @@ use std::any::type_name;  use std::marker::PhantomData;  use std::rc::Rc; -use crate::dependency_history::IDependencyHistory;  use crate::di_container::blocking::IDIContainer;  use crate::errors::di_container::BindingWhenConfiguratorError;  /// When configurator for a binding for type `Interface` inside a [`IDIContainer`].  ///  /// [`IDIContainer`]: crate::di_container::blocking::IDIContainer -pub struct BindingWhenConfigurator<Interface, DIContainerType, DependencyHistoryType> +pub struct BindingWhenConfigurator<Interface, DIContainerType>  where      Interface: 'static + ?Sized, -    DIContainerType: IDIContainer<DependencyHistoryType>, -    DependencyHistoryType: IDependencyHistory, +    DIContainerType: IDIContainer,  {      di_container: Rc<DIContainerType>,      interface_phantom: PhantomData<Interface>, -    dependency_history_phantom: PhantomData<DependencyHistoryType>,  } -impl<Interface, DIContainerType, DependencyHistoryType> -    BindingWhenConfigurator<Interface, DIContainerType, DependencyHistoryType> +impl<Interface, DIContainerType> BindingWhenConfigurator<Interface, DIContainerType>  where      Interface: 'static + ?Sized, -    DIContainerType: IDIContainer<DependencyHistoryType>, -    DependencyHistoryType: IDependencyHistory, +    DIContainerType: IDIContainer,  {      pub(crate) fn new(di_container: Rc<DIContainerType>) -> Self      {          Self {              di_container,              interface_phantom: PhantomData, -            dependency_history_phantom: PhantomData,          }      } @@ -97,8 +91,7 @@ mod tests          let binding_when_configurator = BindingWhenConfigurator::<              dyn subjects::INumber, -            mocks::blocking_di_container::MockDIContainer<mocks::MockDependencyHistory>, -            mocks::MockDependencyHistory, +            mocks::blocking_di_container::MockDIContainer,          >::new(Rc::new(di_container_mock));          assert!(binding_when_configurator.when_named("cool").is_ok()); diff --git a/src/di_container/blocking/mod.rs b/src/di_container/blocking/mod.rs index cd7065c..5781583 100644 --- a/src/di_container/blocking/mod.rs +++ b/src/di_container/blocking/mod.rs @@ -54,7 +54,6 @@ use std::any::type_name;  use std::cell::RefCell;  use std::rc::Rc; -use crate::dependency_history::{DependencyHistory, IDependencyHistory};  use crate::di_container::binding_storage::DIContainerBindingStorage;  use crate::di_container::blocking::binding::builder::BindingBuilder;  use crate::errors::di_container::DIContainerError; @@ -62,6 +61,9 @@ use crate::private::cast::boxed::CastBox;  use crate::private::cast::rc::CastRc;  use crate::provider::blocking::{IProvider, Providable};  use crate::ptr::SomePtr; +use crate::util::use_dependency_history; + +use_dependency_history!();  pub mod binding;  pub mod prelude; @@ -69,15 +71,10 @@ pub mod prelude;  /// Blocking dependency injection container interface.  ///  /// **This trait is sealed and cannot be implemented for types outside this crate.** -pub trait IDIContainer<DependencyHistoryType>: -    Sized + 'static + details::DIContainerInternals<DependencyHistoryType> -where -    DependencyHistoryType: IDependencyHistory, +pub trait IDIContainer: Sized + 'static + details::DIContainerInternals  {      /// Returns a new [`BindingBuilder`] for the given interface. -    fn bind<Interface>( -        self: &mut Rc<Self>, -    ) -> BindingBuilder<Interface, Self, DependencyHistoryType> +    fn bind<Interface>(self: &mut Rc<Self>) -> BindingBuilder<Interface, Self>      where          Interface: 'static + ?Sized; @@ -109,7 +106,7 @@ where      #[doc(hidden)]      fn get_bound<Interface>(          self: &Rc<Self>, -        dependency_history: DependencyHistoryType, +        dependency_history: DependencyHistory,          name: Option<&'static str>,      ) -> Result<SomePtr<Interface>, DIContainerError>      where @@ -119,8 +116,7 @@ where  /// Blocking dependency injection container.  pub struct DIContainer  { -    binding_storage: -        RefCell<DIContainerBindingStorage<dyn IProvider<Self, DependencyHistory>>>, +    binding_storage: RefCell<DIContainerBindingStorage<dyn IProvider<Self>>>,  }  impl DIContainer @@ -135,11 +131,9 @@ impl DIContainer      }  } -impl IDIContainer<DependencyHistory> for DIContainer +impl IDIContainer for DIContainer  { -    fn bind<Interface>( -        self: &mut Rc<Self>, -    ) -> BindingBuilder<Interface, Self, DependencyHistory> +    fn bind<Interface>(self: &mut Rc<Self>) -> BindingBuilder<Interface, Self>      where          Interface: 'static + ?Sized,      { @@ -183,7 +177,7 @@ impl IDIContainer<DependencyHistory> for DIContainer      }  } -impl details::DIContainerInternals<DependencyHistory> for DIContainer +impl details::DIContainerInternals for DIContainer  {      fn has_binding<Interface>(self: &Rc<Self>, name: Option<&'static str>) -> bool      where @@ -195,7 +189,7 @@ impl details::DIContainerInternals<DependencyHistory> for DIContainer      fn set_binding<Interface>(          self: &Rc<Self>,          name: Option<&'static str>, -        provider: Box<dyn IProvider<Self, DependencyHistory>>, +        provider: Box<dyn IProvider<Self>>,      ) where          Interface: 'static + ?Sized,      { @@ -207,7 +201,7 @@ impl details::DIContainerInternals<DependencyHistory> for DIContainer      fn remove_binding<Interface>(          self: &Rc<Self>,          name: Option<&'static str>, -    ) -> Option<Box<dyn IProvider<Self, DependencyHistory>>> +    ) -> Option<Box<dyn IProvider<Self>>>      where          Interface: 'static + ?Sized,      { @@ -219,7 +213,7 @@ impl DIContainer  {      fn handle_binding_providable<Interface>(          #[cfg(feature = "factory")] self: &Rc<Self>, -        binding_providable: Providable<Self, DependencyHistory>, +        binding_providable: Providable<Self>,      ) -> Result<SomePtr<Interface>, DIContainerError>      where          Interface: 'static + ?Sized, @@ -278,7 +272,7 @@ impl DIContainer          self: &Rc<Self>,          name: Option<&'static str>,          dependency_history: DependencyHistory, -    ) -> Result<Providable<Self, DependencyHistory>, DIContainerError> +    ) -> Result<Providable<Self>, DIContainerError>      where          Interface: 'static + ?Sized,      { @@ -306,12 +300,9 @@ pub(crate) mod details  {      use std::rc::Rc; -    use crate::dependency_history::IDependencyHistory;      use crate::provider::blocking::IProvider; -    pub trait DIContainerInternals<DependencyHistoryType> -    where -        DependencyHistoryType: IDependencyHistory, +    pub trait DIContainerInternals      {          fn has_binding<Interface>(self: &Rc<Self>, name: Option<&'static str>) -> bool          where @@ -320,14 +311,14 @@ pub(crate) mod details          fn set_binding<Interface>(              self: &Rc<Self>,              name: Option<&'static str>, -            provider: Box<dyn IProvider<Self, DependencyHistoryType>>, +            provider: Box<dyn IProvider<Self>>,          ) where              Interface: 'static + ?Sized;          fn remove_binding<Interface>(              self: &Rc<Self>,              name: Option<&'static str>, -        ) -> Option<Box<dyn IProvider<Self, DependencyHistoryType>>> +        ) -> Option<Box<dyn IProvider<Self>>>          where              Interface: 'static + ?Sized;      }  | 
