diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Lower.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Lower.java index 1a470cc9112..62bf38cc3a3 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Lower.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Lower.java @@ -2644,7 +2644,6 @@ public class Lower extends TreeTranslator { MethodSymbol m = tree.sym; tree.params = tree.params.prepend(ordParam).prepend(nameParam); - incrementParamTypeAnnoIndexes(m, 2); m.extraParams = m.extraParams.prepend(ordParam.sym); m.extraParams = m.extraParams.prepend(nameParam.sym); @@ -2667,17 +2666,6 @@ public class Lower extends TreeTranslator { currentMethodSym = prevMethodSym; } } - //where - private void incrementParamTypeAnnoIndexes(MethodSymbol m, - int amount) { - for (final Attribute.TypeCompound anno : m.getRawTypeAttributes()) { - // Increment the parameter_index of any existing formal - // parameter annotations. - if (anno.position.type == TargetType.METHOD_FORMAL_PARAMETER) { - anno.position.parameter_index += amount; - } - } - } private void visitMethodDefInternal(JCMethodDecl tree) { if (tree.name == names.init && @@ -2711,7 +2699,6 @@ public class Lower extends TreeTranslator { tree.params = tree.params.appendList(fvdefs); if (currentClass.hasOuterInstance()) { tree.params = tree.params.prepend(otdef); - incrementParamTypeAnnoIndexes(m, 1); } // If this is an initial constructor, i.e., it does not start with diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/jvm/ClassWriter.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/jvm/ClassWriter.java index 1c0e957e45b..3ff3c12b442 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/jvm/ClassWriter.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/jvm/ClassWriter.java @@ -656,8 +656,7 @@ public class ClassWriter extends ClassFile { private void writeParamAnnotations(MethodSymbol m, RetentionPolicy retention) { - databuf.appendByte(m.params.length() + m.extraParams.length()); - writeParamAnnotations(m.extraParams, retention); + databuf.appendByte(m.params.length()); writeParamAnnotations(m.params, retention); } diff --git a/langtools/test/tools/javac/annotations/SyntheticParameters.java b/langtools/test/tools/javac/annotations/SyntheticParameters.java index 7c70df2db0b..31cc1bcf50a 100644 --- a/langtools/test/tools/javac/annotations/SyntheticParameters.java +++ b/langtools/test/tools/javac/annotations/SyntheticParameters.java @@ -46,20 +46,11 @@ public class SyntheticParameters extends ClassfileInspector { null, new ExpectedParameterAnnotation[] { (ExpectedParameterAnnotation) - // Assert there is no annotation on the - // this$0 parameter. - new ExpectedParameterAnnotation( - "", - 0, - "A", - true, - 0), - (ExpectedParameterAnnotation) // Assert there is an annotation on the // first parameter. new ExpectedParameterAnnotation( "", - 1, + 0, "A", true, 1), @@ -71,27 +62,11 @@ public class SyntheticParameters extends ClassfileInspector { true, 1), (ExpectedParameterAnnotation) - new ExpectedParameterAnnotation( - "foo", - 1, - "A", - true, - 0), - (ExpectedParameterAnnotation) - // Assert there is no annotation on the - // this$0 parameter. - new ExpectedParameterAnnotation( - "", - 0, - "B", - false, - 0), - (ExpectedParameterAnnotation) // Assert there is an annotation on the // first parameter. new ExpectedParameterAnnotation( "", - 1, + 0, "B", false, 1), @@ -117,56 +92,20 @@ public class SyntheticParameters extends ClassfileInspector { null, new ExpectedParameterAnnotation[] { (ExpectedParameterAnnotation) - // Assert there is no annotation on the - // $enum$name parameter. - new ExpectedParameterAnnotation( - "", - 0, - "A", - true, - 0), - (ExpectedParameterAnnotation) - // Assert there is no annotation on the - // $enum$ordinal parameter. - new ExpectedParameterAnnotation( - "", - 1, - "A", - true, - 0), - (ExpectedParameterAnnotation) // Assert there is an annotation on the // first parameter. new ExpectedParameterAnnotation( "", - 2, + 0, "A", true, 1), (ExpectedParameterAnnotation) - // Assert there is no annotation on the - // $enum$name parameter. - new ExpectedParameterAnnotation( - "", - 0, - "B", - false, - 0), - (ExpectedParameterAnnotation) - // Assert there is no annotation on the - // $enum$ordinal parameter. - new ExpectedParameterAnnotation( - "", - 1, - "B", - false, - 0), - (ExpectedParameterAnnotation) // Assert there is an annotation on the // first parameter. new ExpectedParameterAnnotation( "", - 2, + 0, "B", false, 1) diff --git a/langtools/test/tools/javac/annotations/typeAnnotations/classfile/SyntheticParameters.java b/langtools/test/tools/javac/annotations/typeAnnotations/classfile/SyntheticParameters.java index a747fc8f0b2..39f1741a63e 100644 --- a/langtools/test/tools/javac/annotations/typeAnnotations/classfile/SyntheticParameters.java +++ b/langtools/test/tools/javac/annotations/typeAnnotations/classfile/SyntheticParameters.java @@ -44,15 +44,6 @@ public class SyntheticParameters extends ClassfileInspector { null, new ExpectedMethodTypeAnnotation[] { (ExpectedMethodTypeAnnotation) - // Assert there is no annotation on the - // this$0 parameter. - new ExpectedMethodTypeAnnotation.Builder( - "", - "A", - TypeAnnotation.TargetType.METHOD_FORMAL_PARAMETER, - false, - 0).setParameterIndex(0).build(), - (ExpectedMethodTypeAnnotation) // Assert there is an annotation on the // first parameter. new ExpectedMethodTypeAnnotation.Builder( @@ -60,21 +51,7 @@ public class SyntheticParameters extends ClassfileInspector { "A", TypeAnnotation.TargetType.METHOD_FORMAL_PARAMETER, false, - 1).setParameterIndex(1).build(), - (ExpectedMethodTypeAnnotation) - new ExpectedMethodTypeAnnotation.Builder( - "foo", - "A", - TypeAnnotation.TargetType.METHOD_FORMAL_PARAMETER, - false, - 1).setParameterIndex(0).build(), - (ExpectedMethodTypeAnnotation) - new ExpectedMethodTypeAnnotation.Builder( - "foo", - "A", - TypeAnnotation.TargetType.METHOD_FORMAL_PARAMETER, - false, - 0).setParameterIndex(1).build() + 1).setParameterIndex(0).build() }, null); private static final Expected Foo_expected = @@ -89,26 +66,7 @@ public class SyntheticParameters extends ClassfileInspector { "A", TypeAnnotation.TargetType.METHOD_FORMAL_PARAMETER, false, - 0).setParameterIndex(0).build(), - (ExpectedMethodTypeAnnotation) - // Assert there is no annotation on the - // $enum$ordinal parameter. - new ExpectedMethodTypeAnnotation.Builder( - "", - "A", - TypeAnnotation.TargetType.METHOD_FORMAL_PARAMETER, - false, - 0).setParameterIndex(1).build(), - (ExpectedMethodTypeAnnotation) - // Assert there is an annotation on the - // first parameter. - new ExpectedMethodTypeAnnotation.Builder( - "", - "A", - TypeAnnotation.TargetType.METHOD_FORMAL_PARAMETER, - false, - 1).setParameterIndex(2).build() - }, + 1).setParameterIndex(0).build() }, null); public static void main(String... args) throws Exception { diff --git a/langtools/test/tools/javac/annotations/typeAnnotations/referenceinfos/Constructors.java b/langtools/test/tools/javac/annotations/typeAnnotations/referenceinfos/Constructors.java index 2775fdd9790..78e9acab2ab 100644 --- a/langtools/test/tools/javac/annotations/typeAnnotations/referenceinfos/Constructors.java +++ b/langtools/test/tools/javac/annotations/typeAnnotations/referenceinfos/Constructors.java @@ -43,7 +43,7 @@ public class Constructors { @TADescription(annotation = "TA", type = METHOD_RETURN, genericLocation = {1, 0}) @TADescription(annotation = "TB", type = METHOD_RETURN, genericLocation = {1, 0}) - @TADescription(annotation = "TC", type = METHOD_FORMAL_PARAMETER, paramIndex = 1) + @TADescription(annotation = "TC", type = METHOD_FORMAL_PARAMETER, paramIndex = 0) @TestClass("%TEST_CLASS_NAME%$Inner") public String innerClass() { return "class %TEST_CLASS_NAME% { class Inner {" + @@ -56,7 +56,7 @@ public class Constructors { @TADescription(annotation = "TB", type = METHOD_RETURN, genericLocation = {1, 0}) @TADescription(annotation = "TC", type = METHOD_RECEIVER) @TADescription(annotation = "TD", type = METHOD_RETURN, genericLocation = {1, 0}) - @TADescription(annotation = "TE", type = METHOD_FORMAL_PARAMETER, paramIndex = 1) + @TADescription(annotation = "TE", type = METHOD_FORMAL_PARAMETER, paramIndex = 0) @TestClass("%TEST_CLASS_NAME%$Inner") public String innerClass2() { return "class %TEST_CLASS_NAME% { class Inner {" + @@ -70,7 +70,7 @@ public class Constructors { @TADescription(annotation = "TC", type = METHOD_RETURN, genericLocation = {1, 0, 1, 0}) @TADescription(annotation = "TD", type = METHOD_RECEIVER, genericLocation = {1, 0}) @TADescription(annotation = "TE", type = METHOD_RETURN, genericLocation = {1, 0, 1, 0}) - @TADescription(annotation = "TF", type = METHOD_FORMAL_PARAMETER, paramIndex = 1) + @TADescription(annotation = "TF", type = METHOD_FORMAL_PARAMETER, paramIndex = 0) @TestClass("Outer$Middle$Inner") public String innerClass3() { return "class Outer { class Middle { class Inner {" + @@ -89,7 +89,7 @@ public class Constructors { @TADescription(annotation = "RTAs", type = METHOD_RETURN, genericLocation = {1, 0}) @TADescription(annotation = "RTBs", type = METHOD_RETURN, genericLocation = {1, 0}) - @TADescription(annotation = "RTCs", type = METHOD_FORMAL_PARAMETER, paramIndex = 1) + @TADescription(annotation = "RTCs", type = METHOD_FORMAL_PARAMETER, paramIndex = 0) @TestClass("%TEST_CLASS_NAME%$Inner") public String innerClassRepeatableAnnotation() { return "class %TEST_CLASS_NAME% { class Inner {" + @@ -102,7 +102,7 @@ public class Constructors { @TADescription(annotation = "RTBs", type = METHOD_RETURN, genericLocation = {1, 0}) @TADescription(annotation = "RTCs", type = METHOD_RECEIVER) @TADescription(annotation = "RTDs", type = METHOD_RETURN, genericLocation = {1, 0}) - @TADescription(annotation = "RTEs", type = METHOD_FORMAL_PARAMETER, paramIndex = 1) + @TADescription(annotation = "RTEs", type = METHOD_FORMAL_PARAMETER, paramIndex = 0) @TestClass("%TEST_CLASS_NAME%$Inner") public String innerClassRepeatableAnnotation2() { return "class %TEST_CLASS_NAME% { class Inner {" + @@ -116,7 +116,7 @@ public class Constructors { @TADescription(annotation = "RTCs", type = METHOD_RETURN, genericLocation = {1, 0, 1, 0}) @TADescription(annotation = "RTDs", type = METHOD_RECEIVER, genericLocation = {1, 0}) @TADescription(annotation = "RTEs", type = METHOD_RETURN, genericLocation = {1, 0, 1, 0}) - @TADescription(annotation = "RTFs", type = METHOD_FORMAL_PARAMETER, paramIndex = 1) + @TADescription(annotation = "RTFs", type = METHOD_FORMAL_PARAMETER, paramIndex = 0) @TestClass("Outer$Middle$Inner") public String innerClassRepatableAnnotation3() { return "class Outer { class Middle { class Inner {" +