-
Notifications
You must be signed in to change notification settings - Fork 746
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Consider using Multi-Release jars for Error Prone #3756
Comments
Some WIP on this in #4521
|
|
|
copybara-service bot
pushed a commit
that referenced
this issue
Aug 14, 2024
and use it to work around a breaking change in `SignatureGenerator`. #3756 PiperOrigin-RevId: 661672308
copybara-service bot
pushed a commit
that referenced
this issue
Aug 15, 2024
and use it to work around a breaking change in `SignatureGenerator`. #3756 PiperOrigin-RevId: 663105454
jrguzman-ms
pushed a commit
to msft-mirror-aosp/platform.build.soong
that referenced
this issue
Oct 10, 2024
The latest errorprone updates use a multi-release jar file: google/error-prone#3756 https://openjdk.org/jeps/238 The module-info.class existing under certain version folders caused package-check.sh to fail. Currently errorprone only has a versioned module-info.class file, but if it later adds versioned implementation classes, we may also need to update package-check.sh to respect multi-release jars. Bug: 253827323 Test: m RUN_ERROR_PRONE=true out/soong/.intermediates/packages/modules/Media/apex/framework/updatable-media/android_common/package-check.stamp with errorprone update to 3.32.0 Change-Id: Ieaee73636aa5321494c14c221d38964e1b0cebb1
I updated #4586 with a multi-release JAR setup that seems to work, at least locally. TBD what aspect (if any) of the GitHub Actions configuration has to be adjusted. |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
This bug tracks trying to use Multi-Release jar files for Error Prone.
The main use-case is that some checks need to handle AST nodes that not available in all supported JDK versions. Currently we're mostly using reflection to work around that, with mrjars we could move some of that logic behind an internal API and provide implementations that used the new AST nodes for JDK versions that supported them, avoiding the reflection. (e.g. #3737, #3610 (comment))
One of the barriers to doing this is figuring out the best way to produce mrjars with maven. (If anyone reading this has relevant experience, suggestions are welcome!)
The text was updated successfully, but these errors were encountered: