Status Update
Comments
al...@gmail.com <al...@gmail.com> #2
I think there are a number of existing issues already requesting this (particularly for the nullability annotations). The blocker for this is that metalava needs to support typeuse annotations, and it doesn't yet (and it's a nontrivial amount of work; there is partial support in there behind a compile-time flag, but it's not complete.)
sa...@google.com <sa...@google.com> #3
Kotlin's AnnotationTarget.TYPE
maps to Java's ElementType.TYPE_USE
, which was added in SDK 26. If we use this in Java code, we will likely need to do one of the following:
- Require
minSdkVersion=26
-- which is too high at this point in time - Advise clients to enable core library desugaring -- which I think still has client usability issues
- Advise clients to ignore
javac
class resolution warnings -- which we're already getting flak for with Kotlin
Tor, do you see any better option here?
pr...@google.com <pr...@google.com> #4
And, of course, that Metalava doesn't support typeuse annotations yet. But we (AndroidX) have more control over when that happens.
pr...@google.com <pr...@google.com> #5
I think all of the androidx annotations are compile or class retention, not runtime retention, so there probably aren't any minSdkVersion requirements?
pr...@google.com <pr...@google.com> #6
Ah, yes, good point -- the errors I saw for other annotations were due to Kotlin's Metadata
which is runtime retention. We may still need to add Proguard rules, though, to avoid resolution warnings coming out of bytecode optimizers.
Description
Thank you for submitting a 3PCD Breakage Report! To help reproduce the breakage on our end, please provide us with the necessary test login credentials or a test 1P site (or a “sandbox demo” environment such as glitch.com or JS Fiddle or Project IDX ).
Any sensitive details (such as test login credentials) can be shared using the “Restrict this comment/attachment” feature. Look for the eye+lock icon below the comment box.
If the above are not possible, please provide a single screen recording that shows all of the following steps: