-
Notifications
You must be signed in to change notification settings - Fork 20
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Update .gitignore, LICENSE and README.md
- Loading branch information
Showing
3 changed files
with
180 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,173 @@ | ||
# CarbonGraph | ||
A Swift dependency injection / lookup framework for iOS | ||
data:image/s3,"s3://crabby-images/91f4a/91f4ad742d6131afdc505f5e8b21198bed8f0636" alt="Banner" | ||
|
||
data:image/s3,"s3://crabby-images/4395c/4395c349bb67b8d7f4204c18ed063f35d26a6731" alt="Swift Version" | ||
data:image/s3,"s3://crabby-images/30634/30634f9341fcda1e32684ccf87ff83f7682cdde6" alt="Platforms" | ||
data:image/s3,"s3://crabby-images/9ea68/9ea6863cb90d69d2ebf4a9c38ead05d20c37bc88" alt="License" | ||
|
||
CarbonGraph is a Swift dependency injection / lookup framework for iOS. You can use it to build loose coupling between modules. | ||
|
||
| Framework | Description | | ||
| --- | --- | | ||
| CarbonCore | The main implementation of CarbonGraph | | ||
| CarbonObjC | CarbonCore's ObjC adaptation framework | | ||
|
||
## Features | ||
|
||
- [x] Complete dependency injection capabilities | ||
- [x] Complete Objective-C support | ||
- [x] Convenient object definition DSL | ||
- [x] High-performance thread-safe solution | ||
- [x] Support resolving native Swift types | ||
- [x] Support resolving with external parameters | ||
- [x] Support resolving with circular dependencies | ||
- [x] Automatic scanning of configuration | ||
- [x] Additional module life cycle management capabilities | ||
|
||
## Requirements | ||
|
||
| CarbonGraph Stable Version | Required iOS Version | Required Swift Version | | ||
| --- | --- | --- | | ||
| 1.1.0 | 9.0 | 5.2 | | ||
|
||
### Compatibility | ||
|
||
| Xcode Version | Swift Version | MacOS Version | Build for distribution | | ||
| --- | --- | --- | --- | | ||
| 11.4 | 5.2 | Catalina 10.15.7 | passing | | ||
| 12.1 | 5.3 | Catalina 10.15.7 | passing | | ||
| 12.4 ☑ | 5.3.2 | Catalina 10.15.7 | passing | | ||
| ~~12.5~~ | ~~5.4~~ | ~~Big Sur 11.6~~ | ~~error~~ | | ||
| ~~12.5.1~~ | ~~5.4.2~~ | ~~Big Sur 11.6~~ | ~~error~~ | | ||
| 13.0 ☑ | 5.5 | Big Sur 11.6 | passing | | ||
|
||
## Installation | ||
|
||
CocoaPods is a dependency manager for Cocoa projects. For usage and installation instructions, visit their website. To integrate CarbonGraph into your Xcode project using CocoaPods, specify it in your Podfile: | ||
|
||
pod 'CarbonCore', '~> 1.2.2' | ||
|
||
## Basic Usage | ||
|
||
* Basic object registration and resolving | ||
```swift | ||
let context = ApplicationContext() | ||
context.register(builder: Definition().object(FilePath())) | ||
appContext[FilePath.self] | ||
``` | ||
|
||
* Use configuration batch registration | ||
```swift | ||
class MyConfiguration: ScannableObject, Configuration { | ||
static func definitions() -> Definitions { | ||
Definition() | ||
.object(FilePath()) | ||
Definition() | ||
.constructor(FileModel.init(filePath:)) | ||
Definition() | ||
.factory { _ in FileModel(path: “/“) } | ||
} | ||
} | ||
|
||
let context = ApplicationContext() | ||
context.register(configuration: MyConfiguration.self) | ||
``` | ||
|
||
* Multiple object definition methods | ||
```swift | ||
Definition().object(FilePath()) | ||
Definition().constructor(FilePath.init) | ||
Definition().factory { _ in FilePath() } | ||
Definition().factory(createFilePath()) | ||
|
||
static func createFilePath(context: ObjectContext) -> FilePath { FilePath() } | ||
``` | ||
|
||
* Define protocol alias for object | ||
```swift | ||
Definition() | ||
.object(FileModel(path: "/") as FileModelProtocol) | ||
``` | ||
|
||
* Define multiple protocol aliases for the object | ||
```swift | ||
Definition() | ||
.protocol(FileManagerProtocol.self) | ||
.alias(ImageManagerProtocol.self) | ||
.alias(DirectoryManagerProtocol.self) | ||
.object(FileManager()) | ||
``` | ||
|
||
* Use constructor for dependency injection | ||
```swift | ||
Definition() | ||
.constructor(FileModel.init(filePath:)) | ||
``` | ||
|
||
* Use property for dependency injection | ||
```swift | ||
Definition() | ||
.protocol(FileViewControllerProtocol.self) | ||
.object(FileViewController()) | ||
.property(\.avatarFactory) | ||
``` | ||
|
||
* Use setter for dependency injection | ||
```swift | ||
Definition() | ||
.protocol(FileViewControllerProtocol.self) | ||
.object(FileViewController()) | ||
.setter(FileViewController.setAvatarFactory) | ||
``` | ||
|
||
* Use static factory for dependency injection | ||
```swift | ||
Definition() | ||
.factory(fileModel(context:filePath:)) | ||
appContext[FileModelProtocol.self] | ||
|
||
static func fileModel2(context: ObjectContext, filePath: FilePath) -> FileModelProtocol { | ||
FileModel(path: filePath.path, name: filePath.name) | ||
} | ||
``` | ||
|
||
* Use a static factory for manual dependency injection | ||
```swift | ||
Definition() | ||
.factory { ctx in FileModel(filePath: ctx[FilePath.self]) as FileModelProtocol } | ||
appContext[FileModelProtocol.self] | ||
``` | ||
|
||
* Create objects with external parameters | ||
```swift | ||
Definition() | ||
.factory(fileModel(context:arg1:arg2:)) | ||
appContext[FileModelProtocol.self, "/china/beijing", "family.png"] | ||
|
||
static func fileModel(context: ObjectContext, arg1: String, arg2: String) -> FileModelProtocol { | ||
FileModel(path: arg1, name: arg2) | ||
} | ||
``` | ||
|
||
For more usage scenarios, please refer to Netdisk Demo or related unit test cases, or contact us for help. | ||
|
||
## Unit Tests | ||
|
||
1. Open Carbon.xcworkspace with Xcode | ||
2. Execute Command + U in Xcode | ||
|
||
## Discussion | ||
|
||
| Tool | Address | Description | | ||
| --- | --- | --- | | ||
| Infoflow | 5346856 | CarbonGraph users discussion group | | ||
| Email | [email protected] | CarbonGraph core contributors email group | | ||
|
||
## Credits | ||
|
||
The idea of using dependency injection to build loosely coupled projects is from [Spring](https://spring.io). The implementation of using generics to obtain method parameter types is from [Swinject](https://github.com/Swinject/Swinject). | ||
|
||
Thanks for the excellent ideas and implementation provided by the above framework. | ||
|
||
## License | ||
|
||
CarbonGraph is released under the MIT license. See [LICENSE](https://console.cloud.baidu-int.com/devops/icode/repos/baidu/netdisk/ios-carbon-lib/blob/master:LICENSE) for details. |