An open API service indexing awesome lists of open source software.

https://github.com/badchoice/rvcontainer

Simple lightweight IoC container for objective-c based on Laravel's
https://github.com/badchoice/rvcontainer

Last synced: about 1 year ago
JSON representation

Simple lightweight IoC container for objective-c based on Laravel's

Awesome Lists containing this project

README

          

# RVContainer

This is a simple and lightweigh IoC Container for Objective-c based on Laravel's one.

#### Installation

```
pod 'RVContainer'
```

#### Usage

There are two options to use it, creating a new `RVContainer` instance and storing it wherever you can access from any part you could need it, or using the singleton provided.

When using the singleton there are two ways to use it

```
[RVContainer container]
````

or simply using `IOC` marco that shortens the above call.

```
IOC
```

To bind your classes to the container there are several methods

##### Basic binding
```
[IOC bind:AwesomeClass.class resolver:SubAwesomeClass.class];
````

```
[IOC bind:AwesomeClass.class closure: ^(id){
return [SubAwesomeClass new];
}];
```

You can bind an instance, so the container will allways return it when asking for that class

```
SubAwesomeClass * instance = [SubAwesomeClass new];
[IOC instance:AwesomeClass.class object:instance];
```

And similar to the previous one, you can register a singleton that will always be returned when asking for it
```
[IOC singleton:AwesomeClass.class closure:^id{
return [SubAwesomeClass new];
}];
````

Another imporant feature is to bind contracts (or protocols in objective-c).

```
[IOC bindProtocol:@protocol(aProtocol) resolver:ClassThatImplementsTheProtocol.class];
````

#### Resolve
If you try to resolve a class not in the container, it will return a new instance of the class requested

```
AwesomeClass * object = [IOC make:SubAwesomeClass.class];
```

```
ClassThatImplementsTheProtocol * object = [IOC makeProtocol:@protocol(aProtocol)];
```

### Autoinject
If you don't want to clutter your classes with container resolving things you can use autoinject
It will automatically inject the dependencies to you object properties

You need to declare the properties to be injected like the following:

```
#import "RVAutoInject.h"

@interface ClassWithObjectsToBeInjected : NSObject

@property(strong,nonatomic) inject(AwesomeClass) *subtest;
@property(strong,nonatomic) TestClass *test;
@property(strong,nonatomic) injectProtocol(aProtocol) *testProtocol;

@end
```

And then in your init method call

```
[RVAutoInject autoInject:self];
```

> I'm not really happy with this Autoinject call but I don't know how to make it automatically

### Contributing
I really welcome any issue and PR so feel free to post them