diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/Versions.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/Versions.java index 9d08ee670f6..a44a22931f1 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/Versions.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/Versions.java @@ -26,6 +26,7 @@ package jdk.javadoc.internal; import java.util.ResourceBundle; +import java.util.stream.Collectors; import static java.util.ResourceBundle.getBundle; @@ -77,15 +78,18 @@ public final class Versions { /** * Returns a short string representation of the provided version. * - *

Examples of strings returned from this method are: "15" and - * "15-internal". + *

The string contains the dotted representation of the version number, + * followed by the prerelease info, if any. + * For example, "15", "15.1", "15.0.1", "15-internal". * * @return a short string representation of the provided version * * @throws NullPointerException if {@code v == null} */ public static String shortVersionStringOf(Runtime.Version v) { - String svstr = String.valueOf(v.feature()); + String svstr = v.version().stream() + .map(Object::toString) + .collect(Collectors.joining(".")); if (v.pre().isPresent()) { svstr += "-" + v.pre().get(); } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlConfiguration.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlConfiguration.java index a055d21daa8..743c72b1826 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlConfiguration.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlConfiguration.java @@ -159,11 +159,6 @@ public class HtmlConfiguration extends BaseConfiguration { return docletVersion; } - @Override - public String getDocletVersionString() { - return Versions.shortVersionStringOf(docletVersion); - } - @Override public Resources getDocResources() { return docResources; diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlDocletWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlDocletWriter.java index 26999451093..453341e6e76 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlDocletWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlDocletWriter.java @@ -431,7 +431,7 @@ public class HtmlDocletWriter { Content htmlComment = contents.newPage; List additionalStylesheets = configuration.getAdditionalStylesheets(); additionalStylesheets.addAll(localStylesheets); - Head head = new Head(path, configuration.getDocletVersionString(), configuration.startTime) + Head head = new Head(path, configuration.getDocletVersion(), configuration.startTime) .setTimestamp(!options.noTimestamp()) .setDescription(description) .setGenerator(getGenerator(getClass())) diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/IndexRedirectWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/IndexRedirectWriter.java index e9ace055240..99db81bcc59 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/IndexRedirectWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/IndexRedirectWriter.java @@ -75,7 +75,7 @@ public class IndexRedirectWriter extends HtmlDocletWriter { */ private void generateIndexFile() throws DocFileIOException { Content htmlComment = contents.newPage; - Head head = new Head(path, configuration.getDocletVersionString(), configuration.startTime) + Head head = new Head(path, configuration.getDocletVersion(), configuration.startTime) .setTimestamp(!options.noTimestamp()) .setDescription("index redirect") .setGenerator(getGenerator(getClass())) diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/SourceToHTMLConverter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/SourceToHTMLConverter.java index f1c58b93957..f0a13436221 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/SourceToHTMLConverter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/SourceToHTMLConverter.java @@ -235,7 +235,7 @@ public class SourceToHTMLConverter { * @param path the path for the file. */ private void writeToFile(Content body, DocPath path, TypeElement te) throws DocFileIOException { - Head head = new Head(path, configuration.getDocletVersionString(), configuration.startTime) + Head head = new Head(path, configuration.getDocletVersion(), configuration.startTime) // .setTimestamp(!options.notimestamp) // temporary: compatibility! .setTitle(resources.getText("doclet.Window_Source_title")) // .setCharset(options.charset) // temporary: compatibility! diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/Head.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/Head.java index d4a9f616b23..858de157ccf 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/Head.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/Head.java @@ -49,7 +49,7 @@ import jdk.javadoc.internal.doclets.toolkit.util.DocPaths; * deletion without notice. */ public class Head extends Content { - private final String docletVersion; + private final Runtime.Version docletVersion; private final Date generatedDate; private final DocPath pathToRoot; private String title; @@ -74,9 +74,9 @@ public class Head extends Content { * recording the time the file was created. * The doclet version should also be provided for recording in the file. * @param path the path for the file that will include this HEAD element - * @param docletVersion a string identifying the doclet version + * @param docletVersion the doclet version */ - public Head(DocPath path, String docletVersion, Date generatedDate) { + public Head(DocPath path, Runtime.Version docletVersion, Date generatedDate) { this.docletVersion = docletVersion; this.generatedDate = generatedDate; pathToRoot = path.parent().invert(); @@ -294,9 +294,8 @@ public class Head extends Content { private Comment getGeneratedBy(boolean timestamp, Date now) { String text = "Generated by javadoc"; // marker string, deliberately not localized - text += " (" + docletVersion + ")"; if (timestamp) { - text += " on " + now; + text += " ("+ docletVersion.feature() + ") on " + now; } return new Comment(text); } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/BaseConfiguration.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/BaseConfiguration.java index 2f537fc6bc7..f11a03ae871 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/BaseConfiguration.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/BaseConfiguration.java @@ -157,14 +157,6 @@ public abstract class BaseConfiguration { */ public abstract Runtime.Version getDocletVersion(); - /** - * Returns a short string representation of the version returned by - * {@linkplain #getDocletVersion()}. - * - * @return a short string representation of the version - */ - public abstract String getDocletVersionString(); - /** * This method should be defined in all those doclets (configurations), * which want to derive themselves from this BaseConfiguration. This method diff --git a/test/langtools/jdk/javadoc/doclet/testGeneratedBy/TestGeneratedBy.java b/test/langtools/jdk/javadoc/doclet/testGeneratedBy/TestGeneratedBy.java index ceb6d08fd51..299452cc646 100644 --- a/test/langtools/jdk/javadoc/doclet/testGeneratedBy/TestGeneratedBy.java +++ b/test/langtools/jdk/javadoc/doclet/testGeneratedBy/TestGeneratedBy.java @@ -79,9 +79,9 @@ public class TestGeneratedBy extends JavadocTester { } void checkTimestamps(boolean timestamp, String... files) { - String version = System.getProperty("java.version"); - String genBy = "Generated by javadoc (" + version + ")"; - if (timestamp) genBy += " on "; + String version = System.getProperty("java.specification.version"); + String genBy = "Generated by javadoc"; + if (timestamp) genBy += " (" + version + ") on "; for (String file: files) { // genBy is the current standard "Generated by" text