From d03ac9784a513318e72e0488f3fa5b5ccb93fb77 Mon Sep 17 00:00:00 2001 From: Eric McCorkle Date: Sat, 28 Sep 2013 13:46:14 -0400 Subject: [PATCH] 8025413: NPE in Type.java due to recent change IsCompound throws a NPE for noType and other types. Made it return a reasonable result instead. Reviewed-by: jjg, vromero --- .../com/sun/tools/javac/code/Type.java | 9 ++ .../processing/model/type/InheritedAP.java | 96 +++++++++++++++++++ 2 files changed, 105 insertions(+) create mode 100644 langtools/test/tools/javac/processing/model/type/InheritedAP.java diff --git a/langtools/src/share/classes/com/sun/tools/javac/code/Type.java b/langtools/src/share/classes/com/sun/tools/javac/code/Type.java index 699ac7ebedc..56e4d411ac8 100644 --- a/langtools/src/share/classes/com/sun/tools/javac/code/Type.java +++ b/langtools/src/share/classes/com/sun/tools/javac/code/Type.java @@ -1651,6 +1651,9 @@ public abstract class Type implements TypeMirror { public R accept(TypeVisitor v, P p) { return v.visitNoType(this, p); } + + @Override + public boolean isCompound() { return false; } } /** Represents VOID. @@ -1671,6 +1674,9 @@ public abstract class Type implements TypeMirror { return TypeKind.VOID; } + @Override + public boolean isCompound() { return false; } + @Override public R accept(TypeVisitor v, P p) { return v.visitNoType(this, p); @@ -1697,6 +1703,9 @@ public abstract class Type implements TypeMirror { return TypeKind.NULL; } + @Override + public boolean isCompound() { return false; } + @Override public R accept(TypeVisitor v, P p) { return v.visitNull(this, p); diff --git a/langtools/test/tools/javac/processing/model/type/InheritedAP.java b/langtools/test/tools/javac/processing/model/type/InheritedAP.java new file mode 100644 index 00000000000..d2ba37aea59 --- /dev/null +++ b/langtools/test/tools/javac/processing/model/type/InheritedAP.java @@ -0,0 +1,96 @@ +/* + * Copyright (c) 2012, 2013, 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 8024513 + * @library /tools/javac/lib + * @build InheritedAP + * @compile -cp . -processor InheritedAP -proc:only InheritedAP.java + * @summary NPE in annotation processing + */ +import java.util.*; +import javax.annotation.processing.*; +import javax.lang.model.element.*; +import javax.lang.model.type.*; +import javax.lang.model.util.*; +import java.lang.annotation.*; +import static javax.lang.model.type.TypeKind.*; +import static javax.lang.model.SourceVersion.*; +import static javax.lang.model.util.ElementFilter.*; + +@SupportedAnnotationTypes("testclass") +@SupportedSourceVersion(RELEASE_8) +public class InheritedAP extends AbstractProcessor { + static Types types; + public void init(ProcessingEnvironment penv) {super.init(penv);} + public static Types getTypes() { return types; } + + public boolean process(Set typeElementSet,RoundEnvironment renv) { + if ( renv.errorRaised()) { System.out.println("Error!"); return false; } + if ( typeElementSet.size() <=0 && typesIn(renv.getRootElements()).size() <= 0 ) { + return true; + } + types=processingEnv.getTypeUtils(); + for (TypeElement typeElem: typesIn(renv.getRootElements())) { + if (typeElem.getAnnotation(testclass.class) != null) { + new ElementScanner( new SimpleTypeMirrorVisitor()).scan(typeElem, null); + } + } + return true ; + } +} + +class SimpleTypeMirrorVisitor extends SimpleTypeVisitor6 { + protected Void defaultAction(TypeMirror mirror, Void p ) { + try { + System.out.println( "InheritedAP.getTypes().directSupertypes( "+mirror.toString()+" );" ); + InheritedAP.getTypes().directSupertypes(mirror); + System.out.println("PASS"); + }catch(java.lang.IllegalArgumentException iae) {/*stuff*/ } + return p; + } +} + +class ElementScanner > + extends ElementScanner6 { + SimpleTypeVisitor6 typeVisitor; + + public ElementScanner(T typeVisitor) { this.typeVisitor=typeVisitor;} + + @Override + public Void scan(Element e, Void p) { + if (e instanceof TypeElement ) { + TypeElement te = (TypeElement) e; + te.getSuperclass().accept(typeVisitor,p); + } + return p; + } + +} + + +@interface testclass { } + +@testclass +@interface iface { }