src/java.base/share/classes/java/lang/VersionProps.java.template
author rriggs
Fri, 09 Nov 2018 13:28:16 -0500
changeset 52478 b915bd68d907
parent 48670 ea6706103cef
child 52724 0bdbf854472f
permissions -rw-r--r--
8185496: Improve performance of system properties initialization in initPhase1 8213424: VersionProps duplicate and skipped initialization Reviewed-by: mchung, redestad, dholmes
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     1
/*
44785
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
     2
 * Copyright (c) 1999, 2017, Oracle and/or its affiliates. All rights reserved.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
90ce3da70b43 Initial load
duke
parents:
diff changeset
     4
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
90ce3da70b43 Initial load
duke
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 4115
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 4115
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    10
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
90ce3da70b43 Initial load
duke
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
90ce3da70b43 Initial load
duke
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
90ce3da70b43 Initial load
duke
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
90ce3da70b43 Initial load
duke
parents:
diff changeset
    15
 * accompanied this code).
90ce3da70b43 Initial load
duke
parents:
diff changeset
    16
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
90ce3da70b43 Initial load
duke
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    20
 *
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 4115
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 4115
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 4115
diff changeset
    23
 * questions.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    24
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    25
36225
6ae0eebc46e9 8150162: Move sun.misc.Version to a truly internal package
chegar
parents: 34011
diff changeset
    26
package java.lang;
6ae0eebc46e9 8150162: Move sun.misc.Version to a truly internal package
chegar
parents: 34011
diff changeset
    27
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    28
import java.io.PrintStream;
44785
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
    29
import java.util.Arrays;
39302
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
    30
import java.util.List;
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
    31
import java.util.Optional;
52478
b915bd68d907 8185496: Improve performance of system properties initialization in initPhase1
rriggs
parents: 48670
diff changeset
    32
import java.util.Properties;
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    33
36225
6ae0eebc46e9 8150162: Move sun.misc.Version to a truly internal package
chegar
parents: 34011
diff changeset
    34
class VersionProps {
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    35
90ce3da70b43 Initial load
duke
parents:
diff changeset
    36
    private static final String launcher_name =
33984
2333676816eb 8085822: JEP 223: New Version-String Scheme (initial integration)
ihse
parents: 27565
diff changeset
    37
        "@@LAUNCHER_NAME@@";
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    38
90ce3da70b43 Initial load
duke
parents:
diff changeset
    39
    private static final String java_version =
33984
2333676816eb 8085822: JEP 223: New Version-String Scheme (initial integration)
ihse
parents: 27565
diff changeset
    40
        "@@VERSION_SHORT@@";
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    41
48327
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
    42
    private static final String java_version_date =
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
    43
        "@@VERSION_DATE@@";
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
    44
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    45
    private static final String java_runtime_name =
33984
2333676816eb 8085822: JEP 223: New Version-String Scheme (initial integration)
ihse
parents: 27565
diff changeset
    46
        "@@RUNTIME_NAME@@";
15683
3acd10709925 8003256: (profiles) Add support for profile identification
alanb
parents: 8993
diff changeset
    47
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    48
    private static final String java_runtime_version =
33984
2333676816eb 8085822: JEP 223: New Version-String Scheme (initial integration)
ihse
parents: 27565
diff changeset
    49
        "@@VERSION_STRING@@";
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    50
39302
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
    51
    private static final String VERSION_NUMBER =
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
    52
        "@@VERSION_NUMBER@@";
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
    53
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
    54
    private static final String VERSION_BUILD =
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
    55
        "@@VERSION_BUILD@@";
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
    56
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
    57
    private static final String VERSION_PRE =
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
    58
        "@@VERSION_PRE@@";
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
    59
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
    60
    private static final String VERSION_OPT =
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
    61
        "@@VERSION_OPT@@";
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
    62
48327
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
    63
    private static final boolean isLTS =
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
    64
        "@@VERSION_OPT@@".startsWith("LTS");
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
    65
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
    66
    private static final String VENDOR_VERSION_STRING =
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
    67
        "@@VENDOR_VERSION_STRING@@";
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
    68
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
    69
    private static final String vendor_version =
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
    70
        (VENDOR_VERSION_STRING.length() > 0
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
    71
         ? " " + VENDOR_VERSION_STRING : "");
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
    72
52478
b915bd68d907 8185496: Improve performance of system properties initialization in initPhase1
rriggs
parents: 48670
diff changeset
    73
    public static void init(Properties props) {
b915bd68d907 8185496: Improve performance of system properties initialization in initPhase1
rriggs
parents: 48670
diff changeset
    74
        props.setProperty("java.version", java_version);
b915bd68d907 8185496: Improve performance of system properties initialization in initPhase1
rriggs
parents: 48670
diff changeset
    75
        props.setProperty("java.version.date", java_version_date);
b915bd68d907 8185496: Improve performance of system properties initialization in initPhase1
rriggs
parents: 48670
diff changeset
    76
        props.setProperty("java.runtime.version", java_runtime_version);
b915bd68d907 8185496: Improve performance of system properties initialization in initPhase1
rriggs
parents: 48670
diff changeset
    77
        props.setProperty("java.runtime.name", java_runtime_name);
48327
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
    78
        if (VENDOR_VERSION_STRING.length() > 0)
52478
b915bd68d907 8185496: Improve performance of system properties initialization in initPhase1
rriggs
parents: 48670
diff changeset
    79
            props.setProperty("java.vendor.version", VENDOR_VERSION_STRING);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    80
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    81
39648
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
    82
    private static int parseVersionNumber(String version, int prevIndex, int index) {
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
    83
        if (index - prevIndex > 1 &&
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
    84
            Character.digit(version.charAt(prevIndex), 10) <= 0)
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
    85
            throw new IllegalArgumentException("Leading zeros not supported (" +
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
    86
                    version.substring(prevIndex, index) + ")");
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
    87
        return Integer.parseInt(version, prevIndex, index, 10);
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
    88
    }
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
    89
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
    90
    // This method is reflectively used by regression tests.
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
    91
    static List<Integer> parseVersionNumbers(String version) {
44785
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
    92
        // Let's find the size of an array required to hold $VNUM components
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
    93
        int size = 0;
39302
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
    94
        int prevIndex = 0;
44785
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
    95
        do {
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
    96
            prevIndex = version.indexOf('.', prevIndex) + 1;
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
    97
            size++;
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
    98
        } while (prevIndex > 0);
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
    99
        Integer[] verNumbers = new Integer[size];
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
   100
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
   101
        // Fill in the array with $VNUM components
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
   102
        int n = 0;
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
   103
        prevIndex = 0;
39648
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
   104
        int index = version.indexOf('.');
44785
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
   105
        while (index > -1) {
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
   106
            verNumbers[n] = parseVersionNumber(version, prevIndex, index);
39314
779f1d11a746 8160457: VersionProps.versionNumbers() is broken
simonis
parents: 39302
diff changeset
   107
            prevIndex = index + 1; // Skip the period
39648
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
   108
            index = version.indexOf('.', prevIndex);
44785
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
   109
            n++;
39302
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   110
        }
44785
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
   111
        verNumbers[n] = parseVersionNumber(version, prevIndex, version.length());
39648
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
   112
44785
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
   113
        if (verNumbers[0] == 0 || verNumbers[n] == 0)
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
   114
            throw new IllegalArgumentException("Leading/trailing zeros not allowed (" +
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
   115
                    Arrays.toString(verNumbers) + ")");
39648
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
   116
44785
62a18e20f5c1 8177738: Runtime.Version must be a value-based class
prappo
parents: 42338
diff changeset
   117
        return List.of(verNumbers);
39648
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
   118
    }
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
   119
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
   120
    static List<Integer> versionNumbers() {
9bbd1300c256 8160564: TEST: Add a test to check the implementation of VersionProps.versionNumbers()
simonis
parents: 39314
diff changeset
   121
        return parseVersionNumbers(VERSION_NUMBER);
39302
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   122
    }
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   123
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   124
    static Optional<String> pre() {
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   125
        return optionalOf(VERSION_PRE);
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   126
    }
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   127
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   128
    static Optional<Integer> build() {
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   129
        return VERSION_BUILD.isEmpty() ?
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   130
                Optional.empty() :
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   131
                Optional.of(Integer.parseInt(VERSION_BUILD));
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   132
    }
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   133
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   134
    static Optional<String> optional() {
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   135
        return optionalOf(VERSION_OPT);
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   136
    }
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   137
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   138
    // Treat empty strings as value not being present
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   139
    private static Optional<String> optionalOf(String value) {
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   140
        if (!value.isEmpty()) {
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   141
            return Optional.of(value);
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   142
        } else {
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   143
            return Optional.empty();
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   144
        }
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   145
    }
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   146
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   147
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   148
     * In case you were wondering this method is called by java -version.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   149
     */
