make/scripts/generate-symbol-data.sh
changeset 53695 55d2d437c708
equal deleted inserted replaced
53694:a0a327cae58f 53695:55d2d437c708
       
     1 #!/bin/sh
       
     2 #
       
     3 # Copyright (c) 2019, Oracle and/or its affiliates. All rights reserved.
       
     4 # DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
       
     5 #
       
     6 # This code is free software; you can redistribute it and/or modify it
       
     7 # under the terms of the GNU General Public License version 2 only, as
       
     8 # published by the Free Software Foundation.  Oracle designates this
       
     9 # particular file as subject to the "Classpath" exception as provided
       
    10 # by Oracle in the LICENSE file that accompanied this code.
       
    11 #
       
    12 # This code is distributed in the hope that it will be useful, but WITHOUT
       
    13 # ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
       
    14 # FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
       
    15 # version 2 for more details (a copy is included in the LICENSE file that
       
    16 # accompanied this code).
       
    17 #
       
    18 # You should have received a copy of the GNU General Public License version
       
    19 # 2 along with this work; if not, write to the Free Software Foundation,
       
    20 # Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
       
    21 #
       
    22 # Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
       
    23 # or visit www.oracle.com if you need additional information or have any
       
    24 # questions.
       
    25 #
       
    26 
       
    27 # This script allows to easily generate (add or update) "--release N" data for JDK N + 1.
       
    28 # N must be 11 or greater. This script works on Linux. To create new data, or update existing
       
    29 # data, it is necessary to:
       
    30 # - download a binary build of OpenJDK N for Linux, API of which will be recorded. It is strongly recommended
       
    31 #   to use an official build, not a custom build, to avoid any chance of including unofficial changes.
       
    32 #   The binary build should never be a build newer than the GA for JDK N. Install the build. The installation
       
    33 #   directory will be denoted as "${JDK_N_INSTALL}" in the further text.
       
    34 # - have a checkout the JDK to which the data should be added (or in which the data should be updated).
       
    35 #   The checkout directory will be denoted as "${JDK_CHECKOUT}" in the further text.
       
    36 #   The checkout must not have any local changes that could interfere with the new data. In particular,
       
    37 #   there must be absolutely no changed, new or removed files under the ${JDK_CHECKOUT}/make/data/symbols
       
    38 #   directory.
       
    39 # - open a terminal program and run these commands:
       
    40 #     cd "${JDK_CHECKOUT}"/make/data/symbols
       
    41 #     bash ../../scripts/generate-symbol-data.sh "${JDK_N_INSTALL}"
       
    42 # - this command will generate or update data for "--release N" into the ${JDK_CHECKOUT}/make/data/symbols
       
    43 #   directory, updating all registration necessary. If the goal was to update the data, and there are no
       
    44 #   new or changed files in the ${JDK_CHECKOUT}/make/data/symbols directory after running this script,
       
    45 #   there were no relevant changes and no further action is necessary. Note that version for N > 9 are encoded
       
    46 #   using capital letters, i.e. A represents version 10, B represents 11, and so on. The version numbers are in
       
    47 #   the names of the files in the ${JDK_CHECKOUT}/make/data/symbols directory, as well as in
       
    48 #   the ${JDK_CHECKOUT}/make/data/symbols/symbols file.
       
    49 # - if there are any changed/new files in the ${JDK_CHECKOUT}/make/data/symbols directory after running this script,
       
    50 #   then all the changes in this directory, including any new files, need to be sent for review and eventually pushed.
       
    51 #   The commit message should specify which binary build was installed in the ${JDK_N_INSTALL} directory and also
       
    52 #   include the SCM state that was used to build it, which can be found in ${JDK_N_INSTALL}/release,
       
    53 #   in property "SOURCE".
       
    54 
       
    55 if [ "$1x" = "x" ] ; then
       
    56     echo "Must provide the target JDK as a parameter:" >&2
       
    57     echo "$0 <target-jdk>" >&2
       
    58     exit 1
       
    59 fi;
       
    60 
       
    61 if [ ! -f symbols ] ; then
       
    62     echo "Must run inside the make/data/symbols directory" >&2
       
    63     exit 1
       
    64 fi;
       
    65 
       
    66 if [ "`hg status .`x" != "x" ] ; then
       
    67     echo "The make/data/symbols directory contains local changes!" >&2
       
    68     exit 1
       
    69 fi;
       
    70 
       
    71 $1/bin/java --add-exports jdk.jdeps/com.sun.tools.classfile=ALL-UNNAMED \
       
    72             --add-exports jdk.compiler/com.sun.tools.javac.api=ALL-UNNAMED \
       
    73             --add-exports jdk.compiler/com.sun.tools.javac.jvm=ALL-UNNAMED \
       
    74             --add-exports jdk.compiler/com.sun.tools.javac.util=ALL-UNNAMED \
       
    75             --add-modules jdk.jdeps \
       
    76             ../../../make/langtools/src/classes/build/tools/symbolgenerator/CreateSymbols.java \
       
    77             build-description-incremental symbols include.list