diff --git a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/AbstractMemberWriter.java b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/AbstractMemberWriter.java index 0bbb6e4b392..943a7af66ee 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/AbstractMemberWriter.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/AbstractMemberWriter.java @@ -345,18 +345,18 @@ public abstract class AbstractMemberWriter { /** * Print use info. */ - protected void printUseInfo(Object mems, String heading) { + protected void printUseInfo(List mems, String heading) { if (mems == null) { return; } - List members = (List)mems; + List members = mems; if (members.size() > 0) { writer.tableIndexSummary(); writer.tableUseInfoHeaderStart("#CCCCFF"); writer.print(heading); writer.tableHeaderEnd(); - for (Iterator it = members.iterator(); it.hasNext(); ) { - ProgramElementDoc pgmdoc = (ProgramElementDoc)it.next(); + for (Iterator it = members.iterator(); it.hasNext(); ) { + ProgramElementDoc pgmdoc = it.next(); ClassDoc cd = pgmdoc.containingClass(); writer.printSummaryLinkType(this, pgmdoc); diff --git a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ClassUseWriter.java b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ClassUseWriter.java index 713dce1e88f..ca1f32543d3 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ClassUseWriter.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ClassUseWriter.java @@ -39,28 +39,28 @@ public class ClassUseWriter extends SubWriterHolderWriter { final ClassDoc classdoc; Set pkgToPackageAnnotations = null; - final Map pkgToClassTypeParameter; - final Map pkgToClassAnnotations; - final Map pkgToMethodTypeParameter; - final Map pkgToMethodArgTypeParameter; - final Map pkgToMethodReturnTypeParameter; - final Map pkgToMethodAnnotations; - final Map pkgToMethodParameterAnnotations; - final Map pkgToFieldTypeParameter; - final Map pkgToFieldAnnotations; - final Map pkgToSubclass; - final Map pkgToSubinterface; - final Map pkgToImplementingClass; - final Map pkgToField; - final Map pkgToMethodReturn; - final Map pkgToMethodArgs; - final Map pkgToMethodThrows; - final Map pkgToConstructorAnnotations; - final Map pkgToConstructorParameterAnnotations; - final Map pkgToConstructorArgs; - final Map pkgToConstructorArgTypeParameter; - final Map pkgToConstructorThrows; - final SortedSet pkgSet; + final Map> pkgToClassTypeParameter; + final Map> pkgToClassAnnotations; + final Map> pkgToMethodTypeParameter; + final Map> pkgToMethodArgTypeParameter; + final Map> pkgToMethodReturnTypeParameter; + final Map> pkgToMethodAnnotations; + final Map> pkgToMethodParameterAnnotations; + final Map> pkgToFieldTypeParameter; + final Map> pkgToFieldAnnotations; + final Map> pkgToSubclass; + final Map> pkgToSubinterface; + final Map> pkgToImplementingClass; + final Map> pkgToField; + final Map> pkgToMethodReturn; + final Map> pkgToMethodArgs; + final Map> pkgToMethodThrows; + final Map> pkgToConstructorAnnotations; + final Map> pkgToConstructorParameterAnnotations; + final Map> pkgToConstructorArgs; + final Map> pkgToConstructorArgTypeParameter; + final Map> pkgToConstructorThrows; + final SortedSet pkgSet; final MethodWriterImpl methodSubWriter; final ConstructorWriterImpl constrSubWriter; final FieldWriterImpl fieldSubWriter; @@ -81,9 +81,9 @@ public class ClassUseWriter extends SubWriterHolderWriter { super(configuration, path, filename, relpath); this.classdoc = classdoc; if (mapper.classToPackageAnnotations.containsKey(classdoc.qualifiedName())) - pkgToPackageAnnotations = new HashSet((List) mapper.classToPackageAnnotations.get(classdoc.qualifiedName())); + pkgToPackageAnnotations = new HashSet(mapper.classToPackageAnnotations.get(classdoc.qualifiedName())); configuration.currentcd = classdoc; - this.pkgSet = new TreeSet(); + this.pkgSet = new TreeSet(); this.pkgToClassTypeParameter = pkgDivide(mapper.classToClassTypeParam); this.pkgToClassAnnotations = pkgDivide(mapper.classToClassAnnotations); this.pkgToMethodTypeParameter = pkgDivide(mapper.classToExecMemberDocTypeParam); @@ -135,19 +135,19 @@ public class ClassUseWriter extends SubWriterHolderWriter { } } - private Map pkgDivide(Map classMap) { - Map map = new HashMap(); - List list= (List)classMap.get(classdoc.qualifiedName()); + private Map> pkgDivide(Map> classMap) { + Map> map = new HashMap>(); + List list= classMap.get(classdoc.qualifiedName()); if (list != null) { Collections.sort(list); - Iterator it = list.iterator(); + Iterator it = list.iterator(); while (it.hasNext()) { - ProgramElementDoc doc = (ProgramElementDoc)it.next(); + ProgramElementDoc doc = it.next(); PackageDoc pkg = doc.containingPackage(); pkgSet.add(pkg); - List inPkg = (List)map.get(pkg.name()); + List inPkg = map.get(pkg.name()); if (inPkg == null) { - inPkg = new ArrayList(); + inPkg = new ArrayList(); map.put(pkg.name(), inPkg); } inPkg.add(doc); diff --git a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ConfigurationImpl.java b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ConfigurationImpl.java index 4ea6d38c13f..98c27bfb4eb 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ConfigurationImpl.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ConfigurationImpl.java @@ -253,7 +253,7 @@ public class ConfigurationImpl extends Configuration { } } if (root.specifiedClasses().length > 0) { - Map map = new HashMap(); + Map map = new HashMap(); PackageDoc pd; ClassDoc[] classes = root.classes(); for (int i = 0; i < classes.length; i++) { @@ -481,7 +481,7 @@ public class ConfigurationImpl extends Configuration { /** * {@inheritDoc} */ - public Comparator getMemberComparator() { + public Comparator getMemberComparator() { return null; } } diff --git a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ConstantsSummaryWriterImpl.java b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ConstantsSummaryWriterImpl.java index 24cefb2e896..7237638920e 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ConstantsSummaryWriterImpl.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ConstantsSummaryWriterImpl.java @@ -107,7 +107,7 @@ public class ConstantsSummaryWriterImpl extends HtmlDocletWriter /** * {@inheritDoc} */ - public void writeLinkToPackageContent(PackageDoc pkg, String parsedPackageName, Set printedPackageHeaders) { + public void writeLinkToPackageContent(PackageDoc pkg, String parsedPackageName, Set printedPackageHeaders) { String packageName = pkg.name(); //add link to summary li(); diff --git a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ConstructorWriterImpl.java b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ConstructorWriterImpl.java index 979553e77cf..b219876b6cd 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ConstructorWriterImpl.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/ConstructorWriterImpl.java @@ -55,10 +55,10 @@ public class ConstructorWriterImpl extends AbstractExecutableMemberWriter super(writer, classDoc); VisibleMemberMap visibleMemberMap = new VisibleMemberMap(classDoc, VisibleMemberMap.CONSTRUCTORS, configuration().nodeprecated); - List constructors = new ArrayList(visibleMemberMap.getMembersFor(classDoc)); + List constructors = new ArrayList(visibleMemberMap.getMembersFor(classDoc)); for (int i = 0; i < constructors.size(); i++) { - if (((ProgramElementDoc)(constructors.get(i))).isProtected() || - ((ProgramElementDoc)(constructors.get(i))).isPrivate()) { + if ((constructors.get(i)).isProtected() || + (constructors.get(i)).isPrivate()) { setFoundNonPubConstructor(true); } } diff --git a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/HtmlDocletWriter.java b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/HtmlDocletWriter.java index 8a08253c6f2..67ce9bb4665 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/HtmlDocletWriter.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/HtmlDocletWriter.java @@ -1463,7 +1463,7 @@ public class HtmlDocletWriter extends HtmlDocWriter { int originalLength = result.length(); TagletOutput output = TagletWriter.getInlineTagOuput( configuration.tagletManager, holderTag, - (Tag) tagelem, getTagletWriterInstance(isFirstSentence)); + tagelem, getTagletWriterInstance(isFirstSentence)); result.append(output == null ? "" : output.toString()); if (originalLength == 0 && isFirstSentence && tagelem.name().equals("@inheritDoc") && result.length() > 0) { break; @@ -1750,8 +1750,8 @@ public class HtmlDocletWriter extends HtmlDocWriter { * @return an array of strings representing the annotations being * documented. */ - private List getAnnotations(int indent, AnnotationDesc[] descList, boolean linkBreak) { - List results = new ArrayList(); + private List getAnnotations(int indent, AnnotationDesc[] descList, boolean linkBreak) { + List results = new ArrayList(); StringBuffer annotation; for (int i = 0; i < descList.length; i++) { AnnotationTypeDoc annotationDoc = descList[i].annotationType(); @@ -1781,7 +1781,7 @@ public class HtmlDocletWriter extends HtmlDocWriter { pairs[j].element(), pairs[j].element().name(), false)); annotation.append('='); AnnotationValue annotationValue = pairs[j].value(); - List annotationTypeValues = new ArrayList(); + List annotationTypeValues = new ArrayList(); if (annotationValue.value() instanceof AnnotationValue[]) { AnnotationValue[] annotationArray = (AnnotationValue[]) annotationValue.value(); diff --git a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/HtmlSerialMethodWriter.java b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/HtmlSerialMethodWriter.java index 3f8eb66d804..b14a8855e9d 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/HtmlSerialMethodWriter.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/HtmlSerialMethodWriter.java @@ -90,7 +90,7 @@ public class HtmlSerialMethodWriter extends MethodWriterImpl implements tagletManager.getSerializedFormTags(), writer.getTagletWriterInstance(false), output); print(output.toString()); - MethodDoc method = (MethodDoc)member; + MethodDoc method = member; if (method.name().compareTo("writeExternal") == 0 && method.tags("serialData").length == 0) { serialWarning(member.position(), "doclet.MissingSerialDataTag", diff --git a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/PackageFrameWriter.java b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/PackageFrameWriter.java index 2a5da68ca2b..0f78a41408b 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/PackageFrameWriter.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/PackageFrameWriter.java @@ -73,7 +73,7 @@ public class PackageFrameWriter extends HtmlDocletWriter { super(configuration, DirectoryManager.getDirectoryPath(packageDoc), OUTPUT_FILE_NAME, DirectoryManager.getRelativePath(packageDoc)); this.packageDoc = packageDoc; if (configuration.root.specifiedPackages().length == 0) { - documentedClasses = new HashSet(Arrays.asList(configuration.root.classes())); + documentedClasses = new HashSet(Arrays.asList(configuration.root.classes())); } } diff --git a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/PackageIndexWriter.java b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/PackageIndexWriter.java index b794d3e72c9..ea100178570 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/PackageIndexWriter.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/PackageIndexWriter.java @@ -49,7 +49,7 @@ public class PackageIndexWriter extends AbstractPackageIndexWriter { * * @see Group */ - private Map groupPackageMap; + private Map> groupPackageMap; /** * List to store the order groups as specified on the command line. @@ -120,10 +120,9 @@ public class PackageIndexWriter extends AbstractPackageIndexWriter { protected void generateIndex() { for (int i = 0; i < groupList.size(); i++) { String groupname = (String)groupList.get(i); - List list = (List)groupPackageMap.get(groupname); + List list = groupPackageMap.get(groupname); if (list != null && list.size() > 0) { - printIndexContents((PackageDoc[])list. - toArray(new PackageDoc[list.size()]), + printIndexContents(list.toArray(new PackageDoc[list.size()]), groupname); } } diff --git a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/PackageUseWriter.java b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/PackageUseWriter.java index c16ce6d7483..ccece091ecf 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/formats/html/PackageUseWriter.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/formats/html/PackageUseWriter.java @@ -38,7 +38,7 @@ import java.util.*; public class PackageUseWriter extends SubWriterHolderWriter { final PackageDoc pkgdoc; - final SortedMap usingPackageToUsedClasses = new TreeMap(); + final SortedMap> usingPackageToUsedClasses = new TreeMap>(); /** * Constructor. @@ -61,15 +61,15 @@ public class PackageUseWriter extends SubWriterHolderWriter { ClassDoc[] content = pkgdoc.allClasses(); for (int i = 0; i < content.length; ++i) { ClassDoc usedClass = content[i]; - Set usingClasses = (Set)mapper.classToClass.get(usedClass.qualifiedName()); + Set usingClasses = mapper.classToClass.get(usedClass.qualifiedName()); if (usingClasses != null) { for (Iterator it = usingClasses.iterator(); it.hasNext(); ) { ClassDoc usingClass = (ClassDoc)it.next(); PackageDoc usingPackage = usingClass.containingPackage(); - Set usedClasses = (Set)usingPackageToUsedClasses + Set usedClasses = usingPackageToUsedClasses .get(usingPackage.name()); if (usedClasses == null) { - usedClasses = new TreeSet(); + usedClasses = new TreeSet(); usingPackageToUsedClasses.put(Util.getPackageName(usingPackage), usedClasses); } diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/Configuration.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/Configuration.java index 794c5c6d044..fdefbc4d43d 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/Configuration.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/Configuration.java @@ -120,12 +120,12 @@ public abstract class Configuration { /** * The list of doc-file subdirectories to exclude */ - protected Set excludedDocFileDirs; + protected Set excludedDocFileDirs; /** * The list of qualifiers to exclude */ - protected Set excludedQualifiers; + protected Set excludedQualifiers; /** * The Root of the generated Program Structure from the Doclet API. @@ -255,8 +255,8 @@ public abstract class Configuration { message = new MessageRetriever(this, "com.sun.tools.doclets.internal.toolkit.resources.doclets"); - excludedDocFileDirs = new HashSet(); - excludedQualifiers = new HashSet(); + excludedDocFileDirs = new HashSet(); + excludedQualifiers = new HashSet(); } /** @@ -329,14 +329,14 @@ public abstract class Configuration { DocErrorReporter reporter); private void initPackageArray() { - Set set = new HashSet(Arrays.asList(root.specifiedPackages())); + Set set = new HashSet(Arrays.asList(root.specifiedPackages())); ClassDoc[] classes = root.specifiedClasses(); for (int i = 0; i < classes.length; i++) { set.add(classes[i].containingPackage()); } - ArrayList results = new ArrayList(set); + ArrayList results = new ArrayList(set); Collections.sort(results); - packages = (PackageDoc[]) results.toArray(new PackageDoc[] {}); + packages = results.toArray(new PackageDoc[] {}); } /** @@ -345,7 +345,7 @@ public abstract class Configuration { * @param options the two dimensional array of options. */ public void setOptions(String[][] options) { - LinkedHashSet customTagStrs = new LinkedHashSet(); + LinkedHashSet customTagStrs = new LinkedHashSet(); for (int oi = 0; oi < options.length; ++oi) { String[] os = options[oi]; String opt = os[0].toLowerCase(); @@ -476,7 +476,7 @@ public abstract class Configuration { } } - private void addToSet(Set s, String str){ + private void addToSet(Set s, String str){ StringTokenizer st = new StringTokenizer(str, ":"); String current; while(st.hasMoreTokens()){ @@ -712,5 +712,5 @@ public abstract class Configuration { * * @return the {@link java.util.Comparator} used to sort members. */ - public abstract Comparator getMemberComparator(); + public abstract Comparator getMemberComparator(); } diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/ConstantsSummaryWriter.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/ConstantsSummaryWriter.java index c7c944e369f..2168ec1b1ab 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/ConstantsSummaryWriter.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/ConstantsSummaryWriter.java @@ -79,7 +79,7 @@ public interface ConstantsSummaryWriter { * something more than once. */ public abstract void writeLinkToPackageContent(PackageDoc pkg, String parsedPackageName, - Set WriteedPackageHeaders); + Set WriteedPackageHeaders); /** * Write the given package name. diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AbstractBuilder.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AbstractBuilder.java index 0776f408946..a27bf737d85 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AbstractBuilder.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AbstractBuilder.java @@ -61,7 +61,7 @@ public abstract class AbstractBuilder { * efficiency purposes. We don't want to copy the * doc files multiple times for a single package. */ - protected static Set containingPackagesSeen; + protected static Set containingPackagesSeen; /** * True if we want to print debug output. diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AnnotationTypeBuilder.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AnnotationTypeBuilder.java index 959428b938f..67a6096190b 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AnnotationTypeBuilder.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AnnotationTypeBuilder.java @@ -84,7 +84,7 @@ public class AnnotationTypeBuilder extends AbstractBuilder { builder.annotationTypeDoc = annotationTypeDoc; builder.writer = writer; if(containingPackagesSeen == null) { - containingPackagesSeen = new HashSet(); + containingPackagesSeen = new HashSet(); } return builder; } diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AnnotationTypeOptionalMemberBuilder.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AnnotationTypeOptionalMemberBuilder.java index 747190897e6..511b457d2be 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AnnotationTypeOptionalMemberBuilder.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AnnotationTypeOptionalMemberBuilder.java @@ -73,7 +73,7 @@ public class AnnotationTypeOptionalMemberBuilder extends builder.writer = writer; builder.visibleMemberMap = new VisibleMemberMap(classDoc, VisibleMemberMap.ANNOTATION_TYPE_MEMBER_OPTIONAL, configuration.nodeprecated); - builder.members = new ArrayList( + builder.members = new ArrayList( builder.visibleMemberMap.getMembersFor(classDoc)); if (configuration.getMemberComparator() != null) { Collections.sort(builder.members, diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AnnotationTypeRequiredMemberBuilder.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AnnotationTypeRequiredMemberBuilder.java index b92b8b42c5e..98b5278f551 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AnnotationTypeRequiredMemberBuilder.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/AnnotationTypeRequiredMemberBuilder.java @@ -62,7 +62,7 @@ public class AnnotationTypeRequiredMemberBuilder extends AbstractMemberBuilder { /** * The list of members being documented. */ - protected List members; + protected List members; /** * The index of the current member that is being documented at this point @@ -97,7 +97,7 @@ public class AnnotationTypeRequiredMemberBuilder extends AbstractMemberBuilder { builder.writer = writer; builder.visibleMemberMap = new VisibleMemberMap(classDoc, VisibleMemberMap.ANNOTATION_TYPE_MEMBER_REQUIRED, configuration.nodeprecated); - builder.members = new ArrayList( + builder.members = new ArrayList( builder.visibleMemberMap.getMembersFor(classDoc)); if (configuration.getMemberComparator() != null) { Collections.sort(builder.members, diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/ClassBuilder.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/ClassBuilder.java index e37f6426005..3c287a3473d 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/ClassBuilder.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/ClassBuilder.java @@ -100,7 +100,7 @@ public class ClassBuilder extends AbstractBuilder { Util.setEnumDocumentation(configuration, classDoc); } if(containingPackagesSeen == null) { - containingPackagesSeen = new HashSet(); + containingPackagesSeen = new HashSet(); } return builder; } diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/ConstantsSummaryBuilder.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/ConstantsSummaryBuilder.java index 746c44013d4..eaf3f11464f 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/ConstantsSummaryBuilder.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/ConstantsSummaryBuilder.java @@ -63,12 +63,12 @@ public class ConstantsSummaryBuilder extends AbstractBuilder { /** * The set of ClassDocs that have constant fields. */ - protected Set classDocsWithConstFields; + protected Set classDocsWithConstFields; /** * The set of printed package headers. */ - protected Set printedPackageHeaders; + protected Set printedPackageHeaders; /** * The current package being documented. @@ -102,7 +102,7 @@ public class ConstantsSummaryBuilder extends AbstractBuilder { ConstantsSummaryBuilder builder = new ConstantsSummaryBuilder( configuration); builder.writer = writer; - builder.classDocsWithConstFields = new HashSet(); + builder.classDocsWithConstFields = new HashSet(); return builder; } @@ -169,7 +169,7 @@ public class ConstantsSummaryBuilder extends AbstractBuilder { public void buildContents() { writer.writeContentsHeader(); PackageDoc[] packages = configuration.packages; - printedPackageHeaders = new HashSet(); + printedPackageHeaders = new HashSet(); for (int i = 0; i < packages.length; i++) { if (hasConstantField(packages[i]) && ! hasPrintedPackageIndex(packages[i].name())) { writer.writeLinkToPackageContent(packages[i], @@ -188,7 +188,7 @@ public class ConstantsSummaryBuilder extends AbstractBuilder { */ public void buildConstantSummaries(List elements) { PackageDoc[] packages = configuration.packages; - printedPackageHeaders = new HashSet(); + printedPackageHeaders = new HashSet(); for (int i = 0; i < packages.length; i++) { if (hasConstantField(packages[i])) { currentPackage = packages[i]; @@ -315,7 +315,7 @@ public class ConstantsSummaryBuilder extends AbstractBuilder { * @param pkgname the name of the package to check. */ private boolean hasPrintedPackageIndex(String pkgname) { - String[] list = (String[])printedPackageHeaders.toArray(new String[] {}); + String[] list = printedPackageHeaders.toArray(new String[] {}); for (int i = 0; i < list.length; i++) { if (pkgname.startsWith(list[i])) { return true; @@ -363,7 +363,7 @@ public class ConstantsSummaryBuilder extends AbstractBuilder { * Builds the table of constants for a given class. */ protected void buildMembersSummary() { - List members = new ArrayList(members()); + List members = new ArrayList(members()); if (members.size() > 0) { Collections.sort(members); writer.writeConstantMembers(classdoc, members); @@ -375,17 +375,17 @@ public class ConstantsSummaryBuilder extends AbstractBuilder { * @param cd the classdoc to examine. * @return the list of visible constant fields for the given classdoc. */ - protected List members() { - List l = visibleMemberMapFields.getLeafClassMembers(configuration); + protected List members() { + List l = visibleMemberMapFields.getLeafClassMembers(configuration); l.addAll(visibleMemberMapEnumConst.getLeafClassMembers(configuration)); - Iterator iter; + Iterator iter; if(l != null){ iter = l.iterator(); } else { return null; } - List inclList = new LinkedList(); + List inclList = new LinkedList(); FieldDoc member; while(iter.hasNext()){ member = (FieldDoc)iter.next(); diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/ConstructorBuilder.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/ConstructorBuilder.java index 8e4dc812e7c..d7e2a8c46ac 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/ConstructorBuilder.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/ConstructorBuilder.java @@ -72,7 +72,7 @@ public class ConstructorBuilder extends AbstractMemberBuilder { /** * The constructors being documented. */ - private List constructors; + private List constructors; /** * Construct a new ConstructorBuilder. @@ -104,12 +104,10 @@ public class ConstructorBuilder extends AbstractMemberBuilder { VisibleMemberMap.CONSTRUCTORS, configuration.nodeprecated); builder.constructors = - new ArrayList(builder.visibleMemberMap.getMembersFor(classDoc)); + new ArrayList(builder.visibleMemberMap.getMembersFor(classDoc)); for (int i = 0; i < builder.constructors.size(); i++) { - if (((ProgramElementDoc) (builder.constructors.get(i))) - .isProtected() - || ((ProgramElementDoc) (builder.constructors.get(i))) - .isPrivate()) { + if (builder.constructors.get(i).isProtected() + || builder.constructors.get(i).isPrivate()) { writer.setFoundNonPubConstructor(true); } } diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/EnumConstantBuilder.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/EnumConstantBuilder.java index bfba89bed92..f9bb17f84ae 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/EnumConstantBuilder.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/EnumConstantBuilder.java @@ -61,7 +61,7 @@ public class EnumConstantBuilder extends AbstractMemberBuilder { /** * The list of enum constants being documented. */ - private List enumConstants; + private List enumConstants; /** * The index of the current enum constant that is being documented at this point @@ -99,7 +99,7 @@ public class EnumConstantBuilder extends AbstractMemberBuilder { VisibleMemberMap.ENUM_CONSTANTS, configuration.nodeprecated); builder.enumConstants = - new ArrayList(builder.visibleMemberMap.getMembersFor(classDoc)); + new ArrayList(builder.visibleMemberMap.getMembersFor(classDoc)); if (configuration.getMemberComparator() != null) { Collections.sort( builder.enumConstants, diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/FieldBuilder.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/FieldBuilder.java index 87b4a02d7ff..cfa53f0f7bf 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/FieldBuilder.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/FieldBuilder.java @@ -61,7 +61,7 @@ public class FieldBuilder extends AbstractMemberBuilder { /** * The list of fields being documented. */ - private List fields; + private List fields; /** * The index of the current field that is being documented at this point @@ -99,8 +99,8 @@ public class FieldBuilder extends AbstractMemberBuilder { VisibleMemberMap.FIELDS, configuration.nodeprecated); builder.fields = - new ArrayList(builder.visibleMemberMap.getLeafClassMembers( - configuration)); + new ArrayList(builder.visibleMemberMap.getLeafClassMembers( + configuration)); if (configuration.getMemberComparator() != null) { Collections.sort( builder.fields, diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/LayoutParser.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/LayoutParser.java index 43f208302f6..8cca83d98d2 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/LayoutParser.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/LayoutParser.java @@ -45,7 +45,7 @@ public class LayoutParser extends DefaultHandler { /** * The map of XML elements that have been parsed. */ - private Map xmlElementsMap; + private Map> xmlElementsMap; private Configuration configuration; private static LayoutParser instance; @@ -56,7 +56,7 @@ public class LayoutParser extends DefaultHandler { * This class is a singleton. */ private LayoutParser(Configuration configuration) { - xmlElementsMap = new HashMap(); + xmlElementsMap = new HashMap>(); this.configuration = configuration; } @@ -83,7 +83,7 @@ public class LayoutParser extends DefaultHandler { return (List) xmlElementsMap.get(root); } try { - List xmlElements = new ArrayList(); + List xmlElements = new ArrayList(); xmlElementsMap.put(root, xmlElements); currentRoot = root; isParsing = false; @@ -106,7 +106,7 @@ public class LayoutParser extends DefaultHandler { throws SAXException { if (isParsing || qName.equals(currentRoot)) { isParsing = true; - List xmlElements = (List) xmlElementsMap.get(currentRoot); + List xmlElements = xmlElementsMap.get(currentRoot); xmlElements.add(qName); } } @@ -120,11 +120,11 @@ public class LayoutParser extends DefaultHandler { isParsing = false; return; } - List xmlElements = (List) xmlElementsMap.get(currentRoot); + List xmlElements = xmlElementsMap.get(currentRoot); if (xmlElements.get(xmlElements.size()-1).equals(qName)) { return; } else { - List subElements = new ArrayList(); + List subElements = new ArrayList(); int targetIndex = xmlElements.indexOf(qName); int size = xmlElements.size(); for (int i = targetIndex; i < size; i++) { diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/MemberSummaryBuilder.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/MemberSummaryBuilder.java index 86c8d9a5d9b..c375772b648 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/MemberSummaryBuilder.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/MemberSummaryBuilder.java @@ -306,13 +306,13 @@ public class MemberSummaryBuilder extends AbstractMemberBuilder { */ private void buildSummary(MemberSummaryWriter writer, VisibleMemberMap visibleMemberMap) { - List members = new ArrayList(visibleMemberMap.getLeafClassMembers( + List members = new ArrayList(visibleMemberMap.getLeafClassMembers( configuration)); if (members.size() > 0) { Collections.sort(members); writer.writeMemberSummaryHeader(classDoc); for (int i = 0; i < members.size(); i++) { - ProgramElementDoc member = (ProgramElementDoc) members.get(i); + ProgramElementDoc member = members.get(i); Tag[] firstSentenceTags = member.firstSentenceTags(); if (member instanceof MethodDoc && firstSentenceTags.length == 0) { //Inherit comments from overriden or implemented method if @@ -349,7 +349,7 @@ public class MemberSummaryBuilder extends AbstractMemberBuilder { if (inhclass == classDoc) { continue; } - List inhmembers = visibleMemberMap.getMembersFor(inhclass); + List inhmembers = visibleMemberMap.getMembersFor(inhclass); if (inhmembers.size() > 0) { Collections.sort(inhmembers); writer.writeInheritedMemberSummaryHeader(inhclass); @@ -358,7 +358,7 @@ public class MemberSummaryBuilder extends AbstractMemberBuilder { inhclass.isPackagePrivate() && ! Util.isLinkable(inhclass, configuration) ? classDoc : inhclass, - (ProgramElementDoc) inhmembers.get(j), + inhmembers.get(j), j == 0, j == inhmembers.size() - 1); } diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/MethodBuilder.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/MethodBuilder.java index 1f00adc275f..41531a0a4dd 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/MethodBuilder.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/builders/MethodBuilder.java @@ -66,7 +66,7 @@ public class MethodBuilder extends AbstractMemberBuilder { /** * The methods being documented. */ - private List methods; + private List methods; private MethodBuilder(Configuration configuration) { super(configuration); @@ -94,7 +94,7 @@ public class MethodBuilder extends AbstractMemberBuilder { VisibleMemberMap.METHODS, configuration.nodeprecated); builder.methods = - new ArrayList(builder.visibleMemberMap.getLeafClassMembers( + new ArrayList(builder.visibleMemberMap.getLeafClassMembers( configuration)); if (configuration.getMemberComparator() != null) { Collections.sort( diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/CodeTaglet.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/CodeTaglet.java index 63e10aa0daf..e1db9dc7966 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/CodeTaglet.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/CodeTaglet.java @@ -26,6 +26,7 @@ package com.sun.tools.doclets.internal.toolkit.taglets; import java.util.Map; import com.sun.javadoc.Tag; +import com.sun.tools.doclets.Taglet; /** * An inline Taglet used to denote literal code fragments. @@ -47,7 +48,7 @@ public class CodeTaglet extends LiteralTaglet { private static final String NAME = "code"; - public static void register(Map map) { + public static void register(Map map) { map.remove(NAME); map.put(NAME, new CodeTaglet()); } diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/LiteralTaglet.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/LiteralTaglet.java index 9a5341fd492..db7cbe788fe 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/LiteralTaglet.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/LiteralTaglet.java @@ -46,7 +46,7 @@ public class LiteralTaglet implements Taglet { private static final String NAME = "literal"; - public static void register(Map map) { + public static void register(Map map) { map.remove(NAME); map.put(NAME, new LiteralTaglet()); } diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/ParamTaglet.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/ParamTaglet.java index 2159f3c7ab9..a53112f7817 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/ParamTaglet.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/ParamTaglet.java @@ -56,11 +56,11 @@ public class ParamTaglet extends BaseTaglet implements InheritableTaglet { * check. * @return a name-rank number map. */ - private static Map getRankMap(Object[] params){ + private static Map getRankMap(Object[] params){ if (params == null) { return null; } - HashMap result = new HashMap(); + HashMap result = new HashMap(); for (int i = 0; i < params.length; i++) { String name = params[i] instanceof Parameter ? ((Parameter) params[i]).name() : @@ -192,7 +192,7 @@ public class ParamTaglet extends BaseTaglet implements InheritableTaglet { private TagletOutput getTagletOutput(boolean isNonTypeParams, Doc holder, TagletWriter writer, Object[] formalParameters, ParamTag[] paramTags) { TagletOutput result = writer.getOutputInstance(); - Set alreadyDocumented = new HashSet(); + Set alreadyDocumented = new HashSet(); if (paramTags.length > 0) { result.appendOutput( processParamTags(isNonTypeParams, paramTags, @@ -214,7 +214,7 @@ public class ParamTaglet extends BaseTaglet implements InheritableTaglet { */ private TagletOutput getInheritedTagletOutput(boolean isNonTypeParams, Doc holder, TagletWriter writer, Object[] formalParameters, - Set alreadyDocumented) { + Set alreadyDocumented) { TagletOutput result = writer.getOutputInstance(); if ((! alreadyDocumented.contains(null)) && holder instanceof MethodDoc) { @@ -263,7 +263,7 @@ public class ParamTaglet extends BaseTaglet implements InheritableTaglet { */ private TagletOutput processParamTags(boolean isNonTypeParams, ParamTag[] paramTags, Map rankMap, TagletWriter writer, - Set alreadyDocumented) { + Set alreadyDocumented) { TagletOutput result = writer.getOutputInstance(); if (paramTags.length > 0) { for (int i = 0; i < paramTags.length; ++i) { diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/TagletManager.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/TagletManager.java index 33d7c98a828..d04045704ab 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/TagletManager.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/TagletManager.java @@ -61,7 +61,7 @@ public class TagletManager { /** * The map of custom tags. */ - private LinkedHashMap customTags; + private LinkedHashMap customTags; /** * The array of custom tags that can appear in packages. @@ -111,31 +111,31 @@ public class TagletManager { /** * Keep track of standard tags. */ - private Set standardTags; + private Set standardTags; /** * Keep track of standard tags in lowercase to compare for better * error messages when a tag like @docRoot is mistakenly spelled * lowercase @docroot. */ - private Set standardTagsLowercase; + private Set standardTagsLowercase; /** * Keep track of overriden standard tags. */ - private Set overridenStandardTags; + private Set overridenStandardTags; /** * Keep track of the tags that may conflict * with standard tags in the future (any custom tag without * a period in its name). */ - private Set potentiallyConflictingTags; + private Set potentiallyConflictingTags; /** * The set of unseen custom tags. */ - private Set unseenCustomTags; + private Set unseenCustomTags; /** * True if we do not want to use @since tags. @@ -161,12 +161,12 @@ public class TagletManager { */ public TagletManager(boolean nosince, boolean showversion, boolean showauthor, MessageRetriever message){ - overridenStandardTags = new HashSet(); - potentiallyConflictingTags = new HashSet(); - standardTags = new HashSet(); - standardTagsLowercase = new HashSet(); - unseenCustomTags = new HashSet(); - customTags = new LinkedHashMap(); + overridenStandardTags = new HashSet(); + potentiallyConflictingTags = new HashSet(); + standardTags = new HashSet(); + standardTagsLowercase = new HashSet(); + unseenCustomTags = new HashSet(); + customTags = new LinkedHashMap(); this.nosince = nosince; this.showversion = showversion; this.showauthor = showauthor; @@ -201,7 +201,7 @@ public class TagletManager { */ public void addCustomTag(String classname, String tagletPath) { try { - Class customTagClass = null; + Class customTagClass = null; // construct class loader String cpString = null; // make sure env.class.path defaults to dot @@ -219,7 +219,7 @@ public class TagletManager { meth.invoke(null, new Object[] {customTags}); list = customTags.values().toArray(); Object newLastTag = (list != null&& list.length > 0) - ? (Object) list[list.length-1] : null; + ? list[list.length-1] : null; if (lastTag != newLastTag) { //New taglets must always be added to the end of the LinkedHashMap. //If the current and previous last taglet are not equal, that @@ -315,7 +315,7 @@ public class TagletManager { if (tagName == null || locations == null) { return; } - Taglet tag = (Taglet) customTags.get(tagName); + Taglet tag = customTags.get(tagName); locations = locations.toLowerCase(); if (tag == null || header != null) { customTags.remove(tagName); @@ -396,7 +396,7 @@ public class TagletManager { } } //Check if this tag is being used in the wrong location. - if((taglet = (Taglet) customTags.get(name)) != null) { + if ((taglet = customTags.get(name)) != null) { if (areInlineTags && ! taglet.isInlineTag()) { printTagMisuseWarn(taglet, tags[i], "inline"); } @@ -425,7 +425,7 @@ public class TagletManager { * @param holderType the type of documentation that the misused tag was found in. */ private void printTagMisuseWarn(Taglet taglet, Tag tag, String holderType) { - Set locationsSet = new LinkedHashSet(); + Set locationsSet = new LinkedHashSet(); if (taglet.inOverview()) { locationsSet.add("overview"); } @@ -447,7 +447,7 @@ public class TagletManager { if (taglet.isInlineTag()) { locationsSet.add("inline text"); } - String[] locations = (String[]) locationsSet.toArray(new String[]{}); + String[] locations = locationsSet.toArray(new String[]{}); if (locations == null || locations.length == 0) { //This known tag is excluded. return; @@ -592,17 +592,17 @@ public class TagletManager { * Initialize the custom tag arrays. */ private void initCustomTagArrays() { - Iterator it = customTags.values().iterator(); - ArrayList pTags = new ArrayList(customTags.size()); - ArrayList tTags = new ArrayList(customTags.size()); - ArrayList fTags = new ArrayList(customTags.size()); - ArrayList cTags = new ArrayList(customTags.size()); - ArrayList mTags = new ArrayList(customTags.size()); - ArrayList iTags = new ArrayList(customTags.size()); - ArrayList oTags = new ArrayList(customTags.size()); + Iterator it = customTags.values().iterator(); + ArrayList pTags = new ArrayList(customTags.size()); + ArrayList tTags = new ArrayList(customTags.size()); + ArrayList fTags = new ArrayList(customTags.size()); + ArrayList cTags = new ArrayList(customTags.size()); + ArrayList mTags = new ArrayList(customTags.size()); + ArrayList iTags = new ArrayList(customTags.size()); + ArrayList oTags = new ArrayList(customTags.size()); Taglet current; while (it.hasNext()) { - current = (Taglet) it.next(); + current = it.next(); if (current.inPackage() && !current.isInlineTag()) { pTags.add(current); } @@ -625,20 +625,20 @@ public class TagletManager { oTags.add(current); } } - packageTags = (Taglet[]) pTags.toArray(new Taglet[] {}); - typeTags = (Taglet[]) tTags.toArray(new Taglet[] {}); - fieldTags = (Taglet[]) fTags.toArray(new Taglet[] {}); - constructorTags = (Taglet[]) cTags.toArray(new Taglet[] {}); - methodTags = (Taglet[]) mTags.toArray(new Taglet[] {}); - overviewTags = (Taglet[]) oTags.toArray(new Taglet[] {}); - inlineTags = (Taglet[]) iTags.toArray(new Taglet[] {}); + packageTags = pTags.toArray(new Taglet[] {}); + typeTags = tTags.toArray(new Taglet[] {}); + fieldTags = fTags.toArray(new Taglet[] {}); + constructorTags = cTags.toArray(new Taglet[] {}); + methodTags = mTags.toArray(new Taglet[] {}); + overviewTags = oTags.toArray(new Taglet[] {}); + inlineTags = iTags.toArray(new Taglet[] {}); //Init the serialized form tags serializedFormTags = new Taglet[4]; - serializedFormTags[0] = (Taglet) customTags.get("serialData"); - serializedFormTags[1] = (Taglet) customTags.get("throws"); - serializedFormTags[2] = (Taglet) customTags.get("since"); - serializedFormTags[3] = (Taglet) customTags.get("see"); + serializedFormTags[0] = customTags.get("serialData"); + serializedFormTags[1] = customTags.get("throws"); + serializedFormTags[2] = customTags.get("since"); + serializedFormTags[3] = customTags.get("see"); } /** @@ -726,10 +726,9 @@ public class TagletManager { printReportHelper("doclet.Notice_taglet_unseen", unseenCustomTags); } - private void printReportHelper(String noticeKey, Set names) { + private void printReportHelper(String noticeKey, Set names) { if (names.size() > 0) { - String[] namesArray = - (String[]) names.toArray(new String[] {}); + String[] namesArray = names.toArray(new String[] {}); String result = " "; for (int i = 0; i < namesArray.length; i++) { result += "@" + namesArray[i]; @@ -751,9 +750,9 @@ public class TagletManager { */ public Taglet getTaglet(String name) { if (name.indexOf("@") == 0) { - return (Taglet) customTags.get(name.substring(1)); + return customTags.get(name.substring(1)); } else { - return (Taglet) customTags.get(name); + return customTags.get(name); } } diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/ThrowsTaglet.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/ThrowsTaglet.java index 15e7e7924b9..5077c60315e 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/ThrowsTaglet.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/taglets/ThrowsTaglet.java @@ -82,7 +82,7 @@ public class ThrowsTaglet extends BaseExecutableMemberTaglet * Add links for exceptions that are declared but not documented. */ private TagletOutput linkToUndocumentedDeclaredExceptions( - Type[] declaredExceptionTypes, Set alreadyDocumented, + Type[] declaredExceptionTypes, Set alreadyDocumented, TagletWriter writer) { TagletOutput result = writer.getOutputInstance(); //Add links to the exceptions declared but not documented. @@ -107,11 +107,11 @@ public class ThrowsTaglet extends BaseExecutableMemberTaglet * documented. */ private TagletOutput inheritThrowsDocumentation(Doc holder, - Type[] declaredExceptionTypes, Set alreadyDocumented, + Type[] declaredExceptionTypes, Set alreadyDocumented, TagletWriter writer) { TagletOutput result = writer.getOutputInstance(); if (holder instanceof MethodDoc) { - Set declaredExceptionTags = new LinkedHashSet(); + Set declaredExceptionTags = new LinkedHashSet(); for (int j = 0; j < declaredExceptionTypes.length; j++) { DocFinder.Output inheritedDoc = DocFinder.search(new DocFinder.Input((MethodDoc) holder, this, @@ -124,7 +124,7 @@ public class ThrowsTaglet extends BaseExecutableMemberTaglet declaredExceptionTags.addAll(inheritedDoc.tagList); } result.appendOutput(throwsTagsOutput( - (ThrowsTag[]) declaredExceptionTags.toArray(new ThrowsTag[] {}), + declaredExceptionTags.toArray(new ThrowsTag[] {}), writer, alreadyDocumented, false)); } return result; @@ -137,7 +137,7 @@ public class ThrowsTaglet extends BaseExecutableMemberTaglet ExecutableMemberDoc execHolder = (ExecutableMemberDoc) holder; ThrowsTag[] tags = execHolder.throwsTags(); TagletOutput result = writer.getOutputInstance(); - HashSet alreadyDocumented = new HashSet(); + HashSet alreadyDocumented = new HashSet(); if (tags.length > 0) { result.appendOutput(throwsTagsOutput( execHolder.throwsTags(), writer, alreadyDocumented, true)); @@ -161,7 +161,7 @@ public class ThrowsTaglet extends BaseExecutableMemberTaglet * @return the TagletOutput representation of this Tag. */ protected TagletOutput throwsTagsOutput(ThrowsTag[] throwTags, - TagletWriter writer, Set alreadyDocumented, boolean allowDups) { + TagletWriter writer, Set alreadyDocumented, boolean allowDups) { TagletOutput result = writer.getOutputInstance(); if (throwTags.length > 0) { for (int i = 0; i < throwTags.length; ++i) { diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ClassDocCatalog.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ClassDocCatalog.java index 5169e169909..31c8d3f21b3 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ClassDocCatalog.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ClassDocCatalog.java @@ -49,44 +49,44 @@ import java.util.*; * Stores the set of packages that the classes specified on the command line * belong to. Note that the default package is "". */ - private Set packageSet; + private Set packageSet; /** * Stores all classes for each package */ - private Map allClasses; + private Map> allClasses; /** * Stores ordinary classes (excluding Exceptions and Errors) for each * package */ - private Map ordinaryClasses; + private Map> ordinaryClasses; /** * Stores exceptions for each package */ - private Map exceptions; + private Map> exceptions; /** * Stores enums for each package. */ - private Map enums; + private Map> enums; /** * Stores annotation types for each package. */ - private Map annotationTypes; + private Map> annotationTypes; /** * Stores errors for each package */ - private Map errors; + private Map> errors; /** * Stores interfaces for each package */ - private Map interfaces; + private Map> interfaces; /** * Construct a new ClassDocCatalog. @@ -109,14 +109,14 @@ import java.util.*; } private void init() { - allClasses = new HashMap(); - ordinaryClasses = new HashMap(); - exceptions = new HashMap(); - enums = new HashMap(); - annotationTypes = new HashMap(); - errors = new HashMap(); - interfaces = new HashMap(); - packageSet = new HashSet(); + allClasses = new HashMap>(); + ordinaryClasses = new HashMap>(); + exceptions = new HashMap>(); + enums = new HashMap>(); + annotationTypes = new HashMap>(); + errors = new HashMap>(); + interfaces = new HashMap>(); + packageSet = new HashSet(); } /** @@ -148,7 +148,7 @@ import java.util.*; * @param classdoc the ClassDoc to add to the catelog. * @param map the Map to add the ClassDoc to. */ - private void addClass(ClassDoc classdoc, Map map) { + private void addClass(ClassDoc classdoc, Map> map) { PackageDoc pkg = classdoc.containingPackage(); if (pkg.isIncluded()) { @@ -157,22 +157,22 @@ import java.util.*; return; } String key = Util.getPackageName(pkg); - Set s = (Set) map.get(key); + Set s = map.get(key); if (s == null) { packageSet.add(key); - s = new HashSet(); + s = new HashSet(); } s.add(classdoc); map.put(key, s); } - private ClassDoc[] getArray(Map m, String key) { - Set s = (Set) m.get(key); + private ClassDoc[] getArray(Map> m, String key) { + Set s = m.get(key); if (s == null) { return new ClassDoc[] {}; } else { - return (ClassDoc[]) s.toArray(new ClassDoc[] {}); + return s.toArray(new ClassDoc[] {}); } } @@ -202,7 +202,7 @@ import java.util.*; * ClassDocs for. */ public String[] packageNames() { - return (String[]) packageSet.toArray(new String[] {}); + return packageSet.toArray(new String[] {}); } /** diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ClassTree.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ClassTree.java index 20e0e0a7c43..8e1ba208f82 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ClassTree.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ClassTree.java @@ -49,35 +49,35 @@ public class ClassTree { * List of baseclasses. Contains only java.lang.Object. Can be used to get * the mapped listing of sub-classes. */ - private List baseclasses = new ArrayList(); + private List baseclasses = new ArrayList(); /** * Mapping for each Class with their SubClasses */ - private Map subclasses = new HashMap(); + private Map> subclasses = new HashMap>(); /** * List of base-interfaces. Contains list of all the interfaces who do not * have super-interfaces. Can be used to get the mapped listing of * sub-interfaces. */ - private List baseinterfaces = new ArrayList(); + private List baseinterfaces = new ArrayList(); /** * Mapping for each Interface with their SubInterfaces */ - private Map subinterfaces = new HashMap(); + private Map> subinterfaces = new HashMap>(); - private List baseEnums = new ArrayList(); - private Map subEnums = new HashMap(); + private List baseEnums = new ArrayList(); + private Map> subEnums = new HashMap>(); - private List baseAnnotationTypes = new ArrayList(); - private Map subAnnotationTypes = new HashMap(); + private List baseAnnotationTypes = new ArrayList(); + private Map> subAnnotationTypes = new HashMap>(); /** * Mapping for each Interface with classes who implement it. */ - private Map implementingclasses = new HashMap(); + private Map> implementingclasses = new HashMap>(); /** * Constructor. Build the Tree using the Root of this Javadoc run. @@ -132,7 +132,7 @@ public class ClassTree { processType(classes[i], configuration, baseclasses, subclasses); } else if (classes[i].isInterface()) { processInterface(classes[i]); - List list = (List)implementingclasses.get(classes[i]); + List list = implementingclasses.get(classes[i]); if (list != null) { Collections.sort(list); } @@ -143,11 +143,11 @@ public class ClassTree { } Collections.sort(baseinterfaces); - for (Iterator it = subinterfaces.values().iterator(); it.hasNext(); ) { - Collections.sort((List)it.next()); + for (Iterator> it = subinterfaces.values().iterator(); it.hasNext(); ) { + Collections.sort(it.next()); } - for (Iterator it = subclasses.values().iterator(); it.hasNext(); ) { - Collections.sort((List)it.next()); + for (Iterator> it = subclasses.values().iterator(); it.hasNext(); ) { + Collections.sort(it.next()); } } @@ -164,7 +164,7 @@ public class ClassTree { * @param configuration the current configurtation of the doclet. */ private void processType(ClassDoc cd, Configuration configuration, - List bases, Map subs) { + List bases, Map> subs) { ClassDoc superclass = Util.getFirstVisibleSuperClassCD(cd, configuration); if (superclass != null) { if (!add(subs, superclass, cd)) { @@ -219,10 +219,10 @@ public class ClassTree { * @param cd sub-interface to be mapped. * @returns boolean true if class added, false if class already processed. */ - private boolean add(Map map, ClassDoc superclass, ClassDoc cd) { - List list = (List)map.get(superclass); + private boolean add(Map> map, ClassDoc superclass, ClassDoc cd) { + List list = map.get(superclass); if (list == null) { - list = new ArrayList(); + list = new ArrayList(); map.put(superclass, list); } if (list.contains(cd)) { @@ -241,10 +241,10 @@ public class ClassTree { * @param cd class for which the sub-class list is requested. * @returns List Sub-Class list for the class passed. */ - private List get(Map map, ClassDoc cd) { - List list = (List)map.get(cd); + private List get(Map> map, ClassDoc cd) { + List list = map.get(cd); if (list == null) { - return new ArrayList(); + return new ArrayList(); } return list; } @@ -254,7 +254,7 @@ public class ClassTree { * * @param cd class whose sub-class list is required. */ - public List subclasses(ClassDoc cd) { + public List subclasses(ClassDoc cd) { return get(subclasses, cd); } @@ -263,7 +263,7 @@ public class ClassTree { * * @param cd interface whose sub-interface list is required. */ - public List subinterfaces(ClassDoc cd) { + public List subinterfaces(ClassDoc cd) { return get(subinterfaces, cd); } @@ -272,9 +272,9 @@ public class ClassTree { * * @param cd interface whose implementing-classes list is required. */ - public List implementingclasses(ClassDoc cd) { - List result = get(implementingclasses, cd); - List subinterfaces = allSubs(cd, false); + public List implementingclasses(ClassDoc cd) { + List result = get(implementingclasses, cd); + List subinterfaces = allSubs(cd, false); //If class x implements a subinterface of cd, then it follows //that class x implements cd. @@ -301,7 +301,7 @@ public class ClassTree { * @param isEnum true if the subclasses should be forced to come from the * enum tree. */ - public List subs(ClassDoc cd, boolean isEnum) { + public List subs(ClassDoc cd, boolean isEnum) { if (isEnum) { return get(subEnums, cd); } else if (cd.isAnnotationType()) { @@ -324,10 +324,10 @@ public class ClassTree { * @param isEnum true if the subclasses should be forced to come from the * enum tree. */ - public List allSubs(ClassDoc cd, boolean isEnum) { - List list = subs(cd, isEnum); + public List allSubs(ClassDoc cd, boolean isEnum) { + List list = subs(cd, isEnum); for (int i = 0; i < list.size(); i++) { - cd = (ClassDoc)list.get(i); + cd = list.get(i); List tlist = subs(cd, isEnum); for (int j = 0; j < tlist.size(); j++) { ClassDoc tcd = (ClassDoc)tlist.get(j); diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ClassUseMapper.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ClassUseMapper.java index 7edc0ee22b8..b9af61778eb 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ClassUseMapper.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ClassUseMapper.java @@ -46,138 +46,138 @@ public class ClassUseMapper { * Mapping of ClassDocs to set of PackageDoc used by that class. * Entries may be null. */ - public Map classToPackage = new HashMap(); + public Map> classToPackage = new HashMap>(); /** * Mapping of Annotations to set of PackageDoc that use the annotation. */ - public Map classToPackageAnnotations = new HashMap(); + public Map> classToPackageAnnotations = new HashMap>(); /** * Mapping of ClassDocs to set of ClassDoc used by that class. * Entries may be null. */ - public Map classToClass = new HashMap(); + public Map> classToClass = new HashMap>(); /** * Mapping of ClassDocs to list of ClassDoc which are direct or * indirect subclasses of that class. * Entries may be null. */ - public Map classToSubclass = new HashMap(); + public Map> classToSubclass = new HashMap>(); /** * Mapping of ClassDocs to list of ClassDoc which are direct or * indirect subinterfaces of that interface. * Entries may be null. */ - public Map classToSubinterface = new HashMap(); + public Map> classToSubinterface = new HashMap>(); /** * Mapping of ClassDocs to list of ClassDoc which implement * this interface. * Entries may be null. */ - public Map classToImplementingClass = new HashMap(); + public Map> classToImplementingClass = new HashMap>(); /** * Mapping of ClassDocs to list of FieldDoc declared as that class. * Entries may be null. */ - public Map classToField = new HashMap(); + public Map> classToField = new HashMap>(); /** * Mapping of ClassDocs to list of MethodDoc returning that class. * Entries may be null. */ - public Map classToMethodReturn = new HashMap(); + public Map> classToMethodReturn = new HashMap>(); /** * Mapping of ClassDocs to list of MethodDoc having that class * as an arg. * Entries may be null. */ - public Map classToMethodArgs = new HashMap(); + public Map> classToMethodArgs = new HashMap>(); /** * Mapping of ClassDocs to list of MethodDoc which throws that class. * Entries may be null. */ - public Map classToMethodThrows = new HashMap(); + public Map> classToMethodThrows = new HashMap>(); /** * Mapping of ClassDocs to list of ConstructorDoc having that class * as an arg. * Entries may be null. */ - public Map classToConstructorArgs = new HashMap(); + public Map> classToConstructorArgs = new HashMap>(); /** * Mapping of ClassDocs to list of ConstructorDoc which throws that class. * Entries may be null. */ - public Map classToConstructorThrows = new HashMap(); + public Map> classToConstructorThrows = new HashMap>(); /** * The mapping of AnnotationTypeDocs to constructors that use them. */ - public Map classToConstructorAnnotations = new HashMap(); + public Map> classToConstructorAnnotations = new HashMap>(); /** * The mapping of AnnotationTypeDocs to Constructor parameters that use them. */ - public Map classToConstructorParamAnnotation = new HashMap(); + public Map> classToConstructorParamAnnotation = new HashMap>(); /** * The mapping of ClassDocs to Constructor arguments that use them as type parameters. */ - public Map classToConstructorDocArgTypeParam = new HashMap(); + public Map> classToConstructorDocArgTypeParam = new HashMap>(); /** * The mapping of ClassDocs to ClassDocs that use them as type parameters. */ - public Map classToClassTypeParam = new HashMap(); + public Map> classToClassTypeParam = new HashMap>(); /** * The mapping of AnnotationTypeDocs to ClassDocs that use them. */ - public Map classToClassAnnotations = new HashMap(); + public Map> classToClassAnnotations = new HashMap>(); /** * The mapping of ClassDocs to ExecutableMemberDocs that use them as type parameters. */ - public Map classToExecMemberDocTypeParam = new HashMap(); + public Map> classToExecMemberDocTypeParam = new HashMap>(); /** * The mapping of ClassDocs to ExecutableMemberDocs arguments that use them as type parameters. */ - public Map classToExecMemberDocArgTypeParam = new HashMap(); + public Map> classToExecMemberDocArgTypeParam = new HashMap>(); /** * The mapping of AnnotationTypeDocs to ExecutableMemberDocs that use them. */ - public Map classToExecMemberDocAnnotations = new HashMap(); + public Map> classToExecMemberDocAnnotations = new HashMap>(); /** * The mapping of ClassDocs to ExecutableMemberDocs that have return type * with type parameters of that class. */ - public Map classToExecMemberDocReturnTypeParam = new HashMap(); + public Map> classToExecMemberDocReturnTypeParam = new HashMap>(); /** * The mapping of AnnotationTypeDocs to MethodDoc parameters that use them. */ - public Map classToExecMemberDocParamAnnotation = new HashMap(); + public Map> classToExecMemberDocParamAnnotation = new HashMap>(); /** * The mapping of ClassDocs to FieldDocs that use them as type parameters. */ - public Map classToFieldDocTypeParam = new HashMap(); + public Map> classToFieldDocTypeParam = new HashMap>(); /** * The mapping of AnnotationTypeDocs to FieldDocs that use them. */ - public Map annotationToFieldDoc = new HashMap(); + public Map> annotationToFieldDoc = new HashMap>(); public ClassUseMapper(RootDoc root, ClassTree classtree) { @@ -231,15 +231,15 @@ public class ClassUseMapper { /** * Return all subclasses of a class AND fill-in classToSubclass map. */ - private Collection subclasses(ClassDoc cd) { - Collection ret = (Collection)classToSubclass.get(cd.qualifiedName()); + private Collection subclasses(ClassDoc cd) { + Collection ret = classToSubclass.get(cd.qualifiedName()); if (ret == null) { - ret = new TreeSet(); - List subs = classtree.subclasses(cd); + ret = new TreeSet(); + List subs = classtree.subclasses(cd); if (subs != null) { ret.addAll(subs); - for (Iterator it = subs.iterator(); it.hasNext();) { - ret.addAll(subclasses((ClassDoc)it.next())); + for (Iterator it = subs.iterator(); it.hasNext();) { + ret.addAll(subclasses(it.next())); } } addAll(classToSubclass, cd, ret); @@ -250,15 +250,15 @@ public class ClassUseMapper { /** * Return all subinterfaces of an interface AND fill-in classToSubinterface map. */ - private Collection subinterfaces(ClassDoc cd) { - Collection ret = (Collection)classToSubinterface.get(cd.qualifiedName()); + private Collection subinterfaces(ClassDoc cd) { + Collection ret = classToSubinterface.get(cd.qualifiedName()); if (ret == null) { - ret = new TreeSet(); - List subs = classtree.subinterfaces(cd); + ret = new TreeSet(); + List subs = classtree.subinterfaces(cd); if (subs != null) { ret.addAll(subs); - for (Iterator it = subs.iterator(); it.hasNext();) { - ret.addAll(subinterfaces((ClassDoc)it.next())); + for (Iterator it = subs.iterator(); it.hasNext();) { + ret.addAll(subinterfaces(it.next())); } } addAll(classToSubinterface, cd, ret); @@ -272,11 +272,11 @@ public class ClassUseMapper { * implementing subinterfaces) AND fill-in both classToImplementingClass * and classToSubinterface maps. */ - private Collection implementingClasses(ClassDoc cd) { - Collection ret = (List)classToImplementingClass.get(cd.qualifiedName()); + private Collection implementingClasses(ClassDoc cd) { + Collection ret = classToImplementingClass.get(cd.qualifiedName()); if (ret == null) { - ret = new TreeSet(); - List impl = classtree.implementingclasses(cd); + ret = new TreeSet(); + List impl = classtree.implementingclasses(cd); if (impl != null) { ret.addAll(impl); for (Iterator it = impl.iterator(); it.hasNext();) { @@ -298,7 +298,7 @@ public class ClassUseMapper { private void mapExecutable(ExecutableMemberDoc em) { Parameter[] params = em.parameters(); boolean isConstructor = em.isConstructor(); - List classArgs = new ArrayList(); + List classArgs = new ArrayList(); for (int k = 0; k < params.length; k++) { Type pcd = params[k].type(); // primitives don't get mapped, also avoid dups @@ -325,34 +325,38 @@ public class ClassUseMapper { } } - private List refList(Map map, ClassDoc cd) { - List list = (List)map.get(cd.qualifiedName()); + private List refList(Map> map, ClassDoc cd) { + List list = map.get(cd.qualifiedName()); if (list == null) { - list = new ArrayList(); + @SuppressWarnings("unchecked") + List l = new ArrayList(); + list = l; map.put(cd.qualifiedName(), list); } return list; } - private Set packageSet(ClassDoc cd) { - Set pkgSet = (Set)classToPackage.get(cd.qualifiedName()); + private Set packageSet(ClassDoc cd) { + Set pkgSet = classToPackage.get(cd.qualifiedName()); if (pkgSet == null) { - pkgSet = new TreeSet(); + pkgSet = new TreeSet(); classToPackage.put(cd.qualifiedName(), pkgSet); } return pkgSet; } - private Set classSet(ClassDoc cd) { - Set clsSet = (Set)classToClass.get(cd.qualifiedName()); + private Set classSet(ClassDoc cd) { + Set clsSet = classToClass.get(cd.qualifiedName()); if (clsSet == null) { - clsSet = new TreeSet(); + @SuppressWarnings("unchecked") + Set s = new TreeSet(); + clsSet = s; classToClass.put(cd.qualifiedName(), clsSet); } return clsSet; } - private void add(Map map, ClassDoc cd, ProgramElementDoc ref) { + private void add(Map> map, ClassDoc cd, T ref) { // add to specified map refList(map, cd).add(ref); @@ -361,25 +365,23 @@ public class ClassUseMapper { classSet(cd).add(ref instanceof MemberDoc? ((MemberDoc)ref).containingClass() : - ref); + (ClassDoc)ref); } - private void addAll(Map map, ClassDoc cd, Collection refs) { + private void addAll(Map> map, ClassDoc cd, Collection refs) { if (refs == null) { return; } // add to specified map refList(map, cd).addAll(refs); - Set pkgSet = packageSet(cd); - Set clsSet = classSet(cd); + Set pkgSet = packageSet(cd); + Set clsSet = classSet(cd); // add ref's package to package map and class map - for (Iterator it = refs.iterator(); it.hasNext();) { - ProgramElementDoc pedoc = (ProgramElementDoc)it.next(); - pkgSet.add(pedoc.containingPackage()); - clsSet.add(pedoc instanceof MemberDoc? - ((MemberDoc)pedoc).containingClass() : - pedoc); + for (Iterator it = refs.iterator(); it.hasNext();) { + ClassDoc cls = it.next(); + pkgSet.add(cls.containingPackage()); + clsSet.add(cls); } } @@ -392,8 +394,8 @@ public class ClassUseMapper { * @param doc the doc whose type parameters are being checked. * @param holder the holder that owns the type parameters. */ - private void mapTypeParameters(Map map, Object doc, - ProgramElementDoc holder) { + private void mapTypeParameters(Map> map, Object doc, + T holder) { TypeVariable[] typeVariables; if (doc instanceof ClassDoc) { typeVariables = ((ClassDoc) doc).typeParameters(); @@ -438,9 +440,8 @@ public class ClassUseMapper { * @param doc the doc whose type parameters are being checked. * @param holder the holder that owns the type parameters. */ - private void mapAnnotations(Map map, Object doc, - Object holder) { - TypeVariable[] typeVariables; + private void mapAnnotations(Map> map, Object doc, + T holder) { AnnotationDesc[] annotations; boolean isPackage = false; if (doc instanceof ProgramElementDoc) { @@ -458,12 +459,31 @@ public class ClassUseMapper { if (isPackage) refList(map, annotationDoc).add(holder); else - add(map, annotationDoc, (ProgramElementDoc) holder); + add(map, annotationDoc, holder); } } - private void addTypeParameterToMap(Map map, Type type, - ProgramElementDoc holder) { + + /** + * Map the AnnotationType to the ProgramElementDocs that use them as + * type parameters. + * + * @param map the map the insert the information into. + * @param doc the doc whose type parameters are being checked. + * @param holder the holder that owns the type parameters. + */ + private void mapAnnotations(Map> map, PackageDoc doc, + T holder) { + AnnotationDesc[] annotations; + annotations = doc.annotations(); + for (int i = 0; i < annotations.length; i++) { + AnnotationTypeDoc annotationDoc = annotations[i].annotationType(); + refList(map, annotationDoc).add(holder); + } + } + + private void addTypeParameterToMap(Map> map, Type type, + T holder) { if (type instanceof ClassDoc) { add(map, (ClassDoc) type, holder); } else if (type instanceof ParameterizedType) { diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/DeprecatedAPIListBuilder.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/DeprecatedAPIListBuilder.java index b1a39fb4f36..271cde9d8ca 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/DeprecatedAPIListBuilder.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/DeprecatedAPIListBuilder.java @@ -52,7 +52,7 @@ public class DeprecatedAPIListBuilder { /** * List of deprecated type Lists. */ - private List deprecatedLists; + private List> deprecatedLists; /** @@ -61,9 +61,9 @@ public class DeprecatedAPIListBuilder { * @param root Root of the tree. */ public DeprecatedAPIListBuilder(RootDoc root) { - deprecatedLists = new ArrayList(); + deprecatedLists = new ArrayList>(); for (int i = 0; i < NUM_TYPES; i++) { - deprecatedLists.add(i, new ArrayList()); + deprecatedLists.add(i, new ArrayList()); } buildDeprecatedAPIInfo(root); } @@ -114,7 +114,7 @@ public class DeprecatedAPIListBuilder { * @param list List of all the particular deprecated members, e.g. methods. * @param members members to be added in the list. */ - private void composeDeprecatedList(List list, MemberDoc[] members) { + private void composeDeprecatedList(List list, MemberDoc[] members) { for (int i = 0; i < members.length; i++) { if (Util.isDeprecated(members[i])) { list.add(members[i]); @@ -137,8 +137,8 @@ public class DeprecatedAPIListBuilder { * * @param the constant representing the type of list being returned. */ - public List getList(int type) { - return (List) deprecatedLists.get(type); + public List getList(int type) { + return deprecatedLists.get(type); } /** @@ -147,6 +147,6 @@ public class DeprecatedAPIListBuilder { * @param type the type of list being checked. */ public boolean hasDocumentation(int type) { - return ((List) deprecatedLists.get(type)).size() > 0; + return (deprecatedLists.get(type)).size() > 0; } } diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/DocFinder.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/DocFinder.java index 38cfb310e33..7b0b11c4444 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/DocFinder.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/DocFinder.java @@ -164,7 +164,7 @@ public class DocFinder { * subclass of IOException. This subclass of DocFinder.Output allows * multiple tag inheritence. */ - public List tagList = new ArrayList(); + public List tagList = new ArrayList(); } /** diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/Extern.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/Extern.java index 9ea25ae7322..6608183435b 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/Extern.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/Extern.java @@ -53,7 +53,7 @@ public class Extern { * Map package names onto Extern Item objects. * Lazily initialized. */ - private Map packageToItemMap; + private Map packageToItemMap; /** * The global configuration information for this run. @@ -101,7 +101,7 @@ public class Extern { this.path = path; this.relative = relative; if (packageToItemMap == null) { - packageToItemMap = new HashMap(); + packageToItemMap = new HashMap(); } if (!packageToItemMap.containsKey(packageName)) { // save the previous packageToItemMap.put(packageName, this); // mapped location @@ -185,7 +185,7 @@ public class Extern { if (packageToItemMap == null) { return null; } - return (Item)packageToItemMap.get(pkgName); + return packageToItemMap.get(pkgName); } /** diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/Group.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/Group.java index b0380d93205..4fc3af1e9de 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/Group.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/Group.java @@ -61,24 +61,24 @@ public class Group { /** * Map of regular expressions with the corresponding group name. */ - private Map regExpGroupMap = new HashMap(); + private Map regExpGroupMap = new HashMap(); /** * List of regular expressions sorted according to the length. Regular * expression with longest length will be first in the sorted order. */ - private List sortedRegExpList = new ArrayList(); + private List sortedRegExpList = new ArrayList(); /** * List of group names in the same order as given on the command line. */ - private List groupList = new ArrayList(); + private List groupList = new ArrayList(); /** * Map of non-regular expressions(possible package names) with the * corresponding group name. */ - private Map pkgNameGroupMap = new HashMap(); + private Map pkgNameGroupMap = new HashMap(); /** * The global configuration information for this run. @@ -90,9 +90,9 @@ public class Group { * the compare method in the implementing class is doing the reverse * comparison. */ - private static class MapKeyComparator implements Comparator { - public int compare(Object key1, Object key2) { - return ((String)key2).length() - ((String)key1).length(); + private static class MapKeyComparator implements Comparator { + public int compare(String key1, String key2) { + return key2.length() - key1.length(); } } @@ -182,8 +182,8 @@ public class Group { * * @param packages Packages specified on the command line. */ - public Map groupPackages(PackageDoc[] packages) { - Map groupPackageMap = new HashMap(); + public Map> groupPackages(PackageDoc[] packages) { + Map> groupPackageMap = new HashMap>(); String defaultGroupName = (pkgNameGroupMap.isEmpty() && regExpGroupMap.isEmpty())? configuration.message.getText("doclet.Packages") : @@ -195,7 +195,7 @@ public class Group { for (int i = 0; i < packages.length; i++) { PackageDoc pkg = packages[i]; String pkgName = pkg.name(); - String groupName = (String)pkgNameGroupMap.get(pkgName); + String groupName = pkgNameGroupMap.get(pkgName); // if this package is not explicitly assigned to a group, // try matching it to group specified by regular expression if (groupName == null) { @@ -220,9 +220,9 @@ public class Group { */ String regExpGroupName(String pkgName) { for (int j = 0; j < sortedRegExpList.size(); j++) { - String regexp = (String)sortedRegExpList.get(j); + String regexp = sortedRegExpList.get(j); if (pkgName.startsWith(regexp)) { - return (String)regExpGroupMap.get(regexp); + return regExpGroupMap.get(regexp); } } return null; @@ -235,10 +235,10 @@ public class Group { * @param map Map to be searched for gorup name. * @param groupname Group name to search. */ - List getPkgList(Map map, String groupname) { - List list = (List)map.get(groupname); + List getPkgList(Map> map, String groupname) { + List list = map.get(groupname); if (list == null) { - list = new ArrayList(); + list = new ArrayList(); map.put(groupname, list); } return list; diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ImplementedMethods.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ImplementedMethods.java index b12ccea55b8..8fad64d3fd6 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ImplementedMethods.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/ImplementedMethods.java @@ -41,8 +41,8 @@ import java.util.*; */ public class ImplementedMethods { - private Map interfaces = new HashMap(); - private List methlist = new ArrayList(); + private Map interfaces = new HashMap(); + private List methlist = new ArrayList(); private Configuration configuration; private final ClassDoc classdoc; private final MethodDoc method; @@ -67,7 +67,7 @@ public class ImplementedMethods { */ public MethodDoc[] build(boolean sort) { buildImplementedMethodList(sort); - return (MethodDoc[])methlist.toArray(new MethodDoc[methlist.size()]); + return methlist.toArray(new MethodDoc[methlist.size()]); } public MethodDoc[] build() { @@ -75,7 +75,7 @@ public class ImplementedMethods { } public Type getMethodHolder(MethodDoc methodDoc) { - return (Type) interfaces.get(methodDoc); + return interfaces.get(methodDoc); } /** @@ -111,7 +111,7 @@ public class ImplementedMethods { ClassDoc overriddenClass = method.overriddenClass(); if (overriddenClass != null) { for (int i = 0; i < methlist.size(); i++) { - ClassDoc cd = ((MethodDoc)methlist.get(i)).containingClass(); + ClassDoc cd = methlist.get(i).containingClass(); if (cd == overriddenClass || overriddenClass.subclassOf(cd)) { methlist.remove(i); // remove overridden method return; @@ -131,7 +131,7 @@ public class ImplementedMethods { private boolean overridingMethodFound(MethodDoc method) { ClassDoc containingClass = method.containingClass(); for (int i = 0; i < methlist.size(); i++) { - MethodDoc listmethod = (MethodDoc)methlist.get(i); + MethodDoc listmethod = methlist.get(i); if (containingClass == listmethod.containingClass()) { // it's the same method. return true; diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/IndexBuilder.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/IndexBuilder.java index af3de778b6d..ef8c41dfea0 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/IndexBuilder.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/IndexBuilder.java @@ -49,7 +49,7 @@ public class IndexBuilder { * Mapping of each Unicode Character with the member list containing * members with names starting with it. */ - private Map indexmap = new HashMap(); + private Map> indexmap = new HashMap>(); /** * Don't generate deprecated information if true. @@ -68,10 +68,10 @@ public class IndexBuilder { * A comparator used to sort classes and members. * Note: Maybe this compare code belongs in the tool? */ - private class DocComparator implements Comparator { - public int compare(Object d1, Object d2) { - String doc1 = (((Doc) d1).name()); - String doc2 = (((Doc) d2).name()); + private class DocComparator implements Comparator { + public int compare(Doc d1, Doc d2) { + String doc1 = d1.name(); + String doc2 = d2.name(); int compareResult; if ((compareResult = doc1.compareToIgnoreCase(doc2)) != 0) { return compareResult; @@ -124,8 +124,8 @@ public class IndexBuilder { * sort each element which is a list. */ protected void sortIndexMap() { - for (Iterator it = indexmap.values().iterator(); it.hasNext(); ) { - Collections.sort((List)it.next(), new DocComparator()); + for (Iterator> it = indexmap.values().iterator(); it.hasNext(); ) { + Collections.sort(it.next(), new DocComparator()); } } @@ -141,7 +141,7 @@ public class IndexBuilder { ClassDoc[] classes = root.classes(); if (!classesOnly) { if (packages.length == 0) { - Set set = new HashSet(); + Set set = new HashSet(); PackageDoc pd; for (int i = 0; i < classes.length; i++) { pd = classes[i].containingPackage(); @@ -149,7 +149,7 @@ public class IndexBuilder { set.add(pd); } } - adjustIndexMap((PackageDoc[]) set.toArray(packages)); + adjustIndexMap(set.toArray(packages)); } else { adjustIndexMap(packages); } @@ -193,9 +193,9 @@ public class IndexBuilder { '*' : Character.toUpperCase(name.charAt(0)); Character unicode = new Character(ch); - List list = (List)indexmap.get(unicode); + List list = indexmap.get(unicode); if (list == null) { - list = new ArrayList(); + list = new ArrayList(); indexmap.put(unicode, list); } list.add(elements[i]); diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/MetaKeywords.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/MetaKeywords.java index 203ed21f93c..d60da7d1688 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/MetaKeywords.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/MetaKeywords.java @@ -82,7 +82,7 @@ public class MetaKeywords { * definitions are on separate pages. */ public String[] getMetaKeywords(ClassDoc classdoc) { - ArrayList results = new ArrayList(); + ArrayList results = new ArrayList(); // Add field and method keywords only if -keywords option is used if( configuration.keywords ) { @@ -90,16 +90,16 @@ public class MetaKeywords { results.addAll(getMemberKeywords(classdoc.fields())); results.addAll(getMemberKeywords(classdoc.methods())); } - return (String[]) results.toArray(new String[]{}); + return results.toArray(new String[]{}); } /** * Get the current class for a meta tag keyword, as the first * and only element of an array list. */ - protected ArrayList getClassKeyword(ClassDoc classdoc) { + protected ArrayList getClassKeyword(ClassDoc classdoc) { String cltypelower = classdoc.isInterface() ? "interface" : "class"; - ArrayList metakeywords = new ArrayList(1); + ArrayList metakeywords = new ArrayList(1); metakeywords.add(classdoc.qualifiedName() + " " + cltypelower); return metakeywords; } @@ -141,8 +141,8 @@ public class MetaKeywords { * * @param memberdocs array of MemberDoc objects to be added to keywords */ - protected ArrayList getMemberKeywords(MemberDoc[] memberdocs) { - ArrayList results = new ArrayList(); + protected ArrayList getMemberKeywords(MemberDoc[] memberdocs) { + ArrayList results = new ArrayList(); String membername; for (int i=0; i < memberdocs.length; i++) { membername = memberdocs[i].name() diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/SourceToHTMLConverter.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/SourceToHTMLConverter.java index 22f975da10b..6094dbdc096 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/SourceToHTMLConverter.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/SourceToHTMLConverter.java @@ -260,12 +260,12 @@ public class SourceToHTMLConverter { * @param docs the array of Docs to add anchors for. * @param hash the HashMap to add to. */ - protected static void addToHash(Doc[] docs, HashMap hash) { + protected static void addToHash(Doc[] docs, HashMap hash) { if(docs == null) { return; } for(int i = 0; i < docs.length; i++) { - hash.put(new Integer(docs[i].position().line()), getAnchor(docs[i])); + hash.put(docs[i].position().line(), getAnchor(docs[i])); } } diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/Util.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/Util.java index 5cf20e2a9be..0111db73041 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/Util.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/Util.java @@ -73,9 +73,9 @@ public class Util { * @return List List of eligible members for whom * documentation is getting generated. */ - public static List excludeDeprecatedMembersAsList( + public static List excludeDeprecatedMembersAsList( ProgramElementDoc[] members) { - List list = new ArrayList(); + List list = new ArrayList(); for (int i = 0; i < members.length; i++) { if (members[i].tags("deprecated").length == 0) { list.add(members[i]); @@ -372,10 +372,10 @@ public class Util { * We want the list of types in alphabetical order. However, types are not * comparable. We need a comparator for now. */ - private static class TypeComparator implements Comparator { - public int compare(Object type1, Object type2) { - return ((Type) type1).qualifiedTypeName().toLowerCase().compareTo( - ((Type) type2).qualifiedTypeName().toLowerCase()); + private static class TypeComparator implements Comparator { + public int compare(Type type1, Type type2) { + return type1.qualifiedTypeName().toLowerCase().compareTo( + type2.qualifiedTypeName().toLowerCase()); } } @@ -391,9 +391,9 @@ public class Util { * @param sort if true, return list of interfaces sorted alphabetically. * @return List of all the required interfaces. */ - public static List getAllInterfaces(Type type, + public static List getAllInterfaces(Type type, Configuration configuration, boolean sort) { - Map results = sort ? new TreeMap() : new LinkedHashMap(); + Map results = sort ? new TreeMap() : new LinkedHashMap(); Type[] interfaceTypes = null; Type superType = null; if (type instanceof ParameterizedType) { @@ -423,7 +423,7 @@ public class Util { } } if (superType == null) - return new ArrayList(results.values()); + return new ArrayList(results.values()); //Try walking the tree. addAllInterfaceTypes(results, superType, @@ -431,7 +431,7 @@ public class Util { ((ClassDoc) superType).interfaceTypes() : ((ParameterizedType) superType).interfaceTypes(), false, configuration); - List resultsList = new ArrayList(results.values()); + List resultsList = new ArrayList(results.values()); if (sort) { Collections.sort(resultsList, new TypeComparator()); } @@ -442,7 +442,7 @@ public class Util { return getAllInterfaces(type, configuration, true); } - private static void findAllInterfaceTypes(Map results, ClassDoc c, boolean raw, + private static void findAllInterfaceTypes(Map results, ClassDoc c, boolean raw, Configuration configuration) { Type superType = c.superclassType(); if (superType == null) @@ -454,7 +454,7 @@ public class Util { raw, configuration); } - private static void findAllInterfaceTypes(Map results, ParameterizedType p, + private static void findAllInterfaceTypes(Map results, ParameterizedType p, Configuration configuration) { Type superType = p.superclassType(); if (superType == null) @@ -466,7 +466,7 @@ public class Util { false, configuration); } - private static void addAllInterfaceTypes(Map results, Type type, + private static void addAllInterfaceTypes(Map results, Type type, Type[] interfaceTypes, boolean raw, Configuration configuration) { for (int i = 0; i < interfaceTypes.length; i++) { @@ -495,8 +495,8 @@ public class Util { } - public static List asList(ProgramElementDoc[] members) { - List list = new ArrayList(); + public static List asList(ProgramElementDoc[] members) { + List list = new ArrayList(); for (int i = 0; i < members.length; i++) { list.add(members[i]); } @@ -639,7 +639,7 @@ public class Util { * @return an array of tokens. */ public static String[] tokenize(String s, char separator, int maxTokens) { - List tokens = new ArrayList(); + List tokens = new ArrayList(); StringBuilder token = new StringBuilder (); boolean prevIsEscapeChar = false; for (int i = 0; i < s.length(); i += Character.charCount(i)) { @@ -663,7 +663,7 @@ public class Util { if (token.length() > 0) { tokens.add(token.toString()); } - return (String[]) tokens.toArray(new String[] {}); + return tokens.toArray(new String[] {}); } /** diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/VisibleMemberMap.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/VisibleMemberMap.java index 34b9117227f..480a2ce5b54 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/VisibleMemberMap.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/VisibleMemberMap.java @@ -65,19 +65,19 @@ public class VisibleMemberMap { /** * List of ClassDoc objects for which ClassMembers objects are built. */ - private final List visibleClasses = new ArrayList(); + private final List visibleClasses = new ArrayList(); /** * Map for each member name on to a map which contains members with same * name-signature. The mapped map will contain mapping for each MemberDoc * onto it's respecive level string. */ - private final Map memberNameMap = new HashMap(); + private final Map> memberNameMap = new HashMap>(); /** * Map of class and it's ClassMembers object. */ - private final Map classMap = new HashMap(); + private final Map classMap = new HashMap(); /** * Type whose visible members are requested. This is the leaf of @@ -128,8 +128,8 @@ public class VisibleMemberMap { * @param configuation the current configuration of the doclet. * @return the package private members inherited by the class. */ - private List getInheritedPackagePrivateMethods(Configuration configuration) { - List results = new ArrayList(); + private List getInheritedPackagePrivateMethods(Configuration configuration) { + List results = new ArrayList(); for (Iterator iter = visibleClasses.iterator(); iter.hasNext(); ) { ClassDoc currentClass = (ClassDoc) iter.next(); if (currentClass != classdoc && @@ -150,8 +150,8 @@ public class VisibleMemberMap { * * @param configuation the current configuration of the doclet. */ - public List getLeafClassMembers(Configuration configuration) { - List result = getMembersFor(classdoc); + public List getLeafClassMembers(Configuration configuration) { + List result = getMembersFor(classdoc); result.addAll(getInheritedPackagePrivateMethods(configuration)); return result; } @@ -163,10 +163,10 @@ public class VisibleMemberMap { * * @return the list of members for the given class. */ - public List getMembersFor(ClassDoc cd) { - ClassMembers clmembers = (ClassMembers)(classMap.get(cd)); + public List getMembersFor(ClassDoc cd) { + ClassMembers clmembers = classMap.get(cd); if (clmembers == null) { - return new ArrayList(); + return new ArrayList(); } return clmembers.getMembers(); } @@ -175,11 +175,11 @@ public class VisibleMemberMap { * Sort the given mixed list of classes and interfaces to a list of * classes followed by interfaces traversed. Don't sort alphabetically. */ - private void sort(List list) { - List classes = new ArrayList(); - List interfaces = new ArrayList(); + private void sort(List list) { + List classes = new ArrayList(); + List interfaces = new ArrayList(); for (int i = 0; i < list.size(); i++) { - ClassDoc cd = (ClassDoc)list.get(i); + ClassDoc cd = list.get(i); if (cd.isClass()) { classes.add(cd); } else { @@ -191,12 +191,12 @@ public class VisibleMemberMap { list.addAll(interfaces); } - private void fillMemberLevelMap(List list, String level) { + private void fillMemberLevelMap(List list, String level) { for (int i = 0; i < list.size(); i++) { - Object key = getMemberKey((ProgramElementDoc)list.get(i)); - Map memberLevelMap = (Map) memberNameMap.get(key); + Object key = getMemberKey(list.get(i)); + Map memberLevelMap = memberNameMap.get(key); if (memberLevelMap == null) { - memberLevelMap = new HashMap(); + memberLevelMap = new HashMap(); memberNameMap.put(key, memberLevelMap); } memberLevelMap.put(list.get(i), level); @@ -218,10 +218,10 @@ public class VisibleMemberMap { * type variables in consideration when comparing. */ private class ClassMember { - private Set members; + private Set members; public ClassMember(ProgramElementDoc programElementDoc) { - members = new HashSet(); + members = new HashSet(); members.add(programElementDoc); } @@ -256,7 +256,7 @@ public class VisibleMemberMap { /** * List of inherited members from the mapping class. */ - private List members = new ArrayList(); + private List members = new ArrayList(); /** * Level/Depth of inheritance. @@ -268,7 +268,7 @@ public class VisibleMemberMap { * * @return List Inherited members. */ - public List getMembers() { + public List getMembers() { return members; } @@ -276,11 +276,11 @@ public class VisibleMemberMap { this.mappingClass = mappingClass; this.level = level; if (classMap.containsKey(mappingClass) && - level.startsWith(((ClassMembers) classMap.get(mappingClass)).level)) { + level.startsWith(classMap.get(mappingClass).level)) { //Remove lower level class so that it can be replaced with //same class found at higher level. purgeMemberLevelMap(getClassMembers(mappingClass, false), - ((ClassMembers) classMap.get(mappingClass)).level); + classMap.get(mappingClass).level); classMap.remove(mappingClass); visibleClasses.remove(mappingClass); } @@ -326,11 +326,10 @@ public class VisibleMemberMap { * Adjust member-level-map, class-map. */ private void addMembers(ClassDoc fromClass) { - List cdmembers = getClassMembers(fromClass, true); - List incllist = new ArrayList(); + List cdmembers = getClassMembers(fromClass, true); + List incllist = new ArrayList(); for (int i = 0; i < cdmembers.size(); i++) { - ProgramElementDoc pgmelem = - (ProgramElementDoc)(cdmembers.get(i)); + ProgramElementDoc pgmelem = cdmembers.get(i); if (!found(members, pgmelem) && memberIsVisible(pgmelem) && !isOverridden(pgmelem, level)) { @@ -373,7 +372,7 @@ public class VisibleMemberMap { /** * Return all available class members. */ - private List getClassMembers(ClassDoc cd, boolean filter) { + private List getClassMembers(ClassDoc cd, boolean filter) { if (cd.isEnum() && kind == CONSTRUCTORS) { //If any of these rules are hit, return empty array because //we don't document these members ever. @@ -428,16 +427,15 @@ public class VisibleMemberMap { */ private AnnotationTypeElementDoc[] filter(AnnotationTypeDoc doc, boolean required) { - AnnotationTypeElementDoc[] members = ((AnnotationTypeDoc) doc).elements(); - List targetMembers = new ArrayList(); + AnnotationTypeElementDoc[] members = doc.elements(); + List targetMembers = new ArrayList(); for (int i = 0; i < members.length; i++) { if ((required && members[i].defaultValue() == null) || ((!required) && members[i].defaultValue() != null)){ targetMembers.add(members[i]); } } - return (AnnotationTypeElementDoc[]) - targetMembers.toArray(new AnnotationTypeElementDoc[]{}); + return targetMembers.toArray(new AnnotationTypeElementDoc[]{}); } private boolean found(List list, ProgramElementDoc elem) { diff --git a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/links/LinkFactory.java b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/links/LinkFactory.java index 088faa05d05..dd0b78f4c77 100644 --- a/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/links/LinkFactory.java +++ b/langtools/src/share/classes/com/sun/tools/doclets/internal/toolkit/util/links/LinkFactory.java @@ -84,7 +84,7 @@ public abstract class LinkFactory { owner instanceof ClassDoc) { linkInfo.classDoc = (ClassDoc) owner; linkInfo.label = type.typeName(); - linkOutput.append(getClassLink((LinkInfo) linkInfo)); + linkOutput.append(getClassLink(linkInfo)); } else { //No need to link method type parameters. linkInfo.displayLength += type.typeName().length(); @@ -113,7 +113,7 @@ public abstract class LinkFactory { return linkOutput; } else { linkInfo.classDoc = type.asClassDoc(); - linkOutput = getClassLink((LinkInfo) linkInfo); + linkOutput = getClassLink(linkInfo); if (linkInfo.includeTypeAsSepLink) { linkOutput.append(getTypeParameterLinks(linkInfo, false)); } @@ -136,7 +136,7 @@ public abstract class LinkFactory { return linkOutput; } else if (linkInfo.classDoc != null) { //Just a class link - LinkOutput linkOutput = getClassLink((LinkInfo) linkInfo); + LinkOutput linkOutput = getClassLink(linkInfo); if (linkInfo.includeTypeAsSepLink) { linkOutput.append(getTypeParameterLinks(linkInfo, false)); } diff --git a/langtools/src/share/classes/com/sun/tools/javac/util/AbstractLog.java b/langtools/src/share/classes/com/sun/tools/javac/util/AbstractLog.java new file mode 100644 index 00000000000..1de1e825d6b --- /dev/null +++ b/langtools/src/share/classes/com/sun/tools/javac/util/AbstractLog.java @@ -0,0 +1,197 @@ +/* + * Copyright 1999-2008 Sun Microsystems, Inc. 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. Sun designates this + * particular file as subject to the "Classpath" exception as provided + * by Sun in the LICENSE file that accompanied this code. + * + * 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +package com.sun.tools.javac.util; + +import java.util.HashMap; +import java.util.Map; +import javax.tools.JavaFileObject; + +import com.sun.tools.javac.util.JCDiagnostic.DiagnosticPosition; +import com.sun.tools.javac.util.JCDiagnostic.SimpleDiagnosticPosition; + + +/** + * A base class for error logs. Reports errors and warnings, and + * keeps track of error numbers and positions. + * + *

This is NOT part of any API supported by Sun Microsystems. If + * you write code that depends on this, you do so at your own risk. + * This code and its internal interfaces are subject to change or + * deletion without notice. + */ +public abstract class AbstractLog { + AbstractLog(JCDiagnostic.Factory diags) { + this.diags = diags; + sourceMap = new HashMap(); + } + + /** Re-assign source, returning previous setting. + */ + public JavaFileObject useSource(JavaFileObject file) { + JavaFileObject prev = (source == null ? null : source.getFile()); + source = getSource(file); + return prev; + } + + protected DiagnosticSource getSource(JavaFileObject file) { + if (file == null) + return null; + DiagnosticSource s = sourceMap.get(file); + if (s == null) { + s = new DiagnosticSource(file, this); + sourceMap.put(file, s); + } + return s; + } + + /** Report an error, unless another error was already reported at same + * source position. + * @param key The key for the localized error message. + * @param args Fields of the error message. + */ + public void error(String key, Object ... args) { + report(diags.error(source, null, key, args)); + } + + /** Report an error, unless another error was already reported at same + * source position. + * @param pos The source position at which to report the error. + * @param key The key for the localized error message. + * @param args Fields of the error message. + */ + public void error(DiagnosticPosition pos, String key, Object ... args) { + report(diags.error(source, pos, key, args)); + } + + /** Report an error, unless another error was already reported at same + * source position. + * @param pos The source position at which to report the error. + * @param key The key for the localized error message. + * @param args Fields of the error message. + */ + public void error(int pos, String key, Object ... args) { + report(diags.error(source, wrap(pos), key, args)); + } + + /** Report a warning, unless suppressed by the -nowarn option or the + * maximum number of warnings has been reached. + * @param pos The source position at which to report the warning. + * @param key The key for the localized warning message. + * @param args Fields of the warning message. + */ + public void warning(String key, Object ... args) { + report(diags.warning(source, null, key, args)); + } + + /** Report a warning, unless suppressed by the -nowarn option or the + * maximum number of warnings has been reached. + * @param pos The source position at which to report the warning. + * @param key The key for the localized warning message. + * @param args Fields of the warning message. + */ + public void warning(DiagnosticPosition pos, String key, Object ... args) { + report(diags.warning(source, pos, key, args)); + } + + /** Report a warning, unless suppressed by the -nowarn option or the + * maximum number of warnings has been reached. + * @param pos The source position at which to report the warning. + * @param key The key for the localized warning message. + * @param args Fields of the warning message. + */ + public void warning(int pos, String key, Object ... args) { + report(diags.warning(source, wrap(pos), key, args)); + } + + /** Report a warning. + * @param pos The source position at which to report the warning. + * @param key The key for the localized warning message. + * @param args Fields of the warning message. + */ + public void mandatoryWarning(DiagnosticPosition pos, String key, Object ... args) { + report(diags.mandatoryWarning(source, pos, key, args)); + } + + /** Provide a non-fatal notification, unless suppressed by the -nowarn option. + * @param key The key for the localized notification message. + * @param args Fields of the notint an error or warning message: + */ + public void note(String key, Object ... args) { + report(diags.note(source, null, key, args)); + } + + /** Provide a non-fatal notification, unless suppressed by the -nowarn option. + * @param key The key for the localized notification message. + * @param args Fields of the notification message. + */ + public void note(DiagnosticPosition pos, String key, Object ... args) { + report(diags.note(source, pos, key, args)); + } + + /** Provide a non-fatal notification, unless suppressed by the -nowarn option. + * @param key The key for the localized notification message. + * @param args Fields of the notification message. + */ + public void note(int pos, String key, Object ... args) { + report(diags.note(source, wrap(pos), key, args)); + } + + /** Provide a non-fatal notification, unless suppressed by the -nowarn option. + * @param key The key for the localized notification message. + * @param args Fields of the notification message. + */ + public void note(JavaFileObject file, String key, Object ... args) { + report(diags.note(getSource(file), null, key, args)); + } + + /** Provide a non-fatal notification, unless suppressed by the -nowarn option. + * @param key The key for the localized notification message. + * @param args Fields of the notification message. + */ + public void mandatoryNote(final JavaFileObject file, String key, Object ... args) { + report(diags.mandatoryNote(getSource(file), key, args)); + } + + protected abstract void report(JCDiagnostic diagnostic); + + protected abstract void directError(String key, Object... args); + + private DiagnosticPosition wrap(int pos) { + return (pos == Position.NOPOS ? null : new SimpleDiagnosticPosition(pos)); + } + + /** Factory for diagnostics + */ + protected JCDiagnostic.Factory diags; + + /** The file that's currently being translated. + */ + protected DiagnosticSource source; + + /** A cache of lightweight DiagnosticSource objects. + */ + protected Map sourceMap; +} diff --git a/langtools/src/share/classes/com/sun/tools/javac/util/DiagnosticFormatter.java b/langtools/src/share/classes/com/sun/tools/javac/util/DiagnosticFormatter.java index 2c549105256..511ee28fe9f 100644 --- a/langtools/src/share/classes/com/sun/tools/javac/util/DiagnosticFormatter.java +++ b/langtools/src/share/classes/com/sun/tools/javac/util/DiagnosticFormatter.java @@ -28,7 +28,6 @@ package com.sun.tools.javac.util; import javax.tools.JavaFileObject; import com.sun.tools.javac.file.JavacFileManager; -import com.sun.tools.javac.util.JCDiagnostic.DiagnosticSource; import com.sun.tools.javac.util.JCDiagnostic.DiagnosticType; /** diff --git a/langtools/src/share/classes/com/sun/tools/javac/util/DiagnosticSource.java b/langtools/src/share/classes/com/sun/tools/javac/util/DiagnosticSource.java new file mode 100644 index 00000000000..c30d0a5cb2e --- /dev/null +++ b/langtools/src/share/classes/com/sun/tools/javac/util/DiagnosticSource.java @@ -0,0 +1,214 @@ +/* + * Copyright 1999-2008 Sun Microsystems, Inc. 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. Sun designates this + * particular file as subject to the "Classpath" exception as provided + * by Sun in the LICENSE file that accompanied this code. + * + * 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +package com.sun.tools.javac.util; + +import java.io.IOException; +import java.lang.ref.SoftReference; +import java.nio.CharBuffer; +import java.util.Map; +import javax.tools.JavaFileObject; + +import com.sun.tools.javac.file.JavacFileManager; +import com.sun.tools.javac.tree.JCTree; + +import static com.sun.tools.javac.util.LayoutCharacters.*; + +/** + * A simple abstraction of a source file, as needed for use in a diagnostic message. + * Provides access to the line and position in a line for any given character offset. + * + *

This is NOT part of any API supported by Sun Microsystems. If + * you write code that depends on this, you do so at your own risk. + * This code and its internal interfaces are subject to change or + * deletion without notice. + */ +public class DiagnosticSource { + public DiagnosticSource(JavaFileObject fo, AbstractLog log) { + this.fileObject = fo; + this.log = log; + } + + /** Return the underlying file object handled by this + * DiagnosticSource object. + */ + public JavaFileObject getFile() { + return fileObject; + } + + public CharSequence getName() { + return JavacFileManager.getJavacBaseFileName(fileObject); + } + + /** Return the one-based line number associated with a given pos + * for the current source file. Zero is returned if no line exists + * for the given position. + */ + public int getLineNumber(int pos) { + try { + if (findLine(pos)) { + return line; + } + return 0; + } finally { + buf = null; + } + } + + /** Return the one-based column number associated with a given pos + * for the current source file. Zero is returned if no column exists + * for the given position. + */ + public int getColumnNumber(int pos) { + try { + if (findLine(pos)) { + int column = 0; + for (int bp = lineStart; bp < pos; bp++) { + if (bp >= bufLen) { + return 0; + } + if (buf[bp] == '\t') { + column = (column / TabInc * TabInc) + TabInc; + } else { + column++; + } + } + return column + 1; // positions are one-based + } + return 0; + } finally { + buf = null; + } + } + + /** Return the content of the line containing a given pos. + */ + public String getLine(int pos) { + try { + if (!findLine(pos)) + return null; + + int lineEnd = lineStart; + while (lineEnd < bufLen && buf[lineEnd] != CR && buf[lineEnd] != LF) + lineEnd++; + if (lineEnd - lineStart == 0) + return null; + return new String(buf, lineStart, lineEnd - lineStart); + } finally { + buf = null; + } + } + + public Map getEndPosTable() { + return endPosTable; + } + + public void setEndPosTable(Map t) { + if (endPosTable != null && endPosTable != t) + throw new IllegalStateException("endPosTable already set"); + endPosTable = t; + } + + /** Find the line in the buffer that contains the current position + * @param pos Character offset into the buffer + */ + private boolean findLine(int pos) { + if (pos == Position.NOPOS) + return false; + + try { + // try and recover buffer from soft reference cache + if (buf == null && refBuf != null) + buf = refBuf.get(); + + if (buf == null) { + buf = initBuf(fileObject); + lineStart = 0; + line = 1; + } else if (lineStart > pos) { // messages don't come in order + lineStart = 0; + line = 1; + } + + int bp = lineStart; + while (bp < bufLen && bp < pos) { + switch (buf[bp++]) { + case CR: + if (bp < bufLen && buf[bp] == LF) bp++; + line++; + lineStart = bp; + break; + case LF: + line++; + lineStart = bp; + break; + } + } + return bp <= bufLen; + } catch (IOException e) { + log.directError("source.unavailable"); + buf = new char[0]; + return false; + } + } + + protected char[] initBuf(JavaFileObject fileObject) throws IOException { + char[] buf; + CharSequence cs = fileObject.getCharContent(true); + if (cs instanceof CharBuffer) { + CharBuffer cb = (CharBuffer) cs; + buf = JavacFileManager.toArray(cb); + bufLen = cb.limit(); + } else { + buf = cs.toString().toCharArray(); + bufLen = buf.length; + } + refBuf = new SoftReference(buf); + return buf; + } + + /** The underlying file object. */ + protected JavaFileObject fileObject; + + protected Map endPosTable; + + /** A soft reference to the content of the file object. */ + protected SoftReference refBuf; + + /** A temporary hard reference to the content of the file object. */ + protected char[] buf; + + /** The length of the content. */ + protected int bufLen; + + /** The start of a line found by findLine. */ + protected int lineStart; + + /** The line number of a line found by findLine. */ + protected int line; + + /** A log for reporting errors, such as errors accessing the content. */ + protected AbstractLog log; +} diff --git a/langtools/src/share/classes/com/sun/tools/javac/util/JCDiagnostic.java b/langtools/src/share/classes/com/sun/tools/javac/util/JCDiagnostic.java index 75f7c0758c0..a7d862203db 100644 --- a/langtools/src/share/classes/com/sun/tools/javac/util/JCDiagnostic.java +++ b/langtools/src/share/classes/com/sun/tools/javac/util/JCDiagnostic.java @@ -174,18 +174,6 @@ public class JCDiagnostic implements Diagnostic { args); } - /** - * A simple abstraction of a source file, as needed for use in a diagnostic message. - */ - // Note: This class may be superceded by a more general abstraction - public interface DiagnosticSource { - JavaFileObject getFile(); - CharSequence getName(); - int getLineNumber(int pos); - int getColumnNumber(int pos); - Map getEndPosTable(); - }; - /** * A DiagnosticType defines the type of the diagnostic. **/ diff --git a/langtools/src/share/classes/com/sun/tools/javac/util/Log.java b/langtools/src/share/classes/com/sun/tools/javac/util/Log.java index 93bdd542a05..5cd08aed172 100644 --- a/langtools/src/share/classes/com/sun/tools/javac/util/Log.java +++ b/langtools/src/share/classes/com/sun/tools/javac/util/Log.java @@ -26,8 +26,6 @@ package com.sun.tools.javac.util; import java.io.*; -import java.nio.CharBuffer; -import java.util.HashMap; import java.util.HashSet; import java.util.Map; import java.util.Set; @@ -38,9 +36,6 @@ import com.sun.tools.javac.file.JavacFileManager; import com.sun.tools.javac.tree.JCTree; import com.sun.tools.javac.util.JCDiagnostic.DiagnosticPosition; import com.sun.tools.javac.util.JCDiagnostic.DiagnosticType; -import com.sun.tools.javac.util.JCDiagnostic.SimpleDiagnosticPosition; - -import static com.sun.tools.javac.util.LayoutCharacters.*; /** A class for error logs. Reports errors and warnings, and * keeps track of error numbers and positions. @@ -50,7 +45,7 @@ import static com.sun.tools.javac.util.LayoutCharacters.*; * This code and its internal interfaces are subject to change or * deletion without notice. */ -public class Log { +public class Log extends AbstractLog { /** The context key for the log. */ public static final Context.Key logKey = new Context.Key(); @@ -98,28 +93,22 @@ public class Log { * interface to javac (JSR 199). */ protected DiagnosticListener diagListener; + /** * Formatter for diagnostics */ private DiagnosticFormatter diagFormatter; - /** - * Factory for diagnostics - */ - private JCDiagnostic.Factory diags; - - /** Construct a log with given I/O redirections. */ @Deprecated protected Log(Context context, PrintWriter errWriter, PrintWriter warnWriter, PrintWriter noticeWriter) { + super(JCDiagnostic.Factory.instance(context)); context.put(logKey, this); this.errWriter = errWriter; this.warnWriter = warnWriter; this.noticeWriter = noticeWriter; - this.diags = JCDiagnostic.Factory.instance(context); - Options options = Options.instance(context); this.dumpOnError = options.get("-doe") != null; this.promptOnError = options.get("-prompt") != null; @@ -174,10 +163,6 @@ public class Log { return instance; } - /** The file that's currently translated. - */ - protected JCDiagnostic.DiagnosticSource source; - /** The number of errors encountered so far. */ public int nerrors = 0; @@ -192,77 +177,13 @@ public class Log { */ private Set> recorded = new HashSet>(); - private Map> endPosTables; - - /** The buffer containing the file that's currently translated. - */ - private char[] buf = null; - - /** The length of useful data in buf - */ - private int bufLen = 0; - - /** The position in the buffer at which last error was reported - */ - private int bp; - - /** number of the current source line; first line is 1 - */ - private int line; - - /** buffer index of the first character of the current source line - */ - private int lineStart; - public boolean hasDiagnosticListener() { return diagListener != null; } public void setEndPosTable(JavaFileObject name, Map table) { - if (endPosTables == null) - endPosTables = new HashMap>(); - endPosTables.put(name, table); - } - - /** Re-assign source, returning previous setting. - */ - public JavaFileObject useSource(final JavaFileObject name) { - JavaFileObject prev = currentSource(); - if (name != prev) { - source = new JCDiagnostic.DiagnosticSource() { - public JavaFileObject getFile() { - return name; - } - public CharSequence getName() { - return JavacFileManager.getJavacBaseFileName(getFile()); - } - public int getLineNumber(int pos) { - return Log.this.getLineNumber(pos); - } - public int getColumnNumber(int pos) { - return Log.this.getColumnNumber(pos); - } - public Map getEndPosTable() { - return (endPosTables == null ? null : endPosTables.get(name)); - } - }; - buf = null; - } - return prev; - } - - /** Re-assign source buffer for existing source name. - */ - protected void setBuf(char[] newBuf) { - buf = newBuf; - bufLen = buf.length; - bp = 0; - lineStart = 0; - line = 1; - } - - protected char[] getBuf() { - return buf; + name.getClass(); // null check + getSource(name).setEndPosTable(table); } /** Return current source name. @@ -320,74 +241,19 @@ public class Log { * @param pos Buffer index of the error position, must be on current line */ private void printErrLine(int pos, PrintWriter writer) { - if (!findLine(pos)) + String line = (source == null ? null : source.getLine(pos)); + if (line == null) return; + int col = source.getColumnNumber(pos); - int lineEnd = lineStart; - while (lineEnd < bufLen && buf[lineEnd] != CR && buf[lineEnd] != LF) - lineEnd++; - if (lineEnd - lineStart == 0) - return; - printLines(writer, new String(buf, lineStart, lineEnd - lineStart)); - for (bp = lineStart; bp < pos; bp++) { - writer.print((buf[bp] == '\t') ? "\t" : " "); + printLines(writer, line); + for (int i = 0; i < col - 1; i++) { + writer.print((line.charAt(i) == '\t') ? "\t" : " "); } writer.println("^"); writer.flush(); } - protected void initBuf(JavaFileObject fileObject) throws IOException { - CharSequence cs = fileObject.getCharContent(true); - if (cs instanceof CharBuffer) { - CharBuffer cb = (CharBuffer) cs; - buf = JavacFileManager.toArray(cb); - bufLen = cb.limit(); - } else { - buf = cs.toString().toCharArray(); - bufLen = buf.length; - } - } - - /** Find the line in the buffer that contains the current position - * @param pos Character offset into the buffer - */ - private boolean findLine(int pos) { - if (pos == Position.NOPOS || currentSource() == null) - return false; - try { - if (buf == null) { - initBuf(currentSource()); - lineStart = 0; - line = 1; - } else if (lineStart > pos) { // messages don't come in order - lineStart = 0; - line = 1; - } - bp = lineStart; - while (bp < bufLen && bp < pos) { - switch (buf[bp++]) { - case CR: - if (bp < bufLen && buf[bp] == LF) bp++; - line++; - lineStart = bp; - break; - case LF: - line++; - lineStart = bp; - break; - } - } - return bp <= bufLen; - } catch (IOException e) { - //e.printStackTrace(); - // FIXME: include e.getLocalizedMessage() in error message - printLines(errWriter, getLocalizedString("source.unavailable")); - errWriter.flush(); - buf = new char[0]; - } - return false; - } - /** Print the text of a message, translating newlines appropriately * for the platform. */ @@ -400,72 +266,9 @@ public class Log { if (msg.length() != 0) writer.println(msg); } - /** Report an error, unless another error was already reported at same - * source position. - * @param key The key for the localized error message. - * @param args Fields of the error message. - */ - public void error(String key, Object ... args) { - report(diags.error(source, null, key, args)); - } - - /** Report an error, unless another error was already reported at same - * source position. - * @param pos The source position at which to report the error. - * @param key The key for the localized error message. - * @param args Fields of the error message. - */ - public void error(DiagnosticPosition pos, String key, Object ... args) { - report(diags.error(source, pos, key, args)); - } - - /** Report an error, unless another error was already reported at same - * source position. - * @param pos The source position at which to report the error. - * @param key The key for the localized error message. - * @param args Fields of the error message. - */ - public void error(int pos, String key, Object ... args) { - report(diags.error(source, wrap(pos), key, args)); - } - - /** Report a warning, unless suppressed by the -nowarn option or the - * maximum number of warnings has been reached. - * @param pos The source position at which to report the warning. - * @param key The key for the localized warning message. - * @param args Fields of the warning message. - */ - public void warning(String key, Object ... args) { - report(diags.warning(source, null, key, args)); - } - - /** Report a warning, unless suppressed by the -nowarn option or the - * maximum number of warnings has been reached. - * @param pos The source position at which to report the warning. - * @param key The key for the localized warning message. - * @param args Fields of the warning message. - */ - public void warning(DiagnosticPosition pos, String key, Object ... args) { - report(diags.warning(source, pos, key, args)); - } - - /** Report a warning, unless suppressed by the -nowarn option or the - * maximum number of warnings has been reached. - * @param pos The source position at which to report the warning. - * @param key The key for the localized warning message. - * @param args Fields of the warning message. - */ - public void warning(int pos, String key, Object ... args) { - report(diags.warning(source, wrap(pos), key, args)); - } - - /** Report a warning. - * @param pos The source position at which to report the warning. - * @param key The key for the localized warning message. - * @param args Fields of the warning message. - */ - public void mandatoryWarning(DiagnosticPosition pos, String key, Object ... args) { - report(diags.mandatoryWarning(source, pos, key, args)); + protected void directError(String key, Object... args) { + printLines(errWriter, getLocalizedString(key, args)); + errWriter.flush(); } /** Report a warning that cannot be suppressed. @@ -478,74 +281,6 @@ public class Log { nwarnings++; } - /** Provide a non-fatal notification, unless suppressed by the -nowarn option. - * @param key The key for the localized notification message. - * @param args Fields of the notification message. - */ - public void note(String key, Object ... args) { - report(diags.note(source, null, key, args)); - } - - /** Provide a non-fatal notification, unless suppressed by the -nowarn option. - * @param key The key for the localized notification message. - * @param args Fields of the notification message. - */ - public void note(DiagnosticPosition pos, String key, Object ... args) { - report(diags.note(source, pos, key, args)); - } - - /** Provide a non-fatal notification, unless suppressed by the -nowarn option. - * @param key The key for the localized notification message. - * @param args Fields of the notification message. - */ - public void note(int pos, String key, Object ... args) { - report(diags.note(source, wrap(pos), key, args)); - } - - /** Provide a non-fatal notification, unless suppressed by the -nowarn option. - * @param file The file to which the note applies. - * @param key The key for the localized notification message. - * @param args Fields of the notification message. - */ - public void note(JavaFileObject file, String key, Object ... args) { - report(diags.note(wrap(file), null, key, args)); - } - - /** Provide a non-fatal notification, unless suppressed by the -nowarn option. - * @param key The key for the localized notification message. - * @param args Fields of the notification message. - */ - public void mandatoryNote(final JavaFileObject file, String key, Object ... args) { - report(diags.mandatoryNote(wrap(file), key, args)); - } - - private JCDiagnostic.DiagnosticSource wrap(final JavaFileObject file) { - if (file == null) { - return null; - } - return new JCDiagnostic.DiagnosticSource() { - public JavaFileObject getFile() { - return file; - } - public CharSequence getName() { - return JavacFileManager.getJavacBaseFileName(getFile()); - } - public int getLineNumber(int pos) { - return Log.this.getLineNumber(pos); - } - public int getColumnNumber(int pos) { - return Log.this.getColumnNumber(pos); - } - public Map getEndPosTable() { - return (endPosTables == null ? null : endPosTables.get(file)); - } - }; - } - - private DiagnosticPosition wrap(int pos) { - return (pos == Position.NOPOS ? null : new SimpleDiagnosticPosition(pos)); - } - /** * Common diagnostic handling. * The diagnostic is counted, and depending on the options and how many diagnostics have been @@ -657,12 +392,13 @@ public class Log { * and quick prototyping ***************************************************************************/ -/** print an error or warning message: - */ + /** print an error or warning message: + */ private void printRawError(int pos, String msg) { - if (!findLine(pos)) { + if (source == null || pos == Position.NOPOS) { printLines(errWriter, "error: " + msg); } else { + int line = source.getLineNumber(pos); JavaFileObject file = currentSource(); if (file != null) printLines(errWriter, @@ -673,8 +409,8 @@ public class Log { errWriter.flush(); } -/** report an error: - */ + /** report an error: + */ public void rawError(int pos, String msg) { if (nerrors < MaxErrors && shouldReport(currentSource(), pos)) { printRawError(pos, msg); @@ -684,8 +420,8 @@ public class Log { errWriter.flush(); } -/** report a warning: - */ + /** report a warning: + */ public void rawWarning(int pos, String msg) { if (nwarnings < MaxWarnings && emitWarnings) { printRawError(pos, "warning: " + msg); @@ -695,36 +431,6 @@ public class Log { errWriter.flush(); } - /** Return the one-based line number associated with a given pos - * for the current source file. Zero is returned if no line exists - * for the given position. - */ - protected int getLineNumber(int pos) { - if (findLine(pos)) - return line; - return 0; - } - - /** Return the one-based column number associated with a given pos - * for the current source file. Zero is returned if no column exists - * for the given position. - */ - protected int getColumnNumber(int pos) { - if (findLine(pos)) { - int column = 0; - for (bp = lineStart; bp < pos; bp++) { - if (bp >= bufLen) - return 0; - if (buf[bp] == '\t') - column = (column / TabInc * TabInc) + TabInc; - else - column++; - } - return column + 1; // positions are one-based - } - return 0; - } - public static String format(String fmt, Object... args) { return String.format((java.util.Locale)null, fmt, args); } diff --git a/langtools/src/share/classes/com/sun/tools/javadoc/DocletInvoker.java b/langtools/src/share/classes/com/sun/tools/javadoc/DocletInvoker.java index 2a0c1ba9020..4379c9e5eab 100644 --- a/langtools/src/share/classes/com/sun/tools/javadoc/DocletInvoker.java +++ b/langtools/src/share/classes/com/sun/tools/javadoc/DocletInvoker.java @@ -47,7 +47,7 @@ import java.util.StringTokenizer; */ public class DocletInvoker { - private final Class docletClass; + private final Class docletClass; private final String docletClassName; diff --git a/langtools/src/share/classes/com/sun/tools/javadoc/ExecutableMemberDocImpl.java b/langtools/src/share/classes/com/sun/tools/javadoc/ExecutableMemberDocImpl.java index 1e8e2e36a8c..5a1a2b8e027 100644 --- a/langtools/src/share/classes/com/sun/tools/javadoc/ExecutableMemberDocImpl.java +++ b/langtools/src/share/classes/com/sun/tools/javadoc/ExecutableMemberDocImpl.java @@ -231,7 +231,7 @@ public abstract class ExecutableMemberDocImpl StringBuffer result = new StringBuffer(); result.append("("); for (List types = sym.type.getParameterTypes(); types.nonEmpty(); ) { - Type t = (Type)types.head; + Type t = types.head; result.append(TypeMaker.getTypeString(env, t, full)); types = types.tail; if (types.nonEmpty()) { diff --git a/langtools/src/share/classes/com/sun/tools/javadoc/JavadocEnter.java b/langtools/src/share/classes/com/sun/tools/javadoc/JavadocEnter.java index 5ca9cf84c7a..0137a2bf46b 100644 --- a/langtools/src/share/classes/com/sun/tools/javadoc/JavadocEnter.java +++ b/langtools/src/share/classes/com/sun/tools/javadoc/JavadocEnter.java @@ -86,7 +86,7 @@ public class JavadocEnter extends Enter { if (tree.sym != null && tree.sym.kind == Kinds.TYP) { if (tree.sym == null) return; String comment = env.toplevel.docComments.get(tree); - ClassSymbol c = (ClassSymbol)tree.sym; + ClassSymbol c = tree.sym; docenv.makeClassDoc(c, comment, tree, env.toplevel.lineMap); } } diff --git a/langtools/src/share/classes/com/sun/tools/javadoc/JavadocMemberEnter.java b/langtools/src/share/classes/com/sun/tools/javadoc/JavadocMemberEnter.java index 4b6d4d2a5d5..ce815b44284 100644 --- a/langtools/src/share/classes/com/sun/tools/javadoc/JavadocMemberEnter.java +++ b/langtools/src/share/classes/com/sun/tools/javadoc/JavadocMemberEnter.java @@ -63,7 +63,7 @@ class JavadocMemberEnter extends MemberEnter { public void visitMethodDef(JCMethodDecl tree) { super.visitMethodDef(tree); - MethodSymbol meth = (MethodSymbol)tree.sym; + MethodSymbol meth = tree.sym; if (meth == null || meth.kind != Kinds.MTH) return; String docComment = env.toplevel.docComments.get(tree); Position.LineMap lineMap = env.toplevel.lineMap; @@ -82,7 +82,7 @@ class JavadocMemberEnter extends MemberEnter { !isParameter(tree.sym)) { String docComment = env.toplevel.docComments.get(tree); Position.LineMap lineMap = env.toplevel.lineMap; - docenv.makeFieldDoc((VarSymbol)tree.sym, docComment, tree, lineMap); + docenv.makeFieldDoc(tree.sym, docComment, tree, lineMap); } } diff --git a/langtools/src/share/classes/com/sun/tools/javadoc/SeeTagImpl.java b/langtools/src/share/classes/com/sun/tools/javadoc/SeeTagImpl.java index b25f96159bc..b8feb4cc468 100644 --- a/langtools/src/share/classes/com/sun/tools/javadoc/SeeTagImpl.java +++ b/langtools/src/share/classes/com/sun/tools/javadoc/SeeTagImpl.java @@ -450,7 +450,7 @@ class SeeTagImpl extends TagImpl implements SeeTag, LayoutCharacters { if (typeId.length() > 0) { paramList.append(typeId.toString()); } - return (String[])paramList.toArray(new String[paramList.length()]); + return paramList.toArray(new String[paramList.length()]); } void addTypeToParamList() { diff --git a/langtools/src/share/classes/com/sun/tools/javadoc/SerializedForm.java b/langtools/src/share/classes/com/sun/tools/javadoc/SerializedForm.java index 044d075090d..8908fead75e 100644 --- a/langtools/src/share/classes/com/sun/tools/javadoc/SerializedForm.java +++ b/langtools/src/share/classes/com/sun/tools/javadoc/SerializedForm.java @@ -267,7 +267,7 @@ class SerializedForm { * @return an array of MethodDocImpl for serialization methods in this class. */ MethodDoc[] methods() { - return (MethodDoc[])methods.toArray(new MethodDoc[methods.length()]); + return methods.toArray(new MethodDoc[methods.length()]); } /** diff --git a/langtools/src/share/classes/com/sun/tools/javah/Gen.java b/langtools/src/share/classes/com/sun/tools/javah/Gen.java index a2f03aed75e..ef7c131984a 100644 --- a/langtools/src/share/classes/com/sun/tools/javah/Gen.java +++ b/langtools/src/share/classes/com/sun/tools/javah/Gen.java @@ -324,7 +324,7 @@ public abstract class Gen { FieldDoc[] getAllFields(ClassDoc subclazz) throws ClassNotFoundException { - Vector fields = new Vector(); + Vector fields = new Vector(); ClassDoc cd = null; Stack s = new Stack();