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