diff --git a/src/share/classes/com/sun/tools/doclint/DocLint.java b/src/share/classes/com/sun/tools/doclint/DocLint.java index 0e5be61120c5378853361578a2806fff95951f1e..ca448ebe2a8905b8bd73a1e1bb3bf7a4689c9c8e 100644 --- a/src/share/classes/com/sun/tools/doclint/DocLint.java +++ b/src/share/classes/com/sun/tools/doclint/DocLint.java @@ -30,9 +30,10 @@ import java.io.IOException; import java.io.PrintWriter; import java.util.ArrayList; import java.util.List; -import java.util.regex.Pattern; import javax.lang.model.element.Name; +import javax.tools.Diagnostic; +import javax.tools.JavaFileObject; import javax.tools.StandardLocation; import com.sun.source.doctree.DocCommentTree; @@ -151,6 +152,18 @@ public class DocLint implements Plugin { TreePath p = getCurrentPath(); DocCommentTree dc = env.trees.getDocCommentTree(p); + if (p.getLeaf() == p.getCompilationUnit()) { + JavaFileObject fo = p.getCompilationUnit().getSourceFile(); + boolean pkgInfo = fo.isNameCompatible("package-info", JavaFileObject.Kind.SOURCE); + if (!pkgInfo) { + if (dc == null) + return; + env.setCurrent(p, dc); + env.messages.report(Messages.Group.REFERENCE, Diagnostic.Kind.WARNING, p.getLeaf(), + "dc.unexpected.comment"); + } + } + checker.scan(dc, p); } }; @@ -166,8 +179,8 @@ public class DocLint implements Plugin { } void processArgs(String... args) throws BadArgs { - javacOpts = new ArrayList(); - javacFiles = new ArrayList(); + javacOpts = new ArrayList<>(); + javacFiles = new ArrayList<>(); if (args.length == 0) needHelp = true; @@ -214,7 +227,7 @@ public class DocLint implements Plugin { } List splitPath(String path) { - List files = new ArrayList(); + List files = new ArrayList<>(); for (String f: path.split(File.pathSeparator)) { if (f.length() > 0) files.add(new File(f)); @@ -279,7 +292,6 @@ public class DocLint implements Plugin { TaskListener tl = new TaskListener() { @Override public void started(TaskEvent e) { - return; } @Override diff --git a/src/share/classes/com/sun/tools/doclint/resources/doclint.properties b/src/share/classes/com/sun/tools/doclint/resources/doclint.properties index 8905235d082259ba6c111e788db9b97b6efa0f1f..37470976141d1e2714e0b892a57dec19e31e59a9 100644 --- a/src/share/classes/com/sun/tools/doclint/resources/doclint.properties +++ b/src/share/classes/com/sun/tools/doclint/resources/doclint.properties @@ -67,6 +67,7 @@ dc.tag.self.closing = self-closing element not allowed dc.tag.start.unmatched = end tag missing: dc.tag.unknown = unknown tag: {0} dc.text.not.allowed = text not allowed in <{0}> element +dc.unexpected.comment=documentation comment not expected here dc.main.ioerror=IO error: {0} dc.main.no.files.given=No files given diff --git a/test/tools/doclint/BadPackageCommentTest.out b/test/tools/doclint/BadPackageCommentTest.out index 57b4db9c1b228dddbe4dcd8e79ee0c01f11b5977..768d9cb457d836e08c26220f56f19934833a2690 100644 --- a/test/tools/doclint/BadPackageCommentTest.out +++ b/test/tools/doclint/BadPackageCommentTest.out @@ -1,3 +1,6 @@ +BadPackageCommentTest.java:13: warning: documentation comment not expected here +package p; +^ BadPackageCommentTest.java:11: error: no tag name after @ * @@@ ^ @@ -8,3 +11,4 @@ BadPackageCommentTest.java:11: error: no tag name after @ * @@@ ^ 3 errors +1 warning diff --git a/test/tools/doclint/DocLintTester.java b/test/tools/doclint/DocLintTester.java index 848e284b57dfe03150d89e32e3a06a59c3f83b93..78c052a695c2354093b19bf4560e08e90b01263f 100644 --- a/test/tools/doclint/DocLintTester.java +++ b/test/tools/doclint/DocLintTester.java @@ -123,7 +123,7 @@ public class DocLintTester { private static final Pattern dirFileLine = Pattern.compile( "(?m)" // multi-line mode + "^(.*?)" // directory part of file name - + "([A-Za-z0-9.]+:[0-9]+:)"); // file name and line number + + "([-A-Za-z0-9.]+:[0-9]+:)"); // file name and line number String removeFileNames(String s) { Matcher m = dirFileLine.matcher(s); diff --git a/test/tools/doclint/packageTests/bad/Test.java b/test/tools/doclint/packageTests/bad/Test.java new file mode 100644 index 0000000000000000000000000000000000000000..25ce3621acb81100a938816927a7ce80ac2509f2 --- /dev/null +++ b/test/tools/doclint/packageTests/bad/Test.java @@ -0,0 +1,14 @@ +/* + * @test /nodynamiccopyright/ + * @bug 8020664 + * @summary doclint gives incorrect warnings on normal package statements + * @library ../.. + * @build DocLintTester + * @run main DocLintTester -ref Test.out Test.java + */ + +/** Unexpected comment */ +package bad; + +class Test { } + diff --git a/test/tools/doclint/packageTests/bad/Test.out b/test/tools/doclint/packageTests/bad/Test.out new file mode 100644 index 0000000000000000000000000000000000000000..de980ea002867fda99de79b1cbd79fd66e408713 --- /dev/null +++ b/test/tools/doclint/packageTests/bad/Test.out @@ -0,0 +1,4 @@ +Test.java:11: warning: documentation comment not expected here +package bad; +^ +1 warning diff --git a/test/tools/doclint/packageTests/bad/package-info.java b/test/tools/doclint/packageTests/bad/package-info.java new file mode 100644 index 0000000000000000000000000000000000000000..9ebdbbc990f4185eb334df70072affe5e6ea8512 --- /dev/null +++ b/test/tools/doclint/packageTests/bad/package-info.java @@ -0,0 +1,11 @@ +/* + * @test /nodynamiccopyright/ + * @bug 8020664 + * @summary doclint gives incorrect warnings on normal package statements + * @library ../.. + * @build DocLintTester + * @run main DocLintTester -ref package-info.out package-info.java + */ + +// missing comment +package bad; diff --git a/test/tools/doclint/packageTests/bad/package-info.out b/test/tools/doclint/packageTests/bad/package-info.out new file mode 100644 index 0000000000000000000000000000000000000000..fd4377caadb2b4ce8d726176ac6c4d44cf683282 --- /dev/null +++ b/test/tools/doclint/packageTests/bad/package-info.out @@ -0,0 +1,4 @@ +package-info.java:11: warning: no comment +package bad; +^ +1 warning diff --git a/test/tools/doclint/packageTests/good/Test.java b/test/tools/doclint/packageTests/good/Test.java new file mode 100644 index 0000000000000000000000000000000000000000..84db8d5ee8ecd200d46eee0c51998665a9650084 --- /dev/null +++ b/test/tools/doclint/packageTests/good/Test.java @@ -0,0 +1,37 @@ +/* + * Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test /nodynamiccopyright/ + * @bug 8020664 + * @summary doclint gives incorrect warnings on normal package statements + * @library ../.. + * @build DocLintTester + * @run main DocLintTester Test.java + */ + +// no doc comment +package good; + +class Test { } + diff --git a/test/tools/doclint/packageTests/good/package-info.java b/test/tools/doclint/packageTests/good/package-info.java new file mode 100644 index 0000000000000000000000000000000000000000..598feaed23cca38bf087f15572e75736267ff82f --- /dev/null +++ b/test/tools/doclint/packageTests/good/package-info.java @@ -0,0 +1,34 @@ +/* + * Copyright (c) 2012, 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test /nodynamiccopyright/ + * @bug 8020664 + * @summary doclint gives incorrect warnings on normal package statements + * @library ../.. + * @build DocLintTester + * @run main DocLintTester package-info.java + */ + +/** Description. */ +package good;