1 /* 2 * Copyright 2003 Sun Microsystems, Inc. All Rights Reserved. 3 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. 4 * 5 * This code is free software; you can redistribute it and/or modify it 6 * under the terms of the GNU General Public License version 2 only, as 7 * published by the Free Software Foundation. 8 * 9 * This code is distributed in the hope that it will be useful, but WITHOUT 10 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 11 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License 12 * version 2 for more details (a copy is included in the LICENSE file that 13 * accompanied this code). 14 * 15 * You should have received a copy of the GNU General Public License version 16 * 2 along with this work; if not, write to the Free Software Foundation, 17 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. 18 * 19 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, 20 * CA 95054 USA or visit www.sun.com if you need additional information or 21 * have any questions. 22 */ 23 24 /* 25 * @test 26 * @bug 4922918 27 * @summary Check supertypes and superinterfaces of parameterized types. 28 * @library ../../lib 29 * @compile ../../lib/Tester.java Main.java 30 * @run main Main 31 */ 32 33 import java.io.IOException; 34 import java.util.Comparator; 35 import java.util.Arrays; 36 import com.sun.javadoc.*; 37 38 public class Main extends Tester.Doclet { 39 40 private static final Tester tester = new Tester("Main", "pkg1"); 41 42 public static void main(String[] args) throws IOException { 43 tester.run(); 44 tester.verify(); 45 } 46 47 public static boolean start(RootDoc root) { 48 try { 49 ClassDoc[] cds = root.classes(); 50 Arrays.sort(cds); 51 for (ClassDoc cd : cds) { 52 ParameterizedType arrayList = 53 cd.superclassType().asParameterizedType(); 54 tester.println(arrayList); 55 tester.println(); 56 57 tester.println(arrayList.superclassType()); 58 Type[] interfaces = arrayList.interfaceTypes(); 59 // Sort interfaces by type name, for consistent output. 60 Arrays.sort(interfaces, 61 new Comparator<Type>() { 62 public int compare(Type t1, Type t2) { 63 String name1 = t1.qualifiedTypeName(); 64 String name2 = t2.qualifiedTypeName(); 65 return name1.compareTo(name2); 66 } 67 }); 68 for (Type t : interfaces) { 69 tester.println(t); 70 } 71 tester.println(); 72 } 73 74 return true; 75 } catch (IOException e) { 76 return false; 77 } 78 } 79 }