An experiment on the idea of Google's Dagger using different means of code generation: Kotlin compiler.
For now I continue working on implementing richer feature-set. Most of the code is generated in frontend using KotlinPoet. IDE support works out of the box (at least for JB products) thanks to gradle integration. As a side effect of this project, I am exploring how DI can be done better using Kotlin (in compile time safe way).
If you, for any reason, want to look through this:
- The plugin files are in:
buildSrc/compiler-plugin/kotlin-plugin(this is what attaches to compiler) - The test project files is in
src/main/kotlin(this is what gets compiled)
Right now I have implemented the concept of:
- exposing dependencies through
Component. - providing them through
Moduleimplemented asobjectorclassinstance. - providing using
@Injectannotated constructor - inject dependencies into
@Injectannotated fields - inject dependencies into
@Injectannotated functions (one param only) - local scoping inside component using
@Scopeannotations - provide external dependencies using
@Factory - Support of
@BindsInstancefor components - Support for
@Qualifier - external dependencies through
@Builder - Default builder
- Type mapping using
@Binds LazyandProvidersupport
TODO (in any order):
- Default module instantiation when class has an empty constructor
ReusablesupportIntoSet/IntoMap- Subcomponents
- Proper scope support
- ... the rest
Use ./gradlew run. It will build and install plugin to maven local, after it will compile the test project using freshly built plugin and run it. Yay!
To get the plugin, follow instructions here.