This commit is contained in:
Lana Steuck 2016-01-21 10:16:42 -08:00
commit ea8c4d0244
20 changed files with 1064 additions and 186 deletions

View File

@ -77,7 +77,7 @@ javadoc.jls.option=-tag "jls:a:See <cite>${javadoc.jls.cite}</cite>:
-tag "implNote:a:Implementation Note:" -tag "implNote:a:Implementation Note:"
# Version info -- override as needed # Version info -- override as needed
jdk.version = 1.9.0 jdk.version = 9
build.number = b00 build.number = b00
milestone = internal milestone = internal
@ -88,4 +88,4 @@ milestone = internal
# timestamps # timestamps
# FIXME -- need to include openjdk as needed # FIXME -- need to include openjdk as needed
release = ${jdk.version}-${milestone} release = ${jdk.version}-${milestone}
full.version = ${release}-${build.number} full.version = ${release}+${build.number}

View File

@ -55,7 +55,7 @@ public enum SourceVersion {
* 1.6: no changes * 1.6: no changes
* 1.7: diamond syntax, try-with-resources, etc. * 1.7: diamond syntax, try-with-resources, etc.
* 1.8: lambda expressions and default methods * 1.8: lambda expressions and default methods
* 1.9: To be determined * 9: To be determined
*/ */
/** /**

View File

@ -0,0 +1,338 @@
/*
* Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
package com.sun.source.util;
import java.util.List;
import javax.lang.model.element.Name;
import javax.tools.Diagnostic;
import javax.tools.JavaFileObject;
import com.sun.source.doctree.AttributeTree;
import com.sun.source.doctree.AttributeTree.ValueKind;
import com.sun.source.doctree.AuthorTree;
import com.sun.source.doctree.CommentTree;
import com.sun.source.doctree.DeprecatedTree;
import com.sun.source.doctree.DocCommentTree;
import com.sun.source.doctree.DocRootTree;
import com.sun.source.doctree.DocTree;
import com.sun.source.doctree.EndElementTree;
import com.sun.source.doctree.EntityTree;
import com.sun.source.doctree.ErroneousTree;
import com.sun.source.doctree.IdentifierTree;
import com.sun.source.doctree.IndexTree;
import com.sun.source.doctree.InheritDocTree;
import com.sun.source.doctree.LinkTree;
import com.sun.source.doctree.LiteralTree;
import com.sun.source.doctree.ParamTree;
import com.sun.source.doctree.ReferenceTree;
import com.sun.source.doctree.ReturnTree;
import com.sun.source.doctree.SeeTree;
import com.sun.source.doctree.SerialDataTree;
import com.sun.source.doctree.SerialFieldTree;
import com.sun.source.doctree.SerialTree;
import com.sun.source.doctree.SinceTree;
import com.sun.source.doctree.StartElementTree;
import com.sun.source.doctree.TextTree;
import com.sun.source.doctree.ThrowsTree;
import com.sun.source.doctree.UnknownBlockTagTree;
import com.sun.source.doctree.UnknownInlineTagTree;
import com.sun.source.doctree.ValueTree;
import com.sun.source.doctree.VersionTree;
/**
* Factory for creating {@code DocTree} nodes.
*
* @implNote The methods in an implementation of this interface may only accept {@code DocTree}
* nodes that have been created by the same implementation.
*
* @since 9
*/
public interface DocTreeFactory {
/**
* Create a new {@code AttributeTree} object, to represent an HTML attribute in an HTML tag.
* @param name the name of the attribute
* @param vkind the kind of attribute value
* @param value the value, if any, of the attribute
* @return an {@code AttributeTree} object
*/
AttributeTree newAttributeTree(Name name, ValueKind vkind, List<? extends DocTree> value);
/**
* Create a new {@code AuthorTree} object, to represent an {@code {@author } } tag.
* @param name the name of the author
* @return an {@code AuthorTree} object
*/
AuthorTree newAuthorTree(List<? extends DocTree> name);
/**
* Create a new {@code CodeTree} object, to represent a {@code {@code } } tag.
* @param text the content of the tag
* @return a {@code CodeTree} object
*/
LiteralTree newCodeTree(TextTree text);
/**
* Create a new {@code CommentTree}, to represent an HTML comment.
* @param text the content of the comment
* @return a {@code CommentTree} object
*/
CommentTree newCommentTree(String text);
/**
* Create a new {@code DeprecatedTree} object, to represent an {@code {@deprecated } } tag.
* @param text the content of the tag
* @return a {@code DeprecatedTree} object
*/
DeprecatedTree newDeprecatedTree(List<? extends DocTree> text);
/**
* Create a new {@code DocCommentTree} object, to represent a complete doc comment.
* @param firstSentence the first sentence of the doc comment
* @param body the body of the doc comment following the first sentence
* @param tags the block tags in the doc comment
* @return a {@code DocCommentTree} object
*/
DocCommentTree newDocCommentTree(List<? extends DocTree> firstSentence, List<? extends DocTree> body, List<? extends DocTree> tags);
/**
* Create a new {@code DocRootTree} object, to represent an {@code {@docroot} } tag.
* @return a {@code DocRootTree} object
*/
DocRootTree newDocRootTree();
/**
* Create a new {@code EndElement} object, to represent the end of an HTML element.
* @param name the name of the HTML element
* @return an {@code EndElementTree} object
*/
EndElementTree newEndElementTree(Name name);
/**
* Create a new {@code EntityTree} object, to represent an HTML entity.
* @param name the name of the entity, representing the characters between '&lt;' and ';'
* in the representation of the entity in an HTML document
* @return an {@code EntityTree} object
*/
EntityTree newEntityTree(Name name);
/**
* Create a new {@code ErroneousTree} object, to represent some unparseable input.
* @param text the unparseable text
* @param diag a diagnostic associated with the unparseable text, or null
* @return an {@code ErroneousTree} object
*/
ErroneousTree newErroneousTree(String text, Diagnostic<JavaFileObject> diag);
/**
* Create a new {@code ExceptionTree} object, to represent an {@code @exception } tag.
* @param name the name of the exception
* @param description a description of why the exception might be thrown
* @return an {@code ExceptionTree} object
*/
ThrowsTree newExceptionTree(ReferenceTree name, List<? extends DocTree> description);
/**
* Create a new {@code IdentifierTree} object, to represent an identifier, such as in a
* {@code @param } tag.
* @param name the name of the identifier
* @return an {@code IdentifierTree} object
*/
IdentifierTree newIdentifierTree(Name name);
/**
* Create a new {@code IndexTree} object, to represent an {@code {@index } } tag.
* @param term the search term
* @param description an optional description of the search term
* @return an {@code IndexTree} object
*/
IndexTree newIndexTree(DocTree term, List<? extends DocTree> description);
/**
* Create a new {@code InheritDocTree} object, to represent an {@code {@inheritDoc} } tag.
* @return an {@code InheritDocTree} object
*/
InheritDocTree newInheritDocTree();
/**
* Create a new {@code LinkTree} object, to represent a {@code {@link } } tag.
* @param ref the API element being referenced
* @param label an optional label for the link
* @return a {@code LinkTree} object
*/
LinkTree newLinkTree(ReferenceTree ref, List<? extends DocTree> label);
/**
* Create a new {@code LinkPlainTree} object, to represent a {@code {@linkplain } } tag.
* @param ref the API element being referenced
* @param label an optional label for the link
* @return a {@code LinkPlainTree} object
*/
LinkTree newLinkPlainTree(ReferenceTree ref, List<? extends DocTree> label);
/**
* Create a new {@code LiteralTree} object, to represent a {@code {@literal } } tag.
* @param text the content of the tag
* @return a {@code LiteralTree} object
*/
LiteralTree newLiteralTree(TextTree text);
/**
* Create a new {@code ParamTree} object, to represent a {@code @param } tag.
* @param isTypeParameter true if this is a type parameter, and false otherwise
* @param name the parameter being described
* @param description the description of the parameter
* @return a {@code ParamTree} object
*/
ParamTree newParamTree(boolean isTypeParameter, IdentifierTree name, List<? extends DocTree> description);
/**
* Create a new {@code ReferenceTree} object, to represent a reference to an API element.
*
* @param signature the doc comment signature of the reference
* @return a {@code ReferenceTree} object
*/
ReferenceTree newReferenceTree(String signature);
/**
* Create a new {@code ReturnTree} object, to represent a {@code @return } tag.
* @param description the description of the return value of a method
* @return a {@code ReturnTree} object
*/
ReturnTree newReturnTree(List<? extends DocTree> description);
/**
* Create a new {@code SeeTree} object, to represent a {@code @see } tag.
* @param reference the reference
* @return a {@code SeeTree} object
*/
SeeTree newSeeTree(List<? extends DocTree> reference);
/**
* Create a new {@code SerialTree} object, to represent a {@code @serial } tag.
* @param description the description for the tag
* @return a {@code SerialTree} object
*/
SerialTree newSerialTree(List<? extends DocTree> description);
/**
* Create a new {@code SerialDataTree} object, to represent a {@code @serialData } tag.
* @param description the description for the tag
* @return a {@code SerialDataTree} object
*/
SerialDataTree newSerialDataTree(List<? extends DocTree> description);
/**
* Create a new {@code SerialFieldTree} object, to represent a {@code @serialField } tag.
* @param name the name of the field
* @param type the type of the field
* @param description the description of the field
* @return a {@code SerialFieldTree} object
*/
SerialFieldTree newSerialFieldTree(IdentifierTree name, ReferenceTree type, List<? extends DocTree> description);
/**
* Create a new {@code SinceTree} object, to represent a {@code @since } tag.
* @param text the content of the tag
* @return a {@code SinceTree} object
*/
SinceTree newSinceTree(List<? extends DocTree> text);
/**
* Create a new {@code StartElementTree} object, to represent the start of an HTML element.
* @param name the name of the HTML element
* @param attrs the attributes
* @param selfClosing true if the start element is marked as self-closing; otherwise false
* @return a {@code StartElementTree} object
*/
StartElementTree newStartElementTree(Name name, List<? extends DocTree> attrs, boolean selfClosing);
/**
* Create a new {@code TextTree} object, to represent some plain text.
* @param text the text
* @return a {@code TextTree} object
*/
TextTree newTextTree(String text);
/**
* Create a new {@code ThrowsTree} object, to represent a {@code @throws } tag.
* @param name the name of the exception
* @param description a description of why the exception might be thrown
* @return a {@code ThrowsTree} object
*/
ThrowsTree newThrowsTree(ReferenceTree name, List<? extends DocTree> description);
/**
* Create a new {@code UnknownBlockTagTree} object, to represent an unrecognized block tag.
* @param name the name of the block tag
* @param content the content
* @return an {@code UnknownBlockTagTree} object
*/
UnknownBlockTagTree newUnknownBlockTagTree(Name name, List<? extends DocTree> content);
/**
* Create a new {@code UnknownInlineTagTree} object, to represent an unrecognized inline tag.
* @param name the name of the inline tag
* @param content the content
* @return an {@code UnknownInlineTagTree} object
*/
UnknownInlineTagTree newUnknownInlineTagTree(Name name, List<? extends DocTree> content);
/**
* Create a new {@code ValueTree} object, to represent a {@code {@value } } tag.
* @param ref a reference to the value
* @return a {@code ValueTree} object
*/
ValueTree newValueTree(ReferenceTree ref);
/**
* Create a new {@code VersionTree} object, to represent a {@code {@version } } tag.
* @param text the content of the tag
* @return a {@code VersionTree} object
*/
VersionTree newVersionTree(List<? extends DocTree> text);
/**
* Set the position to be recorded in subsequent tree nodes created by this factory.
* The position should be a character offset relative to the beginning of the source file
* or {@link javax.tools.Diagnostic#NOPOS NOPOS}.
* @param pos the position
* @return this object, to facilitate method chaining
*/
DocTreeFactory at(int pos);
/**
* Get the first sentence contained in a list of content.
* The determination of the first sentence is implementation specific, and may
* involve the use of a locale-specific {@link java.text.BreakIterator BreakIterator}
* and other heuristics.
* The resulting list may share a common set of initial items with the input list.
* @param list the list
* @return a list containing the first sentence of the list.
*/
List<DocTree> getFirstSentence(List<? extends DocTree> list);
}

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2006, 2014, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2006, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -70,6 +70,7 @@ public class DocTreePath implements Iterable<DocTree> {
} }
class PathFinder extends DocTreePathScanner<DocTreePath,DocTree> { class PathFinder extends DocTreePathScanner<DocTreePath,DocTree> {
@Override
public DocTreePath scan(DocTree tree, DocTree target) { public DocTreePath scan(DocTree tree, DocTree target) {
if (tree == target) { if (tree == target) {
throw new Result(new DocTreePath(getCurrentPath(), target)); throw new Result(new DocTreePath(getCurrentPath(), target));
@ -151,18 +152,22 @@ public class DocTreePath implements Iterable<DocTree> {
return parent; return parent;
} }
@Override
public Iterator<DocTree> iterator() { public Iterator<DocTree> iterator() {
return new Iterator<DocTree>() { return new Iterator<DocTree>() {
@Override
public boolean hasNext() { public boolean hasNext() {
return next != null; return next != null;
} }
@Override
public DocTree next() { public DocTree next() {
DocTree t = next.leaf; DocTree t = next.leaf;
next = next.parent; next = next.parent;
return t; return t;
} }
@Override
public void remove() { public void remove() {
throw new UnsupportedOperationException(); throw new UnsupportedOperationException();
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -125,6 +125,20 @@ public abstract class DocTrees extends Trees {
*/ */
public abstract DocCommentTree getDocCommentTree(Element e, String relativePath) throws IOException; public abstract DocCommentTree getDocCommentTree(Element e, String relativePath) throws IOException;
/**
* Returns a doc tree path containing the doc comment tree of the given file.
* The file must be an HTML file, in which case the doc comment tree represents the
* contents of the &lt;body&gt; tag, and any enclosing tags are ignored.
* Returns {@code null} if no doc comment was found.
* Future releases may support additional file types.
*
* @param fileObject the content container
* @return a doc tree path containing the doc comment read from the given file.
*
* @since 9
*/
public abstract DocTreePath getDocTreePath(FileObject fileObject);
/** /**
* Returns the language model element referred to by the leaf node of the given * Returns the language model element referred to by the leaf node of the given
* {@link DocTreePath}, or {@code null} if unknown. * {@link DocTreePath}, or {@code null} if unknown.
@ -175,4 +189,12 @@ public abstract class DocTrees extends Trees {
* @since 9 * @since 9
*/ */
public abstract void setBreakIterator(BreakIterator breakiterator); public abstract void setBreakIterator(BreakIterator breakiterator);
/**
* Returns a utility object for creating {@code DocTree} objects.
* @return a utility object for creating {@code DocTree} objects
*
* @since 9
*/
public abstract DocTreeFactory getDocTreeFactory();
} }

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2005, 2015, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2005, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -49,7 +49,6 @@ import javax.lang.model.type.TypeMirror;
import javax.tools.Diagnostic; import javax.tools.Diagnostic;
import javax.tools.FileObject; import javax.tools.FileObject;
import javax.tools.ForwardingFileObject; import javax.tools.ForwardingFileObject;
import javax.tools.ForwardingJavaFileObject;
import javax.tools.JavaCompiler; import javax.tools.JavaCompiler;
import javax.tools.JavaFileManager; import javax.tools.JavaFileManager;
import javax.tools.JavaFileObject; import javax.tools.JavaFileObject;
@ -160,7 +159,7 @@ public class JavacTrees extends DocTrees {
private JavacTaskImpl javacTaskImpl; private JavacTaskImpl javacTaskImpl;
private Names names; private Names names;
private Types types; private Types types;
private DocTreeMaker doctreeMaker; private DocTreeMaker docTreeMaker;
private BreakIterator breakIterator; private BreakIterator breakIterator;
private JavaFileManager fileManager; private JavaFileManager fileManager;
private ParserFactory parser; private ParserFactory parser;
@ -206,7 +205,7 @@ public class JavacTrees extends DocTrees {
memberEnter = MemberEnter.instance(context); memberEnter = MemberEnter.instance(context);
names = Names.instance(context); names = Names.instance(context);
types = Types.instance(context); types = Types.instance(context);
doctreeMaker = DocTreeMaker.instance(context); docTreeMaker = DocTreeMaker.instance(context);
parser = ParserFactory.instance(context); parser = ParserFactory.instance(context);
fileManager = context.get(JavaFileManager.class); fileManager = context.get(JavaFileManager.class);
JavacTask t = context.get(JavacTask.class); JavacTask t = context.get(JavacTask.class);
@ -294,6 +293,11 @@ public class JavacTrees extends DocTrees {
}; };
} }
@Override @DefinedBy(Api.COMPILER_TREE)
public DocTreeMaker getDocTreeFactory() {
return docTreeMaker;
}
private DocTree getLastChild(DocTree tree) { private DocTree getLastChild(DocTree tree) {
final DocTree[] last = new DocTree[] {null}; final DocTree[] last = new DocTree[] {null};
@ -398,7 +402,7 @@ public class JavacTrees extends DocTrees {
@Override @DefinedBy(Api.COMPILER_TREE) @Override @DefinedBy(Api.COMPILER_TREE)
public java.util.List<DocTree> getFirstSentence(java.util.List<? extends DocTree> list) { public java.util.List<DocTree> getFirstSentence(java.util.List<? extends DocTree> list) {
return doctreeMaker.getFirstSentence(list); return docTreeMaker.getFirstSentence(list);
} }
private Symbol attributeDocReference(TreePath path, DCReference ref) { private Symbol attributeDocReference(TreePath path, DCReference ref) {
@ -411,9 +415,9 @@ public class JavacTrees extends DocTrees {
final Name memberName; final Name memberName;
if (ref.qualifierExpression == null) { if (ref.qualifierExpression == null) {
tsym = env.enclClass.sym; tsym = env.enclClass.sym;
memberName = ref.memberName; memberName = (Name) ref.memberName;
} else { } else {
// See if the qualifierExpression is a type or package name. // newSeeTree if the qualifierExpression is a type or package name.
// javac does not provide the exact method required, so // javac does not provide the exact method required, so
// we first check if qualifierExpression identifies a type, // we first check if qualifierExpression identifies a type,
// and if not, then we check to see if it identifies a package. // and if not, then we check to see if it identifies a package.
@ -437,7 +441,7 @@ public class JavacTrees extends DocTrees {
} }
} else { } else {
tsym = t.tsym; tsym = t.tsym;
memberName = ref.memberName; memberName = (Name) ref.memberName;
} }
} }
@ -449,7 +453,7 @@ public class JavacTrees extends DocTrees {
paramTypes = null; paramTypes = null;
else { else {
ListBuffer<Type> lb = new ListBuffer<>(); ListBuffer<Type> lb = new ListBuffer<>();
for (List<JCTree> l = ref.paramTypes; l.nonEmpty(); l = l.tail) { for (List<JCTree> l = (List<JCTree>) ref.paramTypes; l.nonEmpty(); l = l.tail) {
JCTree tree = l.head; JCTree tree = l.head;
Type t = attr.attribType(tree, env); Type t = attr.attribType(tree, env);
lb.add(t); lb.add(t);
@ -913,7 +917,7 @@ public class JavacTrees extends DocTrees {
} }
} }
private JavaFileObject asJavaFileObject(FileObject fileObject) { static JavaFileObject asJavaFileObject(FileObject fileObject) {
JavaFileObject jfo = null; JavaFileObject jfo = null;
if (fileObject instanceof JavaFileObject) { if (fileObject instanceof JavaFileObject) {
@ -927,11 +931,11 @@ public class JavacTrees extends DocTrees {
return jfo; return jfo;
} }
private void checkHtmlKind(FileObject fileObject) { private static void checkHtmlKind(FileObject fileObject) {
checkHtmlKind(fileObject, BaseFileManager.getKind(fileObject.getName())); checkHtmlKind(fileObject, BaseFileManager.getKind(fileObject.getName()));
} }
private void checkHtmlKind(FileObject fileObject, JavaFileObject.Kind kind) { private static void checkHtmlKind(FileObject fileObject, JavaFileObject.Kind kind) {
if (kind != JavaFileObject.Kind.HTML) { if (kind != JavaFileObject.Kind.HTML) {
throw new IllegalArgumentException("HTML file expected:" + fileObject.getName()); throw new IllegalArgumentException("HTML file expected:" + fileObject.getName());
} }
@ -1011,6 +1015,12 @@ public class JavacTrees extends DocTrees {
return new DocCommentParser(parser, diagSource, comment).parse(); return new DocCommentParser(parser, diagSource, comment).parse();
} }
@Override @DefinedBy(Api.COMPILER_TREE)
public DocTreePath getDocTreePath(FileObject fileObject) {
JavaFileObject jfo = asJavaFileObject(fileObject);
return new DocTreePath(makeTreePath(jfo), getDocCommentTree(jfo));
}
@Override @DefinedBy(Api.COMPILER_TREE) @Override @DefinedBy(Api.COMPILER_TREE)
public void setBreakIterator(BreakIterator breakiterator) { public void setBreakIterator(BreakIterator breakiterator) {
this.breakIterator = breakiterator; this.breakIterator = breakiterator;
@ -1126,11 +1136,10 @@ public class JavacTrees extends DocTrees {
} }
} }
public TreePath makeTreePath(final FileObject fileObject, final int offset) { private TreePath makeTreePath(final JavaFileObject jfo) {
JavaFileObject jfo = asJavaFileObject(fileObject);
JCCompilationUnit jcCompilationUnit = new JCCompilationUnit(List.nil()) { JCCompilationUnit jcCompilationUnit = new JCCompilationUnit(List.nil()) {
public int getPos() { public int getPos() {
return offset; return Position.FIRSTPOS;
} }
public JavaFileObject getSourcefile() { public JavaFileObject getSourcefile() {
@ -1140,7 +1149,7 @@ public class JavacTrees extends DocTrees {
@Override @DefinedBy(Api.COMPILER_TREE) @Override @DefinedBy(Api.COMPILER_TREE)
public Position.LineMap getLineMap() { public Position.LineMap getLineMap() {
try { try {
CharSequence content = fileObject.getCharContent(true); CharSequence content = jfo.getCharContent(true);
String s = content.toString(); String s = content.toString();
return Position.makeLineMap(s.toCharArray(), s.length(), true); return Position.makeLineMap(s.toCharArray(), s.length(), true);
} catch (IOException ignore) {} } catch (IOException ignore) {}

View File

@ -368,6 +368,10 @@ public abstract class Type extends AnnoConstruct implements TypeMirror {
accept(stripMetadata, null) : accept(stripMetadata, null) :
this; this;
} }
public Type stripMetadata() {
return accept(stripMetadata, null);
}
//where //where
private final static TypeMapping<Void> stripMetadata = new TypeMapping<Void>() { private final static TypeMapping<Void> stripMetadata = new TypeMapping<Void>() {
@Override @Override

View File

@ -42,6 +42,7 @@ import com.sun.tools.javac.code.Symbol.*;
import com.sun.tools.javac.code.Type.*; import com.sun.tools.javac.code.Type.*;
import com.sun.tools.javac.code.TypeMetadata.Annotations; import com.sun.tools.javac.code.TypeMetadata.Annotations;
import com.sun.tools.javac.code.Types.FunctionDescriptorLookupError; import com.sun.tools.javac.code.Types.FunctionDescriptorLookupError;
import com.sun.tools.javac.comp.ArgumentAttr.LocalCacheContext;
import com.sun.tools.javac.comp.Check.CheckContext; import com.sun.tools.javac.comp.Check.CheckContext;
import com.sun.tools.javac.comp.DeferredAttr.AttrMode; import com.sun.tools.javac.comp.DeferredAttr.AttrMode;
import com.sun.tools.javac.comp.Infer.FreeTypeListener; import com.sun.tools.javac.comp.Infer.FreeTypeListener;
@ -885,6 +886,10 @@ public class Attr extends JCTree.Visitor {
} }
public void visitClassDef(JCClassDecl tree) { public void visitClassDef(JCClassDecl tree) {
Optional<ArgumentAttr.LocalCacheContext> localCacheContext =
Optional.ofNullable(env.info.isSpeculative ?
argumentAttr.withLocalCacheContext() : null);
try {
// Local and anonymous classes have not been entered yet, so we need to // Local and anonymous classes have not been entered yet, so we need to
// do it now. // do it now.
if (env.info.scope.owner.kind.matches(KindSelector.VAL_MTH)) { if (env.info.scope.owner.kind.matches(KindSelector.VAL_MTH)) {
@ -913,13 +918,15 @@ public class Attr extends JCTree.Visitor {
// (This would be an illegal access to "this before super"). // (This would be an illegal access to "this before super").
if (env.info.isSelfCall && if (env.info.isSelfCall &&
env.tree.hasTag(NEWCLASS) && env.tree.hasTag(NEWCLASS) &&
((JCNewClass) env.tree).encl == null) ((JCNewClass)env.tree).encl == null) {
{
c.flags_field |= NOOUTERTHIS; c.flags_field |= NOOUTERTHIS;
} }
attribClass(tree.pos(), c); attribClass(tree.pos(), c);
result = tree.type = c.type; result = tree.type = c.type;
} }
} finally {
localCacheContext.ifPresent(LocalCacheContext::leave);
}
} }
public void visitMethodDef(JCMethodDecl tree) { public void visitMethodDef(JCMethodDecl tree) {
@ -3873,8 +3880,6 @@ public class Attr extends JCTree.Visitor {
v.name != names._class; v.name != names._class;
} }
Warner noteWarner = new Warner();
/** /**
* Check that method arguments conform to its instantiation. * Check that method arguments conform to its instantiation.
**/ **/
@ -3928,7 +3933,7 @@ public class Attr extends JCTree.Visitor {
// For methods, we need to compute the instance type by // For methods, we need to compute the instance type by
// Resolve.instantiate from the symbol's type as well as // Resolve.instantiate from the symbol's type as well as
// any type arguments and value arguments. // any type arguments and value arguments.
noteWarner.clear(); Warner noteWarner = new Warner();
try { try {
Type owntype = rs.checkMethod( Type owntype = rs.checkMethod(
env, env,

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -121,7 +121,7 @@ public class DocCommentParser {
? body.head.pos ? body.head.pos
: !tags.isEmpty() ? tags.head.pos : Position.NOPOS; : !tags.isEmpty() ? tags.head.pos : Position.NOPOS;
DCDocComment dc = m.at(pos).DocComment(comment, body, tags); DCDocComment dc = m.at(pos).newDocCommentTree(comment, body, tags);
return dc; return dc;
} }
@ -171,7 +171,7 @@ public class DocCommentParser {
case '>': case '>':
newline = false; newline = false;
addPendingText(trees, bp - 1); addPendingText(trees, bp - 1);
trees.add(m.at(bp).Erroneous(newString(bp, bp+1), diagSource, "dc.bad.gt")); trees.add(m.at(bp).newErroneousTree(newString(bp, bp + 1), diagSource, "dc.bad.gt"));
nextChar(); nextChar();
if (textStart == -1) { if (textStart == -1) {
textStart = bp; textStart = bp;
@ -231,7 +231,7 @@ public class DocCommentParser {
TagParser tp = tagParsers.get(name); TagParser tp = tagParsers.get(name);
if (tp == null) { if (tp == null) {
List<DCTree> content = blockContent(); List<DCTree> content = blockContent();
return m.at(p).UnknownBlockTag(name, content); return m.at(p).newUnknownBlockTagTree(name, content);
} else { } else {
switch (tp.getKind()) { switch (tp.getKind()) {
case BLOCK: case BLOCK:
@ -284,7 +284,7 @@ public class DocCommentParser {
DCTree text = inlineText(WhitespaceRetentionPolicy.REMOVE_ALL); DCTree text = inlineText(WhitespaceRetentionPolicy.REMOVE_ALL);
if (text != null) { if (text != null) {
nextChar(); nextChar();
return m.at(p).UnknownInlineTag(name, List.of(text)).setEndPos(bp); return m.at(p).newUnknownInlineTagTree(name, List.of(text)).setEndPos(bp);
} }
} else { } else {
if (!tp.retainWhiteSpace) { if (!tp.retainWhiteSpace) {
@ -354,7 +354,7 @@ public class DocCommentParser {
case '}': case '}':
if (--depth == 0) { if (--depth == 0) {
return m.at(pos).Text(newString(pos, bp)); return m.at(pos).newTextTree(newString(pos, bp));
} }
newline = false; newline = false;
lastNonWhite = bp; lastNonWhite = bp;
@ -384,6 +384,7 @@ public class DocCommentParser {
*/ */
// TODO: boolean allowMember should be enum FORBID, ALLOW, REQUIRE // TODO: boolean allowMember should be enum FORBID, ALLOW, REQUIRE
// TODO: improve quality of parse to forbid bad constructions. // TODO: improve quality of parse to forbid bad constructions.
// TODO: update to use ReferenceParser
@SuppressWarnings("fallthrough") @SuppressWarnings("fallthrough")
protected DCReference reference(boolean allowMember) throws ParseException { protected DCReference reference(boolean allowMember) throws ParseException {
int pos = bp; int pos = bp;
@ -481,7 +482,7 @@ public class DocCommentParser {
fac.log.popDiagnosticHandler(deferredDiagnosticHandler); fac.log.popDiagnosticHandler(deferredDiagnosticHandler);
} }
return m.at(pos).Reference(sig, qualExpr, member, paramTypes).setEndPos(bp); return m.at(pos).newReferenceTree(sig, qualExpr, member, paramTypes).setEndPos(bp);
} }
JCTree parseType(String s) throws ParseException { JCTree parseType(String s) throws ParseException {
@ -537,7 +538,7 @@ public class DocCommentParser {
if (isJavaIdentifierStart(ch)) { if (isJavaIdentifierStart(ch)) {
Name name = readJavaIdentifier(); Name name = readJavaIdentifier();
return m.at(pos).Identifier(name); return m.at(pos).newIdentifierTree(name);
} }
throw new ParseException("dc.identifier.expected"); throw new ParseException("dc.identifier.expected");
@ -565,7 +566,7 @@ public class DocCommentParser {
case '"': case '"':
nextChar(); nextChar();
// trim trailing white-space? // trim trailing white-space?
return m.at(pos).Text(newString(pos, bp)); return m.at(pos).newTextTree(newString(pos, bp));
case '@': case '@':
if (newline) if (newline)
@ -593,7 +594,7 @@ public class DocCommentParser {
// fallthrough // fallthrough
case '\r': case '\f': case ' ': case '\t': case '\r': case '\f': case ' ': case '\t':
return m.at(pos).Text(newString(pos, bp)); return m.at(pos).newTextTree(newString(pos, bp));
case '@': case '@':
if (newline) if (newline)
@ -605,7 +606,7 @@ public class DocCommentParser {
case '}': case '}':
if (depth == 0 || --depth == 0) if (depth == 0 || --depth == 0)
return m.at(pos).Text(newString(pos, bp)); return m.at(pos).newTextTree(newString(pos, bp));
break; break;
} }
newline = false; newline = false;
@ -729,7 +730,7 @@ public class DocCommentParser {
if (ch != ';') if (ch != ';')
return erroneous("dc.missing.semicolon", p); return erroneous("dc.missing.semicolon", p);
nextChar(); nextChar();
return m.at(p).Entity(name); return m.at(p).newEntityTree(name);
} }
} }
@ -751,7 +752,7 @@ public class DocCommentParser {
} }
if (ch == '>') { if (ch == '>') {
nextChar(); nextChar();
DCTree dctree = m.at(p).StartElement(name, attrs, selfClosing).setEndPos(bp); DCTree dctree = m.at(p).newStartElementTree(name, attrs, selfClosing).setEndPos(bp);
return dctree; return dctree;
} }
} }
@ -762,7 +763,7 @@ public class DocCommentParser {
skipWhitespace(); skipWhitespace();
if (ch == '>') { if (ch == '>') {
nextChar(); nextChar();
return m.at(p).EndElement(name); return m.at(p).newEndElementTree(name);
} }
} }
} else if (ch == '!') { } else if (ch == '!') {
@ -777,11 +778,13 @@ public class DocCommentParser {
dash++; dash++;
nextChar(); nextChar();
} }
// strictly speaking, a comment should not contain "--" // Strictly speaking, a comment should not contain "--"
// so dash > 2 is an error, dash == 2 implies ch == '>' // so dash > 2 is an error, dash == 2 implies ch == '>'
// See http://www.w3.org/TR/html-markup/syntax.html#syntax-comments
// for more details.
if (dash >= 2 && ch == '>') { if (dash >= 2 && ch == '>') {
nextChar(); nextChar();
return m.at(p).Comment(newString(p, bp)); return m.at(p).newCommentTree(newString(p, bp));
} }
nextChar(); nextChar();
@ -844,7 +847,7 @@ public class DocCommentParser {
skipWhitespace(); skipWhitespace();
value = v.toList(); value = v.toList();
} }
DCAttribute attr = m.at(namePos).Attribute(name, vkind, value); DCAttribute attr = m.at(namePos).newAttributeTree(name, vkind, value);
attrs.add(attr); attrs.add(attr);
} }
@ -869,7 +872,7 @@ public class DocCommentParser {
protected void addPendingText(ListBuffer<DCTree> list, int textEnd) { protected void addPendingText(ListBuffer<DCTree> list, int textEnd) {
if (textStart != -1) { if (textStart != -1) {
if (textStart <= textEnd) { if (textStart <= textEnd) {
list.add(m.at(textStart).Text(newString(textStart, textEnd + 1))); list.add(m.at(textStart).newTextTree(newString(textStart, textEnd + 1)));
} }
textStart = -1; textStart = -1;
} }
@ -891,7 +894,7 @@ public class DocCommentParser {
i--; i--;
} }
textStart = -1; textStart = -1;
return m.at(pos).Erroneous(newString(pos, i + 1), diagSource, code); return m.at(pos).newErroneousTree(newString(pos, i + 1), diagSource, code);
} }
protected boolean isIdentifierStart(char ch) { protected boolean isIdentifierStart(char ch) {
@ -1017,7 +1020,7 @@ public class DocCommentParser {
new TagParser(Kind.BLOCK, DCTree.Kind.AUTHOR) { new TagParser(Kind.BLOCK, DCTree.Kind.AUTHOR) {
public DCTree parse(int pos) { public DCTree parse(int pos) {
List<DCTree> name = blockContent(); List<DCTree> name = blockContent();
return m.at(pos).Author(name); return m.at(pos).newAuthorTree(name);
} }
}, },
@ -1026,7 +1029,7 @@ public class DocCommentParser {
public DCTree parse(int pos) throws ParseException { public DCTree parse(int pos) throws ParseException {
DCTree text = inlineText(WhitespaceRetentionPolicy.REMOVE_FIRST_SPACE); DCTree text = inlineText(WhitespaceRetentionPolicy.REMOVE_FIRST_SPACE);
nextChar(); nextChar();
return m.at(pos).Code((DCText) text); return m.at(pos).newCodeTree((DCText) text);
} }
}, },
@ -1034,7 +1037,7 @@ public class DocCommentParser {
new TagParser(Kind.BLOCK, DCTree.Kind.DEPRECATED) { new TagParser(Kind.BLOCK, DCTree.Kind.DEPRECATED) {
public DCTree parse(int pos) { public DCTree parse(int pos) {
List<DCTree> reason = blockContent(); List<DCTree> reason = blockContent();
return m.at(pos).Deprecated(reason); return m.at(pos).newDeprecatedTree(reason);
} }
}, },
@ -1043,7 +1046,7 @@ public class DocCommentParser {
public DCTree parse(int pos) throws ParseException { public DCTree parse(int pos) throws ParseException {
if (ch == '}') { if (ch == '}') {
nextChar(); nextChar();
return m.at(pos).DocRoot(); return m.at(pos).newDocRootTree();
} }
inlineText(WhitespaceRetentionPolicy.REMOVE_ALL); // skip unexpected content inlineText(WhitespaceRetentionPolicy.REMOVE_ALL); // skip unexpected content
nextChar(); nextChar();
@ -1057,7 +1060,7 @@ public class DocCommentParser {
skipWhitespace(); skipWhitespace();
DCReference ref = reference(false); DCReference ref = reference(false);
List<DCTree> description = blockContent(); List<DCTree> description = blockContent();
return m.at(pos).Exception(ref, description); return m.at(pos).newExceptionTree(ref, description);
} }
}, },
@ -1079,7 +1082,7 @@ public class DocCommentParser {
} else { } else {
nextChar(); nextChar();
} }
return m.at(pos).Index(term, description); return m.at(pos).newIndexTree(term, description);
} }
}, },
@ -1088,7 +1091,7 @@ public class DocCommentParser {
public DCTree parse(int pos) throws ParseException { public DCTree parse(int pos) throws ParseException {
if (ch == '}') { if (ch == '}') {
nextChar(); nextChar();
return m.at(pos).InheritDoc(); return m.at(pos).newInheritDocTree();
} }
inlineText(WhitespaceRetentionPolicy.REMOVE_ALL); // skip unexpected content inlineText(WhitespaceRetentionPolicy.REMOVE_ALL); // skip unexpected content
nextChar(); nextChar();
@ -1101,7 +1104,7 @@ public class DocCommentParser {
public DCTree parse(int pos) throws ParseException { public DCTree parse(int pos) throws ParseException {
DCReference ref = reference(true); DCReference ref = reference(true);
List<DCTree> label = inlineContent(); List<DCTree> label = inlineContent();
return m.at(pos).Link(ref, label); return m.at(pos).newLinkTree(ref, label);
} }
}, },
@ -1110,7 +1113,7 @@ public class DocCommentParser {
public DCTree parse(int pos) throws ParseException { public DCTree parse(int pos) throws ParseException {
DCReference ref = reference(true); DCReference ref = reference(true);
List<DCTree> label = inlineContent(); List<DCTree> label = inlineContent();
return m.at(pos).LinkPlain(ref, label); return m.at(pos).newLinkPlainTree(ref, label);
} }
}, },
@ -1119,7 +1122,7 @@ public class DocCommentParser {
public DCTree parse(int pos) throws ParseException { public DCTree parse(int pos) throws ParseException {
DCTree text = inlineText(WhitespaceRetentionPolicy.REMOVE_FIRST_SPACE); DCTree text = inlineText(WhitespaceRetentionPolicy.REMOVE_FIRST_SPACE);
nextChar(); nextChar();
return m.at(pos).Literal((DCText) text); return m.at(pos).newLiteralTree((DCText) text);
} }
}, },
@ -1144,7 +1147,7 @@ public class DocCommentParser {
skipWhitespace(); skipWhitespace();
List<DCTree> desc = blockContent(); List<DCTree> desc = blockContent();
return m.at(pos).Param(typaram, id, desc); return m.at(pos).newParamTree(typaram, id, desc);
} }
}, },
@ -1152,7 +1155,7 @@ public class DocCommentParser {
new TagParser(Kind.BLOCK, DCTree.Kind.RETURN) { new TagParser(Kind.BLOCK, DCTree.Kind.RETURN) {
public DCTree parse(int pos) { public DCTree parse(int pos) {
List<DCTree> description = blockContent(); List<DCTree> description = blockContent();
return m.at(pos).Return(description); return m.at(pos).newReturnTree(description);
} }
}, },
@ -1167,7 +1170,7 @@ public class DocCommentParser {
skipWhitespace(); skipWhitespace();
if (ch == '@' if (ch == '@'
|| ch == EOI && bp == buf.length - 1) { || ch == EOI && bp == buf.length - 1) {
return m.at(pos).See(List.<DCTree>of(string)); return m.at(pos).newSeeTree(List.<DCTree>of(string));
} }
} }
break; break;
@ -1175,7 +1178,7 @@ public class DocCommentParser {
case '<': case '<':
List<DCTree> html = blockContent(); List<DCTree> html = blockContent();
if (html != null) if (html != null)
return m.at(pos).See(html); return m.at(pos).newSeeTree(html);
break; break;
case '@': case '@':
@ -1192,7 +1195,7 @@ public class DocCommentParser {
if (isJavaIdentifierStart(ch) || ch == '#') { if (isJavaIdentifierStart(ch) || ch == '#') {
DCReference ref = reference(true); DCReference ref = reference(true);
List<DCTree> description = blockContent(); List<DCTree> description = blockContent();
return m.at(pos).See(description.prepend(ref)); return m.at(pos).newSeeTree(description.prepend(ref));
} }
} }
throw new ParseException("dc.unexpected.content"); throw new ParseException("dc.unexpected.content");
@ -1203,7 +1206,7 @@ public class DocCommentParser {
new TagParser(Kind.BLOCK, DCTree.Kind.SERIAL_DATA) { new TagParser(Kind.BLOCK, DCTree.Kind.SERIAL_DATA) {
public DCTree parse(int pos) { public DCTree parse(int pos) {
List<DCTree> description = blockContent(); List<DCTree> description = blockContent();
return m.at(pos).SerialData(description); return m.at(pos).newSerialDataTree(description);
} }
}, },
@ -1219,7 +1222,7 @@ public class DocCommentParser {
skipWhitespace(); skipWhitespace();
description = blockContent(); description = blockContent();
} }
return m.at(pos).SerialField(name, type, description); return m.at(pos).newSerialFieldTree(name, type, description);
} }
}, },
@ -1227,7 +1230,7 @@ public class DocCommentParser {
new TagParser(Kind.BLOCK, DCTree.Kind.SERIAL) { new TagParser(Kind.BLOCK, DCTree.Kind.SERIAL) {
public DCTree parse(int pos) { public DCTree parse(int pos) {
List<DCTree> description = blockContent(); List<DCTree> description = blockContent();
return m.at(pos).Serial(description); return m.at(pos).newSerialTree(description);
} }
}, },
@ -1235,7 +1238,7 @@ public class DocCommentParser {
new TagParser(Kind.BLOCK, DCTree.Kind.SINCE) { new TagParser(Kind.BLOCK, DCTree.Kind.SINCE) {
public DCTree parse(int pos) { public DCTree parse(int pos) {
List<DCTree> description = blockContent(); List<DCTree> description = blockContent();
return m.at(pos).Since(description); return m.at(pos).newSinceTree(description);
} }
}, },
@ -1245,7 +1248,7 @@ public class DocCommentParser {
skipWhitespace(); skipWhitespace();
DCReference ref = reference(false); DCReference ref = reference(false);
List<DCTree> description = blockContent(); List<DCTree> description = blockContent();
return m.at(pos).Throws(ref, description); return m.at(pos).newThrowsTree(ref, description);
} }
}, },
@ -1256,7 +1259,7 @@ public class DocCommentParser {
skipWhitespace(); skipWhitespace();
if (ch == '}') { if (ch == '}') {
nextChar(); nextChar();
return m.at(pos).Value(ref); return m.at(pos).newValueTree(ref);
} }
nextChar(); nextChar();
throw new ParseException("dc.unexpected.content"); throw new ParseException("dc.unexpected.content");
@ -1267,7 +1270,7 @@ public class DocCommentParser {
new TagParser(Kind.BLOCK, DCTree.Kind.VERSION) { new TagParser(Kind.BLOCK, DCTree.Kind.VERSION) {
public DCTree parse(int pos) { public DCTree parse(int pos) {
List<DCTree> description = blockContent(); List<DCTree> description = blockContent();
return m.at(pos).Version(description); return m.at(pos).newVersionTree(description);
} }
}, },
}; };

View File

@ -0,0 +1,178 @@
/*
* Copyright (c) 2012, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
package com.sun.tools.javac.parser;
import com.sun.tools.javac.parser.Tokens.TokenKind;
import com.sun.tools.javac.tree.JCTree;
import com.sun.tools.javac.util.List;
import com.sun.tools.javac.util.ListBuffer;
import com.sun.tools.javac.util.Log;
import com.sun.tools.javac.util.Name;
/**
* A utility class to parse a string in a doc comment containing a
* reference to an API element, such as a type, field or method.
*
* <p><b>This is NOT part of any supported API.
* 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.</b>
*/
public class ReferenceParser {
/**
* An object to contain the result of parsing a reference to an API element.
* Any, but not all, of the member fields may be null.
*/
static public class Reference {
/** The type, if any, in the signature. */
public final JCTree qualExpr;
/** The member name, if any, in the signature. */
public final Name member;
/** The parameter types, if any, in the signature. */
public final List<JCTree> paramTypes;
Reference(JCTree qualExpr, Name member, List<JCTree> paramTypes) {
this.qualExpr = qualExpr;
this.member = member;
this.paramTypes = paramTypes;
}
}
/**
* An exception that indicates an error occurred while parsing a signature.
*/
static public class ParseException extends Exception {
private static final long serialVersionUID = 0;
ParseException(String message) {
super(message);
}
}
private final ParserFactory fac;
/**
* Create a parser object to parse reference signatures.
* @param fac a factory for parsing Java source code.
*/
public ReferenceParser(ParserFactory fac) {
this.fac = fac;
}
/**
* Parse a reference to an API element as may be found in doc comment.
* @param sig the signature to be parsed
* @return a {@code Reference} object containing the result of parsing the signature
* @throws ParseException if there is an error while parsing the signature
*/
public Reference parse(String sig) throws ParseException {
// Break sig apart into qualifiedExpr member paramTypes.
JCTree qualExpr;
Name member;
List<JCTree> paramTypes;
Log.DeferredDiagnosticHandler deferredDiagnosticHandler
= new Log.DeferredDiagnosticHandler(fac.log);
try {
int hash = sig.indexOf("#");
int lparen = sig.indexOf("(", hash + 1);
if (hash == -1) {
if (lparen == -1) {
qualExpr = parseType(sig);
member = null;
} else {
qualExpr = null;
member = parseMember(sig.substring(0, lparen));
}
} else {
qualExpr = (hash == 0) ? null : parseType(sig.substring(0, hash));
if (lparen == -1)
member = parseMember(sig.substring(hash + 1));
else
member = parseMember(sig.substring(hash + 1, lparen));
}
if (lparen < 0) {
paramTypes = null;
} else {
int rparen = sig.indexOf(")", lparen);
if (rparen != sig.length() - 1)
throw new ParseException("dc.ref.bad.parens");
paramTypes = parseParams(sig.substring(lparen + 1, rparen));
}
if (!deferredDiagnosticHandler.getDiagnostics().isEmpty())
throw new ParseException("dc.ref.syntax.error");
} finally {
fac.log.popDiagnosticHandler(deferredDiagnosticHandler);
}
return new Reference(qualExpr, member, paramTypes);
}
private JCTree parseType(String s) throws ParseException {
JavacParser p = fac.newParser(s, false, false, false);
JCTree tree = p.parseType();
if (p.token().kind != TokenKind.EOF)
throw new ParseException("dc.ref.unexpected.input");
return tree;
}
private Name parseMember(String s) throws ParseException {
JavacParser p = fac.newParser(s, false, false, false);
Name name = p.ident();
if (p.token().kind != TokenKind.EOF)
throw new ParseException("dc.ref.unexpected.input");
return name;
}
private List<JCTree> parseParams(String s) throws ParseException {
if (s.trim().isEmpty())
return List.nil();
JavacParser p = fac.newParser(s.replace("...", "[]"), false, false, false);
ListBuffer<JCTree> paramTypes = new ListBuffer<>();
paramTypes.add(p.parseType());
if (p.token().kind == TokenKind.IDENTIFIER)
p.nextToken();
while (p.token().kind == TokenKind.COMMA) {
p.nextToken();
paramTypes.add(p.parseType());
if (p.token().kind == TokenKind.IDENTIFIER)
p.nextToken();
}
if (p.token().kind != TokenKind.EOF)
throw new ParseException("dc.ref.unexpected.input");
return paramTypes.toList();
}
}

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -35,13 +35,13 @@ import com.sun.tools.javac.util.DefinedBy.Api;
import com.sun.tools.javac.util.DiagnosticSource; import com.sun.tools.javac.util.DiagnosticSource;
import com.sun.tools.javac.util.JCDiagnostic; import com.sun.tools.javac.util.JCDiagnostic;
import com.sun.tools.javac.util.JCDiagnostic.SimpleDiagnosticPosition; import com.sun.tools.javac.util.JCDiagnostic.SimpleDiagnosticPosition;
import com.sun.tools.javac.util.List;
import com.sun.tools.javac.util.Name;
import com.sun.tools.javac.util.Position; import com.sun.tools.javac.util.Position;
import java.io.IOException; import java.io.IOException;
import java.io.StringWriter; import java.io.StringWriter;
import java.util.List;
import javax.lang.model.element.Name;
import javax.tools.JavaFileObject; import javax.tools.JavaFileObject;
/** /**
@ -122,32 +122,32 @@ public abstract class DCTree implements DocTree {
this.tags = tags; this.tags = tags;
} }
@DefinedBy(Api.COMPILER_TREE) @Override @DefinedBy(Api.COMPILER_TREE)
public Kind getKind() { public Kind getKind() {
return Kind.DOC_COMMENT; return Kind.DOC_COMMENT;
} }
@DefinedBy(Api.COMPILER_TREE) @Override @DefinedBy(Api.COMPILER_TREE)
public <R, D> R accept(DocTreeVisitor<R, D> v, D d) { public <R, D> R accept(DocTreeVisitor<R, D> v, D d) {
return v.visitDocComment(this, d); return v.visitDocComment(this, d);
} }
@DefinedBy(Api.COMPILER_TREE) @Override @DefinedBy(Api.COMPILER_TREE)
public List<? extends DocTree> getFirstSentence() { public List<? extends DocTree> getFirstSentence() {
return firstSentence; return firstSentence;
} }
@DefinedBy(Api.COMPILER_TREE) @Override @DefinedBy(Api.COMPILER_TREE)
public List<? extends DocTree> getFullBody() { public List<? extends DocTree> getFullBody() {
return fullBody; return fullBody;
} }
@DefinedBy(Api.COMPILER_TREE) @Override @DefinedBy(Api.COMPILER_TREE)
public List<? extends DocTree> getBody() { public List<? extends DocTree> getBody() {
return body; return body;
} }
@DefinedBy(Api.COMPILER_TREE) @Override @DefinedBy(Api.COMPILER_TREE)
public List<? extends DocTree> getBlockTags() { public List<? extends DocTree> getBlockTags() {
return tags; return tags;
} }
@ -155,14 +155,14 @@ public abstract class DCTree implements DocTree {
} }
public static abstract class DCBlockTag extends DCTree implements BlockTagTree { public static abstract class DCBlockTag extends DCTree implements BlockTagTree {
@DefinedBy(Api.COMPILER_TREE) @Override @DefinedBy(Api.COMPILER_TREE)
public String getTagName() { public String getTagName() {
return getKind().tagName; return getKind().tagName;
} }
} }
public static abstract class DCInlineTag extends DCEndPosTree<DCInlineTag> implements InlineTagTree { public static abstract class DCInlineTag extends DCEndPosTree<DCInlineTag> implements InlineTagTree {
@DefinedBy(Api.COMPILER_TREE) @Override @DefinedBy(Api.COMPILER_TREE)
public String getTagName() { public String getTagName() {
return getKind().tagName; return getKind().tagName;
} }
@ -343,6 +343,11 @@ public abstract class DCTree implements DocTree {
this.diag = diags.error(null, diagSource, this, code, args); this.diag = diags.error(null, diagSource, this, code, args);
} }
DCErroneous(String body, JCDiagnostic diag) {
this.body = body;
this.diag = diag;
}
@Override @DefinedBy(Api.COMPILER_TREE) @Override @DefinedBy(Api.COMPILER_TREE)
public Kind getKind() { public Kind getKind() {
return Kind.ERRONEOUS; return Kind.ERRONEOUS;

View File

@ -1,5 +1,5 @@
/* /*
* Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. * Copyright (c) 2011, 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
* *
* This code is free software; you can redistribute it and/or modify it * This code is free software; you can redistribute it and/or modify it
@ -29,16 +29,26 @@ import java.text.BreakIterator;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.EnumSet; import java.util.EnumSet;
import java.util.List;
import java.util.ListIterator; import java.util.ListIterator;
import javax.lang.model.element.Name;
import javax.tools.Diagnostic;
import javax.tools.JavaFileObject;
import com.sun.source.doctree.AttributeTree.ValueKind; import com.sun.source.doctree.AttributeTree.ValueKind;
import com.sun.source.doctree.DocTree; import com.sun.source.doctree.DocTree;
import com.sun.source.doctree.DocTree.Kind; import com.sun.source.doctree.DocTree.Kind;
import com.sun.source.doctree.EndElementTree; import com.sun.source.doctree.EndElementTree;
import com.sun.source.doctree.IdentifierTree;
import com.sun.source.doctree.ReferenceTree;
import com.sun.source.doctree.StartElementTree; import com.sun.source.doctree.StartElementTree;
import com.sun.source.doctree.TextTree; import com.sun.source.doctree.TextTree;
import com.sun.source.util.DocTreeFactory;
import com.sun.tools.doclint.HtmlTag; import com.sun.tools.doclint.HtmlTag;
import com.sun.tools.javac.api.JavacTrees; import com.sun.tools.javac.api.JavacTrees;
import com.sun.tools.javac.parser.ParserFactory;
import com.sun.tools.javac.parser.ReferenceParser;
import com.sun.tools.javac.parser.Tokens.Comment; import com.sun.tools.javac.parser.Tokens.Comment;
import com.sun.tools.javac.tree.DCTree.DCAttribute; import com.sun.tools.javac.tree.DCTree.DCAttribute;
import com.sun.tools.javac.tree.DCTree.DCAuthor; import com.sun.tools.javac.tree.DCTree.DCAuthor;
@ -70,12 +80,12 @@ import com.sun.tools.javac.tree.DCTree.DCUnknownInlineTag;
import com.sun.tools.javac.tree.DCTree.DCValue; import com.sun.tools.javac.tree.DCTree.DCValue;
import com.sun.tools.javac.tree.DCTree.DCVersion; import com.sun.tools.javac.tree.DCTree.DCVersion;
import com.sun.tools.javac.util.Context; import com.sun.tools.javac.util.Context;
import com.sun.tools.javac.util.DefinedBy;
import com.sun.tools.javac.util.DefinedBy.Api;
import com.sun.tools.javac.util.DiagnosticSource; import com.sun.tools.javac.util.DiagnosticSource;
import com.sun.tools.javac.util.JCDiagnostic; import com.sun.tools.javac.util.JCDiagnostic;
import com.sun.tools.javac.util.JCDiagnostic.DiagnosticPosition; import com.sun.tools.javac.util.JCDiagnostic.DiagnosticPosition;
import com.sun.tools.javac.util.List;
import com.sun.tools.javac.util.ListBuffer; import com.sun.tools.javac.util.ListBuffer;
import com.sun.tools.javac.util.Name;
import com.sun.tools.javac.util.Pair; import com.sun.tools.javac.util.Pair;
import com.sun.tools.javac.util.Position; import com.sun.tools.javac.util.Position;
@ -88,7 +98,7 @@ import static com.sun.tools.doclint.HtmlTag.*;
* This code and its internal interfaces are subject to change or * This code and its internal interfaces are subject to change or
* deletion without notice.</b> * deletion without notice.</b>
*/ */
public class DocTreeMaker { public class DocTreeMaker implements DocTreeFactory {
/** The context key for the tree factory. */ /** The context key for the tree factory. */
protected static final Context.Key<DocTreeMaker> treeMakerKey = new Context.Key<>(); protected static final Context.Key<DocTreeMaker> treeMakerKey = new Context.Key<>();
@ -114,6 +124,9 @@ public class DocTreeMaker {
private final JavacTrees trees; private final JavacTrees trees;
/** Utility class to parse reference signatures. */
private final ReferenceParser referenceParser;
/** Create a tree maker with NOPOS as initial position. /** Create a tree maker with NOPOS as initial position.
*/ */
protected DocTreeMaker(Context context) { protected DocTreeMaker(Context context) {
@ -121,11 +134,13 @@ public class DocTreeMaker {
diags = JCDiagnostic.Factory.instance(context); diags = JCDiagnostic.Factory.instance(context);
this.pos = Position.NOPOS; this.pos = Position.NOPOS;
trees = JavacTrees.instance(context); trees = JavacTrees.instance(context);
referenceParser = new ReferenceParser(ParserFactory.instance(context));
sentenceBreakTags = EnumSet.of(H1, H2, H3, H4, H5, H6, PRE, P); sentenceBreakTags = EnumSet.of(H1, H2, H3, H4, H5, H6, PRE, P);
} }
/** Reassign current position. /** Reassign current position.
*/ */
@Override @DefinedBy(Api.COMPILER_TREE)
public DocTreeMaker at(int pos) { public DocTreeMaker at(int pos) {
this.pos = pos; this.pos = pos;
return this; return this;
@ -138,39 +153,44 @@ public class DocTreeMaker {
return this; return this;
} }
public DCAttribute Attribute(Name name, ValueKind vkind, List<DCTree> value) { @Override @DefinedBy(Api.COMPILER_TREE)
DCAttribute tree = new DCAttribute(name, vkind, value); public DCAttribute newAttributeTree(javax.lang.model.element.Name name, ValueKind vkind, java.util.List<? extends DocTree> value) {
DCAttribute tree = new DCAttribute(name, vkind, cast(value));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCAuthor Author(List<DCTree> name) { @Override @DefinedBy(Api.COMPILER_TREE)
DCAuthor tree = new DCAuthor(name); public DCAuthor newAuthorTree(java.util.List<? extends DocTree> name) {
DCAuthor tree = new DCAuthor(cast(name));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCLiteral Code(DCText text) { @Override @DefinedBy(Api.COMPILER_TREE)
DCLiteral tree = new DCLiteral(Kind.CODE, text); public DCLiteral newCodeTree(TextTree text) {
DCLiteral tree = new DCLiteral(Kind.CODE, (DCText) text);
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCComment Comment(String text) { @Override @DefinedBy(Api.COMPILER_TREE)
public DCComment newCommentTree(String text) {
DCComment tree = new DCComment(text); DCComment tree = new DCComment(text);
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCDeprecated Deprecated(List<DCTree> text) { @Override @DefinedBy(Api.COMPILER_TREE)
DCDeprecated tree = new DCDeprecated(text); public DCDeprecated newDeprecatedTree(List<? extends DocTree> text) {
DCDeprecated tree = new DCDeprecated(cast(text));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCDocComment DocComment(Comment comment, List<DCTree> fullBody, List<DCTree> tags) { public DCDocComment newDocCommentTree(Comment comment, List<? extends DocTree> fullBody, List<? extends DocTree> tags) {
Pair<List<DCTree>, List<DCTree>> pair = splitBody(fullBody); Pair<List<DCTree>, List<DCTree>> pair = splitBody(fullBody);
DCDocComment tree = new DCDocComment(comment, fullBody, pair.fst, pair.snd, tags); DCDocComment tree = new DCDocComment(comment, cast(fullBody), pair.fst, pair.snd, cast(tags));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
@ -180,172 +200,219 @@ public class DocTreeMaker {
* first sentence and a body, this is useful, in cases * first sentence and a body, this is useful, in cases
* where the trees are being synthesized by a tool. * where the trees are being synthesized by a tool.
*/ */
public DCDocComment DocComment(List<DCTree> firstSentence, List<DCTree> body, List<DCTree> tags) { @Override @DefinedBy(Api.COMPILER_TREE)
public DCDocComment newDocCommentTree(List<? extends DocTree> firstSentence, List<? extends DocTree> body, List<? extends DocTree> tags) {
ListBuffer<DCTree> lb = new ListBuffer<>(); ListBuffer<DCTree> lb = new ListBuffer<>();
lb.addAll(firstSentence); lb.addAll(cast(firstSentence));
lb.addAll(body); lb.addAll(cast(body));
List<DCTree> fullBody = lb.toList(); List<DCTree> fullBody = lb.toList();
DCDocComment tree = new DCDocComment(null, fullBody, firstSentence, body, tags); DCDocComment tree = new DCDocComment(null, fullBody, cast(firstSentence), cast(body), cast(tags));
return tree; return tree;
} }
public DCDocRoot DocRoot() { @Override @DefinedBy(Api.COMPILER_TREE)
public DCDocRoot newDocRootTree() {
DCDocRoot tree = new DCDocRoot(); DCDocRoot tree = new DCDocRoot();
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCEndElement EndElement(Name name) { @Override @DefinedBy(Api.COMPILER_TREE)
public DCEndElement newEndElementTree(Name name) {
DCEndElement tree = new DCEndElement(name); DCEndElement tree = new DCEndElement(name);
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCEntity Entity(Name name) { @Override @DefinedBy(Api.COMPILER_TREE)
public DCEntity newEntityTree(Name name) {
DCEntity tree = new DCEntity(name); DCEntity tree = new DCEntity(name);
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCErroneous Erroneous(String text, DiagnosticSource diagSource, String code, Object... args) { @Override @DefinedBy(Api.COMPILER_TREE)
public DCErroneous newErroneousTree(String text, Diagnostic<JavaFileObject> diag) {
DCErroneous tree = new DCErroneous(text, (JCDiagnostic) diag);
tree.pos = pos;
return tree;
}
public DCErroneous newErroneousTree(String text, DiagnosticSource diagSource, String code, Object... args) {
DCErroneous tree = new DCErroneous(text, diags, diagSource, code, args); DCErroneous tree = new DCErroneous(text, diags, diagSource, code, args);
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCThrows Exception(DCReference name, List<DCTree> description) { @Override @DefinedBy(Api.COMPILER_TREE)
DCThrows tree = new DCThrows(Kind.EXCEPTION, name, description); public DCThrows newExceptionTree(ReferenceTree name, List<? extends DocTree> description) {
// TODO: verify the reference is just to a type (not a field or method)
DCThrows tree = new DCThrows(Kind.EXCEPTION, (DCReference) name, cast(description));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCIdentifier Identifier(Name name) { @Override @DefinedBy(Api.COMPILER_TREE)
public DCIdentifier newIdentifierTree(Name name) {
DCIdentifier tree = new DCIdentifier(name); DCIdentifier tree = new DCIdentifier(name);
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCIndex Index(DCTree term, List<DCTree> description) { @Override @DefinedBy(Api.COMPILER_TREE)
DCIndex tree = new DCIndex(term, description); public DCIndex newIndexTree(DocTree term, List<? extends DocTree> description) {
DCIndex tree = new DCIndex((DCTree) term, cast(description));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCInheritDoc InheritDoc() { @Override @DefinedBy(Api.COMPILER_TREE)
public DCInheritDoc newInheritDocTree() {
DCInheritDoc tree = new DCInheritDoc(); DCInheritDoc tree = new DCInheritDoc();
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCLink Link(DCReference ref, List<DCTree> label) { @Override @DefinedBy(Api.COMPILER_TREE)
DCLink tree = new DCLink(Kind.LINK, ref, label); public DCLink newLinkTree(ReferenceTree ref, List<? extends DocTree> label) {
DCLink tree = new DCLink(Kind.LINK, (DCReference) ref, cast(label));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCLink LinkPlain(DCReference ref, List<DCTree> label) { @Override @DefinedBy(Api.COMPILER_TREE)
DCLink tree = new DCLink(Kind.LINK_PLAIN, ref, label); public DCLink newLinkPlainTree(ReferenceTree ref, List<? extends DocTree> label) {
DCLink tree = new DCLink(Kind.LINK_PLAIN, (DCReference) ref, cast(label));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCLiteral Literal(DCText text) { @Override @DefinedBy(Api.COMPILER_TREE)
DCLiteral tree = new DCLiteral(Kind.LITERAL, text); public DCLiteral newLiteralTree(TextTree text) {
DCLiteral tree = new DCLiteral(Kind.LITERAL, (DCText) text);
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCParam Param(boolean isTypeParameter, DCIdentifier name, List<DCTree> description) { @Override @DefinedBy(Api.COMPILER_TREE)
DCParam tree = new DCParam(isTypeParameter, name, description); public DCParam newParamTree(boolean isTypeParameter, IdentifierTree name, List<? extends DocTree> description) {
DCParam tree = new DCParam(isTypeParameter, (DCIdentifier) name, cast(description));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCReference Reference(String signature, @Override @DefinedBy(Api.COMPILER_TREE)
JCTree qualExpr, Name member, List<JCTree> paramTypes) { public DCReference newReferenceTree(String signature) {
try {
ReferenceParser.Reference ref = referenceParser.parse(signature);
DCReference tree = new DCReference(signature, ref.qualExpr, ref.member, ref.paramTypes);
tree.pos = pos;
return tree;
} catch (ReferenceParser.ParseException e) {
throw new IllegalArgumentException("invalid signature", e);
}
}
public DCReference newReferenceTree(String signature, JCTree qualExpr, Name member, List<JCTree> paramTypes) {
DCReference tree = new DCReference(signature, qualExpr, member, paramTypes); DCReference tree = new DCReference(signature, qualExpr, member, paramTypes);
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCReturn Return(List<DCTree> description) { @Override @DefinedBy(Api.COMPILER_TREE)
DCReturn tree = new DCReturn(description); public DCReturn newReturnTree(List<? extends DocTree> description) {
DCReturn tree = new DCReturn(cast(description));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCSee See(List<DCTree> reference) { @Override @DefinedBy(Api.COMPILER_TREE)
DCSee tree = new DCSee(reference); public DCSee newSeeTree(List<? extends DocTree> reference) {
DCSee tree = new DCSee(cast(reference));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCSerial Serial(List<DCTree> description) { @Override @DefinedBy(Api.COMPILER_TREE)
DCSerial tree = new DCSerial(description); public DCSerial newSerialTree(List<? extends DocTree> description) {
DCSerial tree = new DCSerial(cast(description));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCSerialData SerialData(List<DCTree> description) { @Override @DefinedBy(Api.COMPILER_TREE)
DCSerialData tree = new DCSerialData(description); public DCSerialData newSerialDataTree(List<? extends DocTree> description) {
DCSerialData tree = new DCSerialData(cast(description));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCSerialField SerialField(DCIdentifier name, DCReference type, List<DCTree> description) { @Override @DefinedBy(Api.COMPILER_TREE)
DCSerialField tree = new DCSerialField(name, type, description); public DCSerialField newSerialFieldTree(IdentifierTree name, ReferenceTree type, List<? extends DocTree> description) {
DCSerialField tree = new DCSerialField((DCIdentifier) name, (DCReference) type, cast(description));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCSince Since(List<DCTree> text) { @Override @DefinedBy(Api.COMPILER_TREE)
DCSince tree = new DCSince(text); public DCSince newSinceTree(List<? extends DocTree> text) {
DCSince tree = new DCSince(cast(text));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCStartElement StartElement(Name name, List<DCTree> attrs, boolean selfClosing) { @Override @DefinedBy(Api.COMPILER_TREE)
DCStartElement tree = new DCStartElement(name, attrs, selfClosing); public DCStartElement newStartElementTree(Name name, List<? extends DocTree> attrs, boolean selfClosing) {
DCStartElement tree = new DCStartElement(name, cast(attrs), selfClosing);
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCText Text(String text) { @Override @DefinedBy(Api.COMPILER_TREE)
public DCText newTextTree(String text) {
DCText tree = new DCText(text); DCText tree = new DCText(text);
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCThrows Throws(DCReference name, List<DCTree> description) { @Override @DefinedBy(Api.COMPILER_TREE)
DCThrows tree = new DCThrows(Kind.THROWS, name, description); public DCThrows newThrowsTree(ReferenceTree name, List<? extends DocTree> description) {
// TODO: verify the reference is just to a type (not a field or method)
DCThrows tree = new DCThrows(Kind.THROWS, (DCReference) name, cast(description));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCUnknownBlockTag UnknownBlockTag(Name name, List<DCTree> content) { @Override @DefinedBy(Api.COMPILER_TREE)
DCUnknownBlockTag tree = new DCUnknownBlockTag(name, content); public DCUnknownBlockTag newUnknownBlockTagTree(Name name, List<? extends DocTree> content) {
DCUnknownBlockTag tree = new DCUnknownBlockTag(name, cast(content));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCUnknownInlineTag UnknownInlineTag(Name name, List<DCTree> content) { @Override @DefinedBy(Api.COMPILER_TREE)
DCUnknownInlineTag tree = new DCUnknownInlineTag(name, content); public DCUnknownInlineTag newUnknownInlineTagTree(Name name, List<? extends DocTree> content) {
DCUnknownInlineTag tree = new DCUnknownInlineTag(name, cast(content));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCValue Value(DCReference ref) { @Override @DefinedBy(Api.COMPILER_TREE)
DCValue tree = new DCValue(ref); public DCValue newValueTree(ReferenceTree ref) {
// TODO: verify the reference is to a constant value
DCValue tree = new DCValue((DCReference) ref);
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
public DCVersion Version(List<DCTree> text) { @Override @DefinedBy(Api.COMPILER_TREE)
DCVersion tree = new DCVersion(text); public DCVersion newVersionTree(List<? extends DocTree> text) {
DCVersion tree = new DCVersion(cast(text));
tree.pos = pos; tree.pos = pos;
return tree; return tree;
} }
@Override @DefinedBy(Api.COMPILER_TREE)
public java.util.List<DocTree> getFirstSentence(java.util.List<? extends DocTree> list) { public java.util.List<DocTree> getFirstSentence(java.util.List<? extends DocTree> list) {
Pair<List<DCTree>, List<DCTree>> pair = splitBody(list); Pair<List<DCTree>, List<DCTree>> pair = splitBody(list);
return new ArrayList<>(pair.fst); return new ArrayList<>(pair.fst);
@ -389,12 +456,12 @@ public class DocTreeMaker {
int sbreak = getSentenceBreak(s, peekedNext); int sbreak = getSentenceBreak(s, peekedNext);
if (sbreak > 0) { if (sbreak > 0) {
s = removeTrailingWhitespace(s.substring(0, sbreak)); s = removeTrailingWhitespace(s.substring(0, sbreak));
DCText text = this.at(spos).Text(s); DCText text = this.at(spos).newTextTree(s);
fs.add(text); fs.add(text);
foundFirstSentence = true; foundFirstSentence = true;
int nwPos = skipWhiteSpace(tt.getBody(), sbreak); int nwPos = skipWhiteSpace(tt.getBody(), sbreak);
if (nwPos > 0) { if (nwPos > 0) {
DCText text2 = this.at(spos + nwPos).Text(tt.getBody().substring(nwPos)); DCText text2 = this.at(spos + nwPos).newTextTree(tt.getBody().substring(nwPos));
body.add(text2); body.add(text2);
} }
continue; continue;
@ -405,7 +472,7 @@ public class DocTreeMaker {
if (sbrk) { if (sbrk) {
DocTree next = itr.next(); DocTree next = itr.next();
s = removeTrailingWhitespace(s); s = removeTrailingWhitespace(s);
DCText text = this.at(spos).Text(s); DCText text = this.at(spos).newTextTree(s);
fs.add(text); fs.add(text);
body.add((DCTree) next); body.add((DCTree) next);
foundFirstSentence = true; foundFirstSentence = true;
@ -436,7 +503,7 @@ public class DocTreeMaker {
/* /*
* Computes the first sentence break, a simple dot-space algorithm. * Computes the first sentence break, a simple dot-space algorithm.
*/ */
int defaultSentenceBreak(String s) { private int defaultSentenceBreak(String s) {
// scan for period followed by whitespace // scan for period followed by whitespace
int period = -1; int period = -1;
for (int i = 0; i < s.length(); i++) { for (int i = 0; i < s.length(); i++) {
@ -483,7 +550,7 @@ public class DocTreeMaker {
* Therefore, we have to probe further to determine whether * Therefore, we have to probe further to determine whether
* there really is a sentence break or not at the end of this run of text. * there really is a sentence break or not at the end of this run of text.
*/ */
int getSentenceBreak(String s, DocTree dt) { private int getSentenceBreak(String s, DocTree dt) {
BreakIterator breakIterator = trees.getBreakIterator(); BreakIterator breakIterator = trees.getBreakIterator();
if (breakIterator == null) { if (breakIterator == null) {
return defaultSentenceBreak(s); return defaultSentenceBreak(s);
@ -533,11 +600,11 @@ public class DocTreeMaker {
return -1; // indeterminate at this time return -1; // indeterminate at this time
} }
boolean isSentenceBreak(javax.lang.model.element.Name tagName) { private boolean isSentenceBreak(javax.lang.model.element.Name tagName) {
return sentenceBreakTags.contains(get(tagName)); return sentenceBreakTags.contains(get(tagName));
} }
boolean isSentenceBreak(DocTree dt, boolean isFirstDocTree) { private boolean isSentenceBreak(DocTree dt, boolean isFirstDocTree) {
switch (dt.getKind()) { switch (dt.getKind()) {
case START_ELEMENT: case START_ELEMENT:
StartElementTree set = (StartElementTree)dt; StartElementTree set = (StartElementTree)dt;
@ -553,7 +620,7 @@ public class DocTreeMaker {
/* /*
* Returns the position of the the first non-white space * Returns the position of the the first non-white space
*/ */
int skipWhiteSpace(String s, int start) { private int skipWhiteSpace(String s, int start) {
for (int i = start; i < s.length(); i++) { for (int i = start; i < s.length(); i++) {
char c = s.charAt(i); char c = s.charAt(i);
if (!Character.isWhitespace(c)) { if (!Character.isWhitespace(c)) {
@ -563,7 +630,7 @@ public class DocTreeMaker {
return -1; return -1;
} }
String removeTrailingWhitespace(String s) { private String removeTrailingWhitespace(String s) {
for (int i = s.length() - 1 ; i >= 0 ; i--) { for (int i = s.length() - 1 ; i >= 0 ; i--) {
char ch = s.charAt(i); char ch = s.charAt(i);
if (!Character.isWhitespace(ch)) { if (!Character.isWhitespace(ch)) {
@ -572,4 +639,9 @@ public class DocTreeMaker {
} }
return s; return s;
} }
@SuppressWarnings("unchecked")
private List<DCTree> cast(List<? extends DocTree> list) {
return (List<DCTree>) list;
}
} }

View File

@ -235,16 +235,16 @@ public class RichDiagnosticFormatter extends
} }
private boolean unique(TypeVar typevar) { private boolean unique(TypeVar typevar) {
typevar = (TypeVar)typevar.stripMetadataIfNeeded(); typevar = (TypeVar) typevar.stripMetadata();
int found = 0; int found = 0;
for (Type t : whereClauses.get(WhereClauseKind.TYPEVAR).keySet()) { for (Type t : whereClauses.get(WhereClauseKind.TYPEVAR).keySet()) {
if (t.toString().equals(typevar.toString())) { if (t.stripMetadata().toString().equals(typevar.toString())) {
found++; found++;
} }
} }
if (found < 1) if (found < 1)
throw new AssertionError("Missing type variable in where clause " + typevar); throw new AssertionError("Missing type variable in where clause: " + typevar);
return found == 1; return found == 1;
} }
//where //where

View File

@ -412,7 +412,15 @@ jck-runtime-summary: FRC
fi fi
# Check to make sure these directories exist # Check to make sure these directories exist
check-jck: $(JCK_HOME) $(PRODUCT_HOME) check-jck:
if [ ! -d '$(JCK_HOME)' ]; then \
echo "JCK_HOME $(JCK_HOME) missing" ; \
$(EXIT) 1 ; \
fi
if [ ! -d '$(PRODUCT_HOME)' ]; then \
echo "PRODUCT_HOME $(PRODUCT_HOME) missing" ; \
$(EXIT) 1 ; \
fi
all-summary: FRC all-summary: FRC
@if [ -n "`find $(TEST_OUTPUT_DIR) -name status.txt`" ]; then @if [ -n "`find $(TEST_OUTPUT_DIR) -name status.txt`" ]; then

View File

@ -0,0 +1,45 @@
/*
* Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation.
*
* This code is distributed in the hope that it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
* version 2 for more details (a copy is included in the LICENSE file that
* accompanied this code).
*
* You should have received a copy of the GNU General Public License version
* 2 along with this work; if not, write to the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
*
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* @test
* @bug 8144580
* @summary java.lang.AssertionError: Missing type variable in where clause: T
* @compile -Xlint:unchecked RichFormatterWithAnnotationsTest.java
*/
import java.lang.annotation.*;
import java.util.*;
public class RichFormatterWithAnnotationsTest {
@Target({ElementType.TYPE_USE})
@interface NonNull { }
public static <T> void test() {
final Collection<@NonNull T> c = new LinkedList<>();
final List<@NonNull String> l = new LinkedList<@NonNull String>((Collection<@NonNull String>) c) {
// empty
};
}
}

View File

@ -0,0 +1,45 @@
/*
* Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/**
* @test
* @bug 8147493
* @summary regression when type-checking unchecked method calls
* @compile T8147493a.java
*/
abstract class T8147493a {
interface One {}
interface Two<I extends One> { I get(); }
interface Three<T> {}
interface Four<T> {}
<E extends Two<?>, L extends Three<E>> Four<L> f(Class raw, E destination) {
return g(raw, destination.get());
}
abstract <I extends One, E extends Two<I>, L extends Three<E>> Four<L> g(
Class<L> labelClass, I destinationId);
}

View File

@ -0,0 +1,42 @@
/*
* Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/**
* @test
* @bug 8147493
* @summary regression when type-checking unchecked method calls
* @compile T8147493b.java
*/
abstract class T8147493b {
abstract <A> A f(A t);
abstract <B> Class<B> g(Class<B> x, String y);
abstract <C> void h(C t);
void m(Class raw) {
h(g(raw, f(null)));
}
}

View File

@ -0,0 +1,46 @@
/*
* Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* @test
* @bug 8147546
* @summary regression when type-checking generic calls inside nested declarations occurring in method context
* @compile T8147546a.java
*/
abstract class T8147546a {
interface I<O> { void t(O clazz); }
abstract <A> I<A> a(Class<A> clazz);
abstract <B> B b(Class<B> t);
abstract <C> C c(C a);
Object f(Iterable<Object> xs) {
return c(c(new Object() {
<T> void g(Class<T> clazz) {
a(clazz).t(b(clazz));
}
}));
}
}

View File

@ -0,0 +1,51 @@
/*
* Copyright (c) 2016, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
* under the terms of the GNU General Public License version 2 only, as
* published by the Free Software Foundation. Oracle designates this
* particular file as subject to the "Classpath" exception as provided
* by Oracle 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 Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
* or visit www.oracle.com if you need additional information or have any
* questions.
*/
/*
* @test
* @bug 8147546
* @summary regression when type-checking generic calls inside nested declarations occurring in method context
* @compile T8147546b.java
*/
abstract class T8147546b {
interface I<O> { void t(O clazz); }
abstract <B> B b(Class<B> t);
abstract <C> C c(C a);
abstract Object d(Runnable r);
Object f(Iterable<Object> xs) {
return c(d(
() -> {
class Foo {
<T> void g(Class<T> clazz, I<T> i) {
i.t(b(clazz));
}
}
}));
}
}

View File

@ -163,7 +163,7 @@ class DocCommentGenerator {
"1.6, 12/11/06", "1.6, 12/11/06",
"1.7, 07/28/11", "1.7, 07/28/11",
"1.8, 04/19/14", "1.8, 04/19/14",
"1.9, 06/03/16" }; "9, 06/03/16" };
static int index = 0; static int index = 0;