commit | b3ea3fcd0b629bc8051923e09eaae3ccac9eed7d | [log] [tgz] |
---|---|---|
author | Johan Bay <jobay@google.com> | Thu Aug 07 11:15:04 2025 +0200 |
committer | Johan Bay <jobay@google.com> | Thu Aug 07 02:20:45 2025 -0700 |
tree | 816c7a06eebe1919883950e5584edc7e867e58c7 | |
parent | 146d3107be56b11093cc865c1548c9a93df62aa8 [diff] |
Fix bridge insertion for code with illegal access errors Change-Id: If47d870a713ab21679311e697f3e448c020ce524
The R8 repo contains two tools:
D8 is a replacement for the DX dexer and R8 is an alternative to the ProGuard shrinking and minification tool.
There are several places to obtain a prebuilt version without building it yourself.
The stable release versions shipped with Android Studio are available from the Google Maven repository, see https://maven.google.com/web/index.html#com.android.tools:r8.
Our CI builds for each commit and stores all build artifacts in Google Cloud Storage in the bucket r8-releases.
To obtain a prebuild from the CI for a specifc version (including both stable and -dev
versions), download from the following URL:
https://storage.googleapis.com/r8-releases/raw/<version>/r8lib.jar
To obtain a prebuild from the CI for a specifc main branch hash, download from the following URL:
https://storage.googleapis.com/r8-releases/raw/main/<hash>/r8lib.jar
The prebuilt JARs have been processed by R8, and for each build the corresponding mapping file is located together with the prebuild under the name r8lib.jar.map
.
To get prebuilds which has not been processed by R8 replace r8lib.jar
with r8.jar
in the URLs above.
The Google Cloud Storage bucket r8-releases can also be used as a simple Maven repository using the following in a Gradle build file:
maven { url = uri("https://storage.googleapis.com/r8-releases/raw") }
See Running D8 and Running R8 below on how to invoke D8 and R8 using the obtained r8lib.jar
in place of build/libs/r8.jar
.
The R8 project uses depot_tools
from the chromium project to manage dependencies. Install depot_tools
and add it to your path before proceeding.
The R8 project uses Java 8 language features and requires a Java 8 compiler and runtime system.
Typical steps to download and build:
$ git clone https://r8.googlesource.com/r8 $ cd r8 $ tools/gradle.py r8
The tools/gradle.py
script will bootstrap using depot_tools to download a version of gradle to use for building on the first run. This will produce a jar file: build/libs/r8.jar
which contains both R8 and D8.
Follow the instructions in the above section.
r8/d8_r8
in IntelliJr8/third_party/gradle
as “Local installation” in “Distribution”r8/third_party/openjdk/jdk-11/linux
as “Gradle JVM”In order to run tests it may currently be necessary to run tools/test.py
from the command line first.
The D8 dexer has a simple command-line interface with only a few options. D8 consumes class files and produce DEX.
The most important option is whether to build in debug or release mode. Debug is the default mode and includes debugging information in the resulting dex files. Debugging information contains information about local variables used when debugging dex code. This information is not useful when shipping final Android apps to users and therefore, final builds should use the --release
flag to remove this debugging information to produce smaller dex files.
Typical invocations of D8 to produce dex file(s) in the out directoy:
Debug mode build:
$ java -cp build/libs/r8.jar com.android.tools.r8.D8 \ --min-api <min-api> \ --output out \ --lib <android.jar/rt.jar> \ input.jar
Release mode build:
$ java -cp build/libs/r8.jar com.android.tools.r8.D8 --release \ --min-api <min-api> \ --output out \ --lib <android.jar/rt.jar> \ input.jar
See Running R8 for information on options --min-api
and --lib
.
The full set of D8 options can be obtained by running the command line tool with the --help
option.
R8 is a whole-program optimizing compiler with focus on shrinking the size of programs. R8 uses the ProGuard configuration format for configuring the whole-program optimization including specifying the entry points for an application.
R8 consumes class files and can output either DEX for Android apps or class files for Java apps.
Typical invocations of R8 to produce optimized DEX file(s) in the out
directory:
$ java -cp build/libs/r8.jar com.android.tools.r8.R8 \ --release \ --min-api <min-api> \ --output out \ --pg-conf proguard.cfg \ --lib <android.jar/rt.jar> \ input.jar
This produce DEX targeting Android devices with a API level of <min-api>
and above.
The option --lib
is passing the bootclasspath for the targeted runtime. For targeting Android use an android.jar
from the Android Platform SDK, typically located in ~/Android/Sdk/platforms/android-XX
, where XX
should be the latest Android version.
To produce class files pass the option --classfile
and leave out --min-api <min-api>
. This invocation will provide optimized Java classfiles in output.jar
:
$ java -cp build/libs/r8.jar com.android.tools.r8.R8 \ --release \ --classfile \ --output output.jar \ --pg-conf proguard.cfg \ --lib <android.jar/rt.jar> \ input.jar
When producing output targeted for the JVM one can pass $JAVA_HOME
to -lib
. R8 will then locate the Java bootclasspath from there.
The full set of R8 options can be obtained by running the command line tool with the --help
option.
R8 is not command line compatible with ProGuard, for instance keep rules cannot be passed on the command line, but have to be passed in a file using the --pg-conf
option.
Android Gradle plugin (AGP) ships with R8 embedded (as part of the builder.jar
from com.android.tools.build:builder:<agp version>
on https://maven.google.com).
To override the embedded version with a prebuilt R8 with version <version>
, merge the following into the top level settings.gradle
or settings.gradle.kts
:
pluginManagement { buildscript { repositories { mavenCentral() maven { url = uri("https://storage.googleapis.com/r8-releases/raw") } } dependencies { classpath("com.android.tools:r8:<version>") } } }
To override the embedded version with a downloaded or freshly built <path>/r8.jar
merge the following into the top level settings.gradle
or settings.gradle.kts
:
pluginManagement { buildscript { dependencies { classpath(files("<path>/r8.jar")) } } }
Typical steps to run tests:
$ tools/test.py --no_internal
The tools/test.py
script will use depot_tools to download a lot of tests and test dependencies on the first run. This includes prebuilt version of the art runtime on which to validate the produced dex code.
In order to contribute to D8/R8 you have to sign the Contributor License Agreement. If your contribution is owned by your employer you need the Corporate Contributor License Agreement.
Signing the CLA should be enough to be approved as a contributer. However, please send an email to r8-dev@googlegroups.com to introduce yourself and your plans for contributing to the project.
To create an account for the code review tool (required for uploading changes) please navigate to https://r8-review.googlesource.com/ and sign in with the account used to sign the CLA. First time you do that you will be asked to Create Gerrit Account. Plase follow that process.
You can now upload your patches. Once you have a change that you are happy with you should make sure that it passes all tests and then upload the change to our code review tool using:
$ git cl upload
On your first upload you will be asked to acquire credentials. Follow the instructions given by git cl upload
(as of Aug 5 2025 that is running git credential-luci login
, the previous .gitcookies
based authentication scheme has been deprecated.).
On successful uploads a link to the code review is printed in the output of the git cl upload
command. In the code review tool you can assign reviewers and mark the change ready for review. At that point the code review tool will send emails to reviewers.
For questions, reach out to us at r8-dev@googlegroups.com.
For D8, find known issues in the D8 issue tracker or file a new D8 bug report.
For R8, find known issues in the R8 issue tracker or file a new R8 bug report.