aboutsummaryrefslogtreecommitdiff
path: root/examples/basic/main.rs
diff options
context:
space:
mode:
authorHampusM <hampus@hampusmat.com>2022-08-22 19:13:19 +0200
committerHampusM <hampus@hampusmat.com>2022-08-22 19:13:19 +0200
commit8e862c7998d0b59c71d20cbcbbc57031f734b6fa (patch)
treefbcddcfa697d0b67c9d20022004aa2ae16c5a339 /examples/basic/main.rs
parentda3f56d48f9c349b29e1d462b2a535b1a89c5e45 (diff)
refactor!: move specifying binding scope to a binding scope configurator
BREAKING CHANGE: Specifying the scope of a DI container binding is now done with a binding scope configurator
Diffstat (limited to 'examples/basic/main.rs')
-rw-r--r--examples/basic/main.rs12
1 files changed, 8 insertions, 4 deletions
diff --git a/examples/basic/main.rs b/examples/basic/main.rs
index 3a937c3..72f07c2 100644
--- a/examples/basic/main.rs
+++ b/examples/basic/main.rs
@@ -2,6 +2,8 @@
#![deny(clippy::pedantic)]
#![allow(clippy::module_name_repetitions)]
+use std::error::Error;
+
mod animals;
mod bootstrap;
mod interfaces;
@@ -10,17 +12,19 @@ use bootstrap::bootstrap;
use interfaces::dog::IDog;
use interfaces::human::IHuman;
-fn main()
+fn main() -> Result<(), Box<dyn Error>>
{
println!("Hello, world!");
- let di_container = bootstrap();
+ let di_container = bootstrap()?;
- let dog = di_container.get_singleton::<dyn IDog>().unwrap();
+ let dog = di_container.get_singleton::<dyn IDog>()?;
dog.woof();
- let human = di_container.get::<dyn IHuman>().unwrap();
+ let human = di_container.get::<dyn IHuman>()?;
human.make_pets_make_sounds();
+
+ Ok(())
}