Inject
A simple Kotlin multi-platform abstraction around the javax.inject annotations. This allows using the annotations in Kotlin common code so that platform specific annotation processors can register them.
For more information about the library, refer to the blog post here which was featured in Android Weekly issue #396.
The blog post was also featured in Kotlin Weekly issue #182.
Using the library
Simply use the provided annotations just as you would use the javax.inject annotations.
For example, using the Inject
annotation on a constructor in Kotlin Common code:
class MyUseCase @Inject constructor() { ... }
Available annotations and interfaces
@Inject
@Named("name")
@Qualifier
@Scope
@Singleton
Provider<T>
Building the library
The library is provided through repsy.io. Checkout the releases package to get the latest version.
Repository
repositories {
maven { url = "https://repo.repsy.io/mvn/chrynan/public" }
}
Dependencies
implementation("com.chrynan.inject:inject:VERSION")
Documentation
More detailed documentation is available in the docs folder. The entry point to the documentation can be found here.
License
Copyright 2021 chRyNaN
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
The javax.inject library is also licensed under the Apache License 2.0.