mirror of
https://github.com/openjdk/jdk.git
synced 2025-08-27 14:54:52 +02:00
8263763: Synthetic constructor parameters of enum are not considered for annotation indices
Reviewed-by: darcy, jfranck
This commit is contained in:
parent
1ee80e03ad
commit
9dd96257c6
4 changed files with 73 additions and 9 deletions
|
@ -605,9 +605,14 @@ public final class Constructor<T> extends Executable {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
boolean handleParameterNumberMismatch(int resultLength, int numParameters) {
|
boolean handleParameterNumberMismatch(int resultLength, Class<?>[] parameterTypes) {
|
||||||
|
int numParameters = parameterTypes.length;
|
||||||
Class<?> declaringClass = getDeclaringClass();
|
Class<?> declaringClass = getDeclaringClass();
|
||||||
if (declaringClass.isEnum() ||
|
if (declaringClass.isEnum()) {
|
||||||
|
return resultLength + 2 == numParameters &&
|
||||||
|
parameterTypes[0] == String.class &&
|
||||||
|
parameterTypes[1] == int.class;
|
||||||
|
} else if (
|
||||||
declaringClass.isAnonymousClass() ||
|
declaringClass.isAnonymousClass() ||
|
||||||
declaringClass.isLocalClass() )
|
declaringClass.isLocalClass() )
|
||||||
return false; // Can't do reliable parameter counting
|
return false; // Can't do reliable parameter counting
|
||||||
|
|
|
@ -566,17 +566,19 @@ public abstract class Executable extends AccessibleObject
|
||||||
Annotation[][] result = parseParameterAnnotations(parameterAnnotations);
|
Annotation[][] result = parseParameterAnnotations(parameterAnnotations);
|
||||||
|
|
||||||
if (result.length != numParameters &&
|
if (result.length != numParameters &&
|
||||||
handleParameterNumberMismatch(result.length, numParameters)) {
|
handleParameterNumberMismatch(result.length, parameterTypes)) {
|
||||||
Annotation[][] tmp = new Annotation[result.length+1][];
|
Annotation[][] tmp = new Annotation[numParameters][];
|
||||||
// Shift annotations down one to account for an implicit leading parameter
|
// Shift annotations down to account for any implicit leading parameters
|
||||||
System.arraycopy(result, 0, tmp, 1, result.length);
|
System.arraycopy(result, 0, tmp, numParameters - result.length, result.length);
|
||||||
tmp[0] = new Annotation[0];
|
for (int i = 0; i < numParameters - result.length; i++) {
|
||||||
|
tmp[i] = new Annotation[0];
|
||||||
|
}
|
||||||
result = tmp;
|
result = tmp;
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
abstract boolean handleParameterNumberMismatch(int resultLength, int numParameters);
|
abstract boolean handleParameterNumberMismatch(int resultLength, Class<?>[] parameterTypes);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@inheritDoc}
|
* {@inheritDoc}
|
||||||
|
|
|
@ -760,7 +760,7 @@ public final class Method extends Executable {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
boolean handleParameterNumberMismatch(int resultLength, int numParameters) {
|
boolean handleParameterNumberMismatch(int resultLength, Class<?>[] parameterTypes) {
|
||||||
throw new AnnotationFormatError("Parameter annotations don't match number of parameters");
|
throw new AnnotationFormatError("Parameter annotations don't match number of parameters");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
57
test/jdk/java/lang/annotation/EnumConstructorAnnotation.java
Normal file
57
test/jdk/java/lang/annotation/EnumConstructorAnnotation.java
Normal file
|
@ -0,0 +1,57 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2021, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @bug 8263763
|
||||||
|
* @summary Check that annotations on an enum constructor are indexed correctly.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.lang.annotation.Annotation;
|
||||||
|
import java.lang.annotation.Retention;
|
||||||
|
import java.lang.annotation.RetentionPolicy;
|
||||||
|
import java.lang.reflect.Constructor;
|
||||||
|
import java.util.Arrays;
|
||||||
|
|
||||||
|
public class EnumConstructorAnnotation {
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
Constructor<?> c = SampleEnum.class.getDeclaredConstructors()[0];
|
||||||
|
Annotation[] a1 = c.getParameters()[2].getAnnotations(), a2 = c.getParameterAnnotations()[2];
|
||||||
|
for (Annotation[] a : Arrays.asList(a1, a2)) {
|
||||||
|
if (a.length != 1) {
|
||||||
|
throw new RuntimeException("Unexpected length " + a.length);
|
||||||
|
} else if (a[0].annotationType() != SampleAnnotation.class) {
|
||||||
|
throw new RuntimeException("Unexpected type " + a[0]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
enum SampleEnum {
|
||||||
|
INSTANCE("foo");
|
||||||
|
SampleEnum(@SampleAnnotation String value) { }
|
||||||
|
}
|
||||||
|
|
||||||
|
@Retention(RetentionPolicy.RUNTIME)
|
||||||
|
@interface SampleAnnotation { }
|
||||||
|
}
|
Loading…
Add table
Add a link
Reference in a new issue