Merge
This commit is contained in:
commit
ea8c4d0244
@ -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}
|
||||||
|
@ -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
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -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 '<' 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);
|
||||||
|
|
||||||
|
}
|
@ -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();
|
||||||
}
|
}
|
||||||
|
@ -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 <body> 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();
|
||||||
}
|
}
|
||||||
|
@ -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) {}
|
||||||
|
@ -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
|
||||||
|
@ -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,
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
@ -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();
|
||||||
|
}
|
||||||
|
}
|
@ -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;
|
||||||
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
@ -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);
|
||||||
|
}
|
@ -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)));
|
||||||
|
}
|
||||||
|
}
|
@ -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));
|
||||||
|
}
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
}
|
@ -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));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
}
|
@ -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;
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user