42338
a60f280f803c 8169069: Module system implementation refresh (11/2016)
alanb
parents: 40192
diff changeset
   150
    public static void print(boolean err) {
a60f280f803c 8169069: Module system implementation refresh (11/2016)
alanb
parents: 40192
diff changeset
   151
        print(err, false);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   152
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   153
90ce3da70b43 Initial load
duke
parents:
diff changeset
   154
    /**
90ce3da70b43 Initial load
duke
parents:
diff changeset
   155
     * This is the same as print except that it adds an extra line-feed
90ce3da70b43 Initial load
duke
parents:
diff changeset
   156
     * at the end, typically used by the -showversion in the launcher
90ce3da70b43 Initial load
duke
parents:
diff changeset
   157
     */
42338
a60f280f803c 8169069: Module system implementation refresh (11/2016)
alanb
parents: 40192
diff changeset
   158
    public static void println(boolean err) {
a60f280f803c 8169069: Module system implementation refresh (11/2016)
alanb
parents: 40192
diff changeset
   159
        print(err, true);
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   160
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   161
90ce3da70b43 Initial load
duke
parents:
diff changeset
   162
    /**
42338
a60f280f803c 8169069: Module system implementation refresh (11/2016)
alanb
parents: 40192
diff changeset
   163
     * Print version info.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   164
     */
42338
a60f280f803c 8169069: Module system implementation refresh (11/2016)
alanb
parents: 40192
diff changeset
   165
    private static void print(boolean err, boolean newln) {
a60f280f803c 8169069: Module system implementation refresh (11/2016)
alanb
parents: 40192
diff changeset
   166
        PrintStream ps = err ? System.err : System.out;
8993
9076d969ffdf 7025066: Build systems changes to support SE Embedded Integration
dholmes
parents: 5506
diff changeset
   167
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   168
        /* First line: platform version. */
42338
a60f280f803c 8169069: Module system implementation refresh (11/2016)
alanb
parents: 40192
diff changeset
   169
        if (err) {
48327
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
   170
            ps.println(launcher_name + " version \"" + java_version + "\""
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
   171
                       + " " + java_version_date
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
   172
                       + (isLTS ? " LTS" : ""));
42338
a60f280f803c 8169069: Module system implementation refresh (11/2016)
alanb
parents: 40192
diff changeset
   173
        } else {
a60f280f803c 8169069: Module system implementation refresh (11/2016)
alanb
parents: 40192
diff changeset
   174
            /* Use a format more in line with GNU conventions */
48327
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
   175
            ps.println(launcher_name + " " + java_version
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
   176
                       + " " + java_version_date
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
   177
                       + (isLTS ? " LTS" : ""));
42338
a60f280f803c 8169069: Module system implementation refresh (11/2016)
alanb
parents: 40192
diff changeset
   178
        }
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   179
90ce3da70b43 Initial load
duke
parents:
diff changeset
   180
        /* Second line: runtime version (ie, libraries). */
34011
b1ce08dd7f17 8139986: Store debug level in java.vm.debug and conditionally print in "java -version"
amurillo
parents: 34003
diff changeset
   181
        String jdk_debug_level = System.getProperty("jdk.debug", "release");
b1ce08dd7f17 8139986: Store debug level in java.vm.debug and conditionally print in "java -version"
amurillo
parents: 34003
diff changeset
   182
        if ("release".equals(jdk_debug_level)) {
48327
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
   183
           /* Do not show debug level "release" builds */
34011
b1ce08dd7f17 8139986: Store debug level in java.vm.debug and conditionally print in "java -version"
amurillo
parents: 34003
diff changeset
   184
            jdk_debug_level = "";
b1ce08dd7f17 8139986: Store debug level in java.vm.debug and conditionally print in "java -version"
amurillo
parents: 34003
diff changeset
   185
        } else {
b1ce08dd7f17 8139986: Store debug level in java.vm.debug and conditionally print in "java -version"
amurillo
parents: 34003
diff changeset
   186
            jdk_debug_level = jdk_debug_level + " ";
b1ce08dd7f17 8139986: Store debug level in java.vm.debug and conditionally print in "java -version"
amurillo
parents: 34003
diff changeset
   187
        }
b1ce08dd7f17 8139986: Store debug level in java.vm.debug and conditionally print in "java -version"
amurillo
parents: 34003
diff changeset
   188
48327
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
   189
        ps.println(java_runtime_name + vendor_version
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
   190
                   + " (" + jdk_debug_level + "build " + java_runtime_version + ")");
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   191
90ce3da70b43 Initial load
duke
parents:
diff changeset
   192
        /* Third line: JVM information. */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   193
        String java_vm_name    = System.getProperty("java.vm.name");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   194
        String java_vm_version = System.getProperty("java.vm.version");
90ce3da70b43 Initial load
duke
parents:
diff changeset
   195
        String java_vm_info    = System.getProperty("java.vm.info");
48327
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
   196
        ps.println(java_vm_name + vendor_version
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
   197
                   + " (" + jdk_debug_level + "build " + java_vm_version + ", "
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
   198
                            + java_vm_info + ")");
d2a837cf9ff1 8192833: JEP 322: Time-Based Release Versioning
mr
parents: 47216
diff changeset
   199
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
   200
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   201
39302
aa8d0bc2a6d2 8160000: Runtime.version() cause startup regressions in 9+119
redestad
parents: 36225
diff changeset
   202
}