Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/soundcloud/delect
The Gradle Plugin for Dagger Reflect.
https://github.com/soundcloud/delect
Last synced: about 2 months ago
JSON representation
The Gradle Plugin for Dagger Reflect.
- Host: GitHub
- URL: https://github.com/soundcloud/delect
- Owner: soundcloud
- License: apache-2.0
- Archived: true
- Created: 2019-05-20T10:04:15.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2022-04-28T17:04:37.000Z (over 2 years ago)
- Last Synced: 2024-09-22T18:03:03.782Z (about 2 months ago)
- Language: Kotlin
- Homepage:
- Size: 177 KB
- Stars: 138
- Watchers: 69
- Forks: 10
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.txt
Awesome Lists containing this project
README
⚠️ **Delect has been retired!**
After 2+ years of service it's time to retire Delect. We won’t be developing the plugin further and we won’t provide support but you’re welcome to keep using Delect if it works for you ✌️
# Delect - The Gradle Plugin for Dagger Reflect
Delect automatically substitutes Dagger for Dagger Reflect for faster local builds.
[Dagger](https://github.com/google/dagger), a dependency injection framework for Java, can slow down compilation with its lengthy annotation processing and code generation.
[Dagger Reflect](https://github.com/jakewharton/dagger-reflect) uses the same API as Dagger but swaps the compile time annotation processing for runtime based reflection.
## Usage
Delect uses the [partial reflection approach](https://github.com/jakewharton/dagger-reflect#usage).1. Add the plugin to your project's root build.gradle:
```
buildscript {
classpath 'com.soundcloud.delect:delect-plugin:0.3.0'
}
apply plugin: 'com.soundcloud.delect'
```
2. Make sure to use the `@Component.Builder` or `@Component.Factory` to create component instances.
3. Add the runtime retention policy to all `@Qualifier`, `@MapKey` and other custom Dagger annotations:
```
@Retention(RUNTIME)
```
4. Add `dagger.reflect=true` to `gradle.properties`.
You can also add it to `~/.gradle/gradle.properties` so it doesn't need to be checked into the project.
5. Build -- and skip all that pesky code generation!## Plugin Development
To publish to maven local:
```
./gradlew -b buildSrc/build.gradle.kts publishToMavenLocal
```
To publish:
```
./gradlew -b buildSrc/build.gradle.kts publishMavenJavaPublicationToMavenRepository
```## Found more than one jar in the 'lintChecks' configuration.
This is a [bug in AGP](https://issuetracker.google.com/issues/141840950).
To disable Dagger Reflect lint checks:
```groovy
delect {
enableReflectLintCheck = false
}
```## License
```
Copyright 2019 SoundCloudLicensed 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 athttp://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.
```