Add support for R8-based minization#2077
Open
ZacSweers wants to merge 20 commits into
Open
Conversation
Goooler
approved these changes
Jul 3, 2026
Comment on lines
+20
to
+21
| /** Use R8 to minimize the shadowed JAR and configure its options. */ | ||
| public fun r8(action: Closure<*>) |
Member
There was a problem hiding this comment.
We don't have to expose Closure.
| import org.gradle.api.tasks.PathSensitivity | ||
|
|
||
| /** Minimal R8 configuration for [ShadowJar.minimize]. */ | ||
| public interface R8Spec { |
Member
There was a problem hiding this comment.
Should we mark DslMarker for r8 blocks?
| val rulesFile = r8Dir.resolve("rules.pro") | ||
| val r8Output = r8Dir.resolve("output.jar") | ||
| val normalizedOutput = r8Dir.resolve("normalized-output.jar") | ||
| val javaHome = System.getProperty("java.home") |
Member
There was a problem hiding this comment.
Should we support Java toolchian like JavaExec?
This file contains hidden or 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
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
This was attempted once or twice in the past on this project before the move, but attempted again here. This adds support for R8-based minimization, which is much more thorough and configurable than the default unused shrinker. This also allows for extra configuration to optimize, obfuscate, etc.
Full usage docs are in the README additions here. The default behavior is purely just tree-shaking. This also allows for the addition of other tools in the future too.
Disclosure: I did use AI to move through some of the boilerplate here, but manually de-fluffed and cleaned things up after too. Much of it was based on my use of R8 manually in another project here: https://github.com/ZacSweers/MoshiX/blob/main/moshi-ir/moshi-kotlin-tests/build.gradle.kts#L18