#!/bin/bash # # Copyright (c) 2012, 2018, 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. # if test "x$1" != xCHECKME; then echo "ERROR: Calling this wrapper script directly is not supported." echo "Use the 'configure' script in the top-level directory instead." exit 1 fi # The next argument is the absolute top-level directory path. # The TOPDIR variable is passed on to configure.ac. TOPDIR="$2" # Remove these two arguments to get to the user supplied arguments shift shift if test "x$BASH" = x; then echo "Error: This script must be run using bash." 1>&2 exit 1 fi # Force autoconf to use bash. This also means we must disable autoconf re-exec. export CONFIG_SHELL=$BASH export _as_can_reexec=no if test "x$CUSTOM_CONFIG_DIR" != x; then custom_hook=$CUSTOM_CONFIG_DIR/custom-hook.m4 if test ! -e $custom_hook; then echo "CUSTOM_CONFIG_DIR not pointing to a proper custom config dir." echo "Error: Cannot continue" 1>&2 exit 1 fi fi CURRENT_DIR=`pwd` if test "x$CURRENT_DIR" = "x$TOPDIR"; then # We are running configure from the src root. # Create '.configure-support' under $TOPDIR/build build_support_dir="$TOPDIR/build/.configure-support" elif test "x$CURRENT_DIR" = "x$CUSTOM_ROOT"; then # We are running configure from the custom root. # Create '.configure-support' under $CUSTOM_ROOT/build build_support_dir="$CUSTOM_ROOT/build/.configure-support" else # We are running configure from outside of the src dir. # Create 'build_support_dir' in the current directory. build_support_dir="$CURRENT_DIR/configure-support" fi conf_script_dir="$TOPDIR/make/autoconf" generated_script="$build_support_dir/generated-configure.sh" ### ### Use autoconf to create a runnable configure script, if needed ### autoconf_missing_help() { APT_GET="`which apt-get 2> /dev/null | grep -v '^no apt-get in'`" YUM="`which yum 2> /dev/null | grep -v '^no yum in'`" BREW="`which brew 2> /dev/null | grep -v '^no brew in'`" CYGWIN="`which cygpath 2> /dev/null | grep -v '^no cygpath in'`" if test "x$APT_GET" != x; then PKGHANDLER_COMMAND="sudo apt-get install autoconf" elif test "x$YUM" != x; then PKGHANDLER_COMMAND="sudo yum install autoconf" elif test "x$BREW" != x; then PKGHANDLER_COMMAND="brew install autoconf" elif test "x$CYGWIN" != x; then PKGHANDLER_COMMAND="( cd <location of cygwin setup.exe> && cmd /c setup -q -P autoconf )" fi if test "x$PKGHANDLER_COMMAND" != x; then echo "You might be able to fix this by running '$PKGHANDLER_COMMAND'." fi } generate_configure_script() { if test "x$AUTOCONF" != x; then if test ! -x "$AUTOCONF"; then echo echo "The specified AUTOCONF variable does not point to a valid autoconf executable:" echo "AUTOCONF=$AUTOCONF" echo "Error: Cannot continue" 1>&2 exit 1 fi else AUTOCONF="`which autoconf 2> /dev/null | grep -v '^no autoconf in'`" if test "x$AUTOCONF" = x; then echo echo "Autoconf is not found on the PATH, and AUTOCONF is not set." echo "You need autoconf to be able to generate a runnable configure script." autoconf_missing_help echo "Error: Cannot find autoconf" 1>&2 exit 1 fi fi autoconf_version=`$AUTOCONF --version | head -1` echo "Using autoconf at ${AUTOCONF} [$autoconf_version]" if test "x$CUSTOM_CONFIG_DIR" != x; then # Generate configure script with custom hooks compiled in. custom_patcher='sed -e "s|#CUSTOM_AUTOCONF_INCLUDE|m4_include([$custom_hook])|"' else custom_patcher='cat' fi mkdir -p $build_support_dir # Call autoconf but replace the "magic" variable in configure.ac if requested. cat $conf_script_dir/configure.ac | eval $custom_patcher | \ ${AUTOCONF} -W all -I$conf_script_dir - > $generated_script rm -rf autom4te.cache # Sanity check if test ! -s $generated_script; then echo "Error: Failed to generate runnable configure script" 1>&2 rm -f $generated_script exit 1 fi } test_generated_up_to_date() { conf_source_files="$conf_script_dir/configure.ac $conf_script_dir/*.m4" if test "x$CUSTOM_CONFIG_DIR" != x; then conf_custom_source_files="$CUSTOM_CONFIG_DIR/*.m4" else conf_custom_source_files="" fi for file in $conf_source_files $conf_custom_source_files ; do if test $file -nt $generated_script; then return 0 fi done return 1 } run_autoconf=false if test "x$1" = xautogen; then # User called us as "configure autogen", so force regeneration run_autoconf=true shift fi if test ! -s $generated_script; then # Generated script is missing, so we need to create it echo "Runnable configure script is not present" run_autoconf=true else # File is present, but is it up to date? if test_generated_up_to_date; then echo "Runnable configure script is not up to date" run_autoconf=true fi fi if test "x$run_autoconf" = xtrue; then echo "Generating runnable configure script at $generated_script" generate_configure_script fi # Autoconf calls the configure script recursively sometimes. # Don't start logging twice in that case if test "x$conf_debug_configure" = xtrue; then conf_debug_configure=recursive fi ### ### Process command-line arguments ### # Returns a shell-escaped version of the argument given. function shell_quote() { if [[ -n "$1" ]]; then # Uses only shell-safe characters? No quoting needed. # '=' is a zsh meta-character, but only in word-initial position. if echo "$1" | grep '^[ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789\.:,%/+=_-]\{1,\}$' > /dev/null \ && ! echo "$1" | grep '^=' > /dev/null; then quoted="$1" else if echo "$1" | grep "[\'!]" > /dev/null; then # csh does history expansion within single quotes, but not # when backslash-escaped! local quoted_quote="'\\''" quoted_exclam="'\\!'" word="${1//\'/${quoted_quote}}" word="${1//\!/${quoted_exclam}}" fi quoted="'$1'" fi echo "$quoted" fi } conf_processed_arguments=() conf_quoted_arguments=() conf_openjdk_target= for conf_option do # Process (and remove) our own extensions that will not be passed to autoconf case $conf_option in --openjdk-target=*) conf_openjdk_target=`expr "X$conf_option" : '[^=]*=\(.*\)'` ;; --debug-configure) if test "x$conf_debug_configure" != xrecursive; then conf_debug_configure=true export conf_debug_configure fi ;; *) conf_processed_arguments=("${conf_processed_arguments[@]}" "$conf_option") ;; esac # Store all variables overridden on the command line case $conf_option in [^-]*=*) # Add name of variable to CONFIGURE_OVERRIDDEN_VARIABLES list inside !...!. conf_env_var=`expr "x$conf_option" : 'x\([^=]*\)='` CONFIGURE_OVERRIDDEN_VARIABLES="$CONFIGURE_OVERRIDDEN_VARIABLES!$conf_env_var!" ;; esac # Save the arguments, intelligently quoted for CONFIGURE_COMMAND_LINE. case $conf_option in *=*) conf_option_name=`expr "x$conf_option" : 'x\([^=]*\)='` conf_option_name=$(shell_quote "$conf_option_name") conf_option_value=`expr "x$conf_option" : 'x[^=]*=\(.*\)'` conf_option_value=$(shell_quote "$conf_option_value") conf_quoted_arguments=("${conf_quoted_arguments[@]}" "$conf_option_name=$conf_option_value") ;; *) conf_quoted_arguments=("${conf_quoted_arguments[@]}" "$(shell_quote "$conf_option")") ;; esac # Check for certain autoconf options that require extra action case $conf_option in -build | --build | --buil | --bui | --bu |-build=* | --build=* | --buil=* | --bui=* | --bu=*) conf_legacy_crosscompile="$conf_legacy_crosscompile $conf_option" ;; -target | --target | --targe | --targ | --tar | --ta | --t | -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) conf_legacy_crosscompile="$conf_legacy_crosscompile $conf_option" ;; -host | --host | --hos | --ho | -host=* | --host=* | --hos=* | --ho=*) conf_legacy_crosscompile="$conf_legacy_crosscompile $conf_option" ;; -help | --help | --hel | --he | -h) conf_print_help=true ;; esac done # Save the quoted command line CONFIGURE_COMMAND_LINE="${conf_quoted_arguments[@]}" if test "x$conf_legacy_crosscompile" != "x"; then if test "x$conf_openjdk_target" != "x"; then echo "Error: Specifying --openjdk-target together with autoconf" echo "legacy cross-compilation flags is not supported." echo "You specified: --openjdk-target=$conf_openjdk_target and $conf_legacy_crosscompile." echo "The recommended use is just --openjdk-target." exit 1 else echo "Warning: You are using legacy autoconf cross-compilation flags." echo "It is recommended that you use --openjdk-target instead." echo "" fi fi if test "x$conf_openjdk_target" != "x"; then conf_build_platform=`sh $conf_script_dir/build-aux/config.guess` conf_processed_arguments=("--build=$conf_build_platform" "--host=$conf_openjdk_target" "--target=$conf_openjdk_target" "${conf_processed_arguments[@]}") fi # Make configure exit with error on invalid options as default. # Can be overridden by --disable-option-checking, since we prepend our argument # and later options override earlier. conf_processed_arguments=("--enable-option-checking=fatal" "${conf_processed_arguments[@]}") ### ### Call the configure script ### if test "x$conf_debug_configure" != x; then # Turn on shell debug output if requested (initial or recursive) set -x fi # Now transfer control to the script generated by autoconf. This is where the # main work is done. RCDIR=`mktemp -dt jdk-build-configure.tmp.XXXXXX` || exit $? trap "rm -rf \"$RCDIR\"" EXIT conf_logfile=./configure.log (exec 3>&1 ; ((. $generated_script "${conf_processed_arguments[@]}" 2>&1 1>&3 ) \ ; echo $? > "$RCDIR/rc" ) \ | tee -a $conf_logfile 1>&2 ; exec 3>&-) | tee -a $conf_logfile conf_result_code=`cat "$RCDIR/rc"` ### ### Post-processing ### if test $conf_result_code -eq 0; then if test "x$conf_print_help" = xtrue; then cat <<EOT Additional (non-autoconf) OpenJDK Options: --openjdk-target=TARGET cross-compile with TARGET as target platform (i.e. the one you will run the resulting binary on). Equivalent to --host=TARGET --target=TARGET --build=<current platform> --debug-configure Run the configure script with additional debug logging enabled. EOT # Print additional help, e.g. a list of toolchains and JVM features. # This must be done by the autoconf script. ( CONFIGURE_PRINT_ADDITIONAL_HELP=true . $generated_script PRINTF=printf ) cat <<EOT Please be aware that, when cross-compiling, the OpenJDK configure script will generally use 'target' where autoconf traditionally uses 'host'. Also note that variables must be passed on the command line. Variables in the environment will generally be ignored, unlike traditional autoconf scripts. EOT fi else echo configure exiting with result code $conf_result_code fi exit $conf_result_code