RFR: 8325433: Type annotations on primitive types are not linked [v3]

Pavel Rappo prappo at openjdk.org
Mon Mar 11 17:15:54 UTC 2024


On Mon, 11 Mar 2024 13:57:23 GMT, Chen Liang <liach at openjdk.org> wrote:

>> Please review this patch that fixes the issue where type annotations on primitive types are not linked.
>> 
>> Tested with file https://cr.openjdk.org/~liach/8325433-arrayanno/ArrayAnno.java
>> 
>> import java.lang.annotation.*;
>> 
>> public class ArrayAnno {
>> 	@Retention(RetentionPolicy.RUNTIME)
>> 	@Target(ElementType.TYPE_USE)
>> 	@Documented
>> 	public @interface Anno { int value(); }
>> 
>> 	public void method(@Anno(1) int @Anno(2) [] @Anno(3) [] arg) {}
>> 	public void method(@Anno(1) String @Anno(2) [] @Anno(3) [] arg) {}
>> }
>> 
>> JDK 21: https://cr.openjdk.org/~liach/8325433-arrayanno/old/ArrayAnno.html
>> This patch: https://cr.openjdk.org/~liach/8325433-arrayanno/new/ArrayAnno.html
>> 
>> Note that a bug within javac (reported in https://bugs.openjdk.org/browse/JDK-8327824) causes the annotations to become `@Anno(1) String @Anno(3) [] @Anno(2) []` in the output files; this bug also affects output class files so I assume this is a bug within javac's tree building. (Intersting, the buggy javadoc output was copied wholesale in the original `TestTypeAnnotations` output for `array2Deep` cases, but no one paid attention to it)
>
> Chen Liang has updated the pull request incrementally with one additional commit since the last revision:
> 
>   Redundant imports

Thanks for taking care of it. The approach seems good. I've submitted this change to our CI system. Once the results are back, I'll let you know.

-------------

PR Comment: https://git.openjdk.org/jdk/pull/18179#issuecomment-1988996333


More information about the javadoc-dev mailing list