An experimental dependency injection framework
- tiny, fast, Dependency Injection framework
- compile-time error checking
- no annotations, no "magic"
- zero* library dependencies
shiv takes method references (java lambdas) and organizes calls to them in such a way where method dependencies are supplied recursively.
It analyzes the dependency graph via Kosaraju's algorithm and verifies model safety at compile time, then swaps to a lightweight hashmap at runtime for maximum performance.
shiv is split up into packages:
- shiv-api is the project's API
- shiv-core is the runtime version of shiv
- it is small and it and the api what you shade into your project
- shiv-analyzer is used in your tests at compile time to check for circular dependencies
- it uses jgrapht but only at compile time (no shading)
- create a class implementing
shiv.Module
- make a function that returns something
- make a function that returns otherthing and depends on the something returned by the last function
- wherever you want to use otherthing without writing
new OtherThing(new Something());
- write
Shiv shiv = Shiv.provide(new YourModuleHere())
- call
Otherthing other = shiv.build().get(Otherthing.class)
- write
i made this for my robotics team some time ago as a proof of concept.
don't say I didn't warn you...
maven {
url "https://repo.superyuuki.com/releases"
}