From ad70cb3231b805d743383bf54f98669e2cd4c1bc Mon Sep 17 00:00:00 2001 From: A F <49113047+arty-F@users.noreply.github.com> Date: Thu, 23 May 2024 22:00:06 +0700 Subject: [PATCH 1/4] Update README.md --- README.md | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index 73009c0..460de5f 100644 --- a/README.md +++ b/README.md @@ -1 +1,4 @@ -# UniDI \ No newline at end of file +# UniDI + + +https://github.com/arty-F/MonoInjector.git?path=Assets/MonoInjector From 39c1604f9c6f1609d3e47c71f326b0c4c63d2bec Mon Sep 17 00:00:00 2001 From: A F <49113047+arty-F@users.noreply.github.com> Date: Thu, 23 May 2024 22:01:08 +0700 Subject: [PATCH 2/4] Update LICENSE.txt --- LICENSE.txt | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/LICENSE.txt b/LICENSE.txt index 8aa2645..9877ada 100644 --- a/LICENSE.txt +++ b/LICENSE.txt @@ -1,6 +1,6 @@ MIT License -Copyright (c) [year] [fullname] +Copyright (c) 2024 arty-F Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal From 1f1efb5c52ca2bf10037b63e6c438c42bbd9ab9e Mon Sep 17 00:00:00 2001 From: A F <49113047+arty-F@users.noreply.github.com> Date: Fri, 24 May 2024 18:04:32 +0700 Subject: [PATCH 3/4] Update README.md --- README.md | 111 +++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 109 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 460de5f..3fa032c 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,111 @@ -# UniDI +# MonoInjector +Fast and easy to use dependency injection library for Unity game engine. -https://github.com/arty-F/MonoInjector.git?path=Assets/MonoInjector +- **Delegate based reflection hooks** for ultra fast resolving speed. +- **Caching** reflection data for reducing allocations. +- **Small codebase**. +- **Easy to use**. +- **DOES NOT CONTAIN UNNECESSARY FUNCTIONALITY** like other popular di frameworks. + +## Features + +- **Field** injection. +- **Property** injection. +- **Method** injection. + +## Installation + +### Install from git URL + +Requires a version of unity that supports path query parameter for git packages (Unity 2021.3 or later). You can add a reference `https://github.com/arty-F/MonoInjector.git?path=Assets/MonoInjector` to Package Manager. + +![Screenshot_1](https://github.com/arty-F/MonoInjector/assets/49113047/0a65d9e3-89f2-44ed-8232-713660590d6f) + +### Install from .unitypackage + +Download the latest .unitypackage file from [releases](https://github.com/arty-F/MonoInjector/releases) page and import downloaded package into unity. + +![Screenshot_2](https://github.com/arty-F/MonoInjector/assets/49113047/4bb02ea9-bd94-4ab4-8d73-54a64661e2d8) + +## Usage + +1. Add `MonoInjectorContext` component to any `GameObject` on scene (the injected dependencies lifecycle will be associated with this object). + +2. Mark field/property/method into which the dependency should be injected with the `[Inject]` attribute. +```csharp +using MonoInjector; + +public class TestClass +{ + [Inject] private InjectedClass1 _injectedField; + + [Inject] public InjectedClass2 InjectedProperty { get; private set; } + + [Inject] + public void Method(InjectedClass3 p1, InjectedClass4 p2) + { + _injectedFromMethod1 = p1; + _injectedFromMethod2 = p2; + } + private InjectedClass3 _injectedFromMethod1; + private InjectedClass4 _injectedFromMethod2; +} +``` + +3. Inject instances by invoking `Inject()` method (this is a part of library extension method). +```csharp +var instance1 = new InjectedClass1(); +instance1.Inject(); + +var instance2 = Instantiate(prefab); +instance2.Inject(); +``` + +4. Resolve dependencies of injection consumer classes by invoking `Resolve()` method. +```csharp +var consumer1 = new TestClass(); +consumer1.Resolve(); + +var consumer2 = Instantiate(prefab); +consumer2.Resolve(); +``` +Or you can use `GameObject` extension method to one row instantiating and resolving dependencies (has 9 overloads like original Instantiate method). +```csharp +[SerializeField] GameObject _prefab; + +private void Start() +{ + var object1 = _prefab.InstantiateResolve(); + var object2 = _prefab.InstantiateResolve(position, rotation); +} +``` + +## Performance + +### Field Injection + +four fields in instance, different types +| | Time | GC Alloc | +| ------------- | ------------- | ------------- | +| 1 instance | 13 ms | 46 KB | +| 100 instances | 15 ms | 80 KB | +| 1000 instances | 28 ms | 389 KB | + +### Property Injection + +four properties in instance, different types +| | Time | GC Alloc | +| ------------- | ------------- | ------------- | +| 1 instance | 4 ms | 21 KB | +| 100 instances | 6 ms | 56 KB | +| 1000 instances | 20 ms | 365 KB | + +### Method Injection + +four method parameters, different types +| | Time | GC Alloc | +| ------------- | ------------- | ------------- | +| 1 instance | 3 ms | 19 KB | +| 100 instances | 4 ms | 19 KB | +| 1000 instances | 6 ms | 19 KB | From e03a5a7ec37214a6ba95cb3d1eaeafee153c4555 Mon Sep 17 00:00:00 2001 From: A F <49113047+arty-F@users.noreply.github.com> Date: Fri, 24 May 2024 18:05:14 +0700 Subject: [PATCH 4/4] Update README.md --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 3fa032c..521cfbd 100644 --- a/README.md +++ b/README.md @@ -6,7 +6,7 @@ Fast and easy to use dependency injection library for Unity game engine. - **Caching** reflection data for reducing allocations. - **Small codebase**. - **Easy to use**. -- **DOES NOT CONTAIN UNNECESSARY FUNCTIONALITY** like other popular di frameworks. +- **DOES NOT CONTAIN UNNECESSARY FUNCTIONALITY** like other popular DI frameworks. ## Features