From 1c46b68581213ca8ae6200daa32f626b5389b4b0 Mon Sep 17 00:00:00 2001 From: HampusM Date: Thu, 25 Aug 2022 20:21:49 +0200 Subject: refactor!: make DI container have single get function BREAKING CHANGE: The DI container get_singleton & get_factory functions have been replaced by the get function now returning a enum --- examples/basic/main.rs | 4 ++-- examples/factory/bootstrap.rs | 18 +++++++++--------- examples/factory/main.rs | 10 +++++++--- examples/generics/main.rs | 10 +++++++--- examples/unbound/main.rs | 4 ++-- examples/with-3rd-party/main.rs | 2 +- 6 files changed, 28 insertions(+), 20 deletions(-) (limited to 'examples') diff --git a/examples/basic/main.rs b/examples/basic/main.rs index 72f07c2..dbc9215 100644 --- a/examples/basic/main.rs +++ b/examples/basic/main.rs @@ -18,11 +18,11 @@ fn main() -> Result<(), Box> let di_container = bootstrap()?; - let dog = di_container.get_singleton::()?; + let dog = di_container.get::()?.singleton()?; dog.woof(); - let human = di_container.get::()?; + let human = di_container.get::()?.transient()?; human.make_pets_make_sounds(); diff --git a/examples/factory/bootstrap.rs b/examples/factory/bootstrap.rs index b752764..ad8c4d3 100644 --- a/examples/factory/bootstrap.rs +++ b/examples/factory/bootstrap.rs @@ -1,3 +1,5 @@ +use std::error::Error; + use syrette::ptr::TransientPtr; use syrette::DIContainer; @@ -9,24 +11,22 @@ use crate::interfaces::user_manager::IUserManager; use crate::user::User; use crate::user_manager::UserManager; -pub fn bootstrap() -> DIContainer +pub fn bootstrap() -> Result> { let mut di_container: DIContainer = DIContainer::new(); di_container .bind::() - .to::() - .unwrap(); + .to::()?; - di_container - .bind::() - .to_factory(&|name, date_of_birth, password| { + di_container.bind::().to_factory( + &|name, date_of_birth, password| { let user: TransientPtr = TransientPtr::new(User::new(name, date_of_birth, password)); user - }) - .unwrap(); + }, + )?; - di_container + Ok(di_container) } diff --git a/examples/factory/main.rs b/examples/factory/main.rs index bf3d43b..0f1a97b 100644 --- a/examples/factory/main.rs +++ b/examples/factory/main.rs @@ -7,21 +7,25 @@ mod interfaces; mod user; mod user_manager; +use std::error::Error; + use bootstrap::bootstrap; use crate::interfaces::user_manager::IUserManager; -fn main() +fn main() -> Result<(), Box> { println!("Hello, world!"); - let di_container = bootstrap(); + let di_container = bootstrap()?; - let mut user_manager = di_container.get::().unwrap(); + let mut user_manager = di_container.get::()?.transient()?; user_manager.fill_with_users(); println!("Printing user information"); user_manager.print_users(); + + Ok(()) } diff --git a/examples/generics/main.rs b/examples/generics/main.rs index 9442641..f491aa0 100644 --- a/examples/generics/main.rs +++ b/examples/generics/main.rs @@ -2,18 +2,22 @@ mod bootstrap; mod interfaces; mod printer; +use std::error::Error; + use bootstrap::bootstrap; use interfaces::printer::IPrinter; -fn main() +fn main() -> Result<(), Box> { let di_container = bootstrap(); - let string_printer = di_container.get::>().unwrap(); + let string_printer = di_container.get::>()?.transient()?; string_printer.print("Hello there".to_string()); - let int_printer = di_container.get::>().unwrap(); + let int_printer = di_container.get::>()?.transient()?; int_printer.print(2782028); + + Ok(()) } diff --git a/examples/unbound/main.rs b/examples/unbound/main.rs index 031a691..e9a8feb 100644 --- a/examples/unbound/main.rs +++ b/examples/unbound/main.rs @@ -19,11 +19,11 @@ fn main() -> Result<(), Box> let di_container = bootstrap()?; - let dog = di_container.get_singleton::()?; + let dog = di_container.get::()?.singleton()?; dog.woof(); - let human = di_container.get::()?; + let human = di_container.get::()?.transient()?; human.make_pets_make_sounds(); diff --git a/examples/with-3rd-party/main.rs b/examples/with-3rd-party/main.rs index dd4c21f..e48c78f 100644 --- a/examples/with-3rd-party/main.rs +++ b/examples/with-3rd-party/main.rs @@ -17,7 +17,7 @@ fn main() -> Result<(), Box> let di_container = bootstrap()?; - let ninja = di_container.get::()?; + let ninja = di_container.get::()?.transient()?; ninja.throw_shuriken(); -- cgit v1.2.3-18-g5258