Skip to content

Commit

Permalink
Update README.md
Browse files Browse the repository at this point in the history
  • Loading branch information
arty-F authored May 24, 2024
1 parent 39c1604 commit 1f1efb5
Showing 1 changed file with 109 additions and 2 deletions.
111 changes: 109 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
@@ -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 |

0 comments on commit 1f1efb5

Please sign in to comment.