diff --git a/bin/idea.sh b/bin/idea.sh index a7bba24a4ca..49c6ee45e3b 100644 --- a/bin/idea.sh +++ b/bin/idea.sh @@ -25,21 +25,7 @@ # Shell script for generating an IDEA project from a given list of modules usage() { - echo "Usage: $0 [-h|--help] [-q|--quiet] [-a|--absolute-paths] [-o|--output ] [modules...]" - echo " -h | --help" - echo " -q | --quiet - No stdout output" - echo " -a | --absolute-paths - Use absolute paths to this jdk, so that generated .idea - project files can be moved independently of jdk sources" - echo " -o | --output - Where .idea directory with project files will be generated - (e.g. using '-o .' will place project files in './.idea') - Default: $TOPLEVEL_DIR" - echo " [modules...] - Generate project modules for specific java modules - (e.g. 'java.base java.desktop') - Default: all existing modules (java.* and jdk.*)" + echo "usage: $0 [-h|--help] [-v|--verbose] [-o|--output ] [modules]+" exit 1 } @@ -47,12 +33,10 @@ SCRIPT_DIR=`dirname $0` #assume TOP is the dir from which the script has been called TOP=`pwd` cd $SCRIPT_DIR; SCRIPT_DIR=`pwd` -cd .. ; TOPLEVEL_DIR=`pwd` cd $TOP; -IDEA_OUTPUT=$TOPLEVEL_DIR/.idea -VERBOSE=true -ABSOLUTE_PATHS=false +IDEA_OUTPUT=$TOP/.idea +VERBOSE="false" while [ $# -gt 0 ] do case $1 in @@ -60,12 +44,8 @@ do usage ;; - -q | --quiet ) - VERBOSE=false - ;; - - -a | --absolute-paths ) - ABSOLUTE_PATHS=true + -v | --vebose ) + VERBOSE="true" ;; -o | --output ) @@ -86,13 +66,18 @@ done mkdir -p $IDEA_OUTPUT || exit 1 cd $IDEA_OUTPUT; IDEA_OUTPUT=`pwd` -cd ..; IDEA_OUTPUT_PARENT=`pwd` -MAKE_DIR="$TOPLEVEL_DIR/make" +if [ "x$TOPLEVEL_DIR" = "x" ] ; then + cd $SCRIPT_DIR/.. + TOPLEVEL_DIR=`pwd` + cd $IDEA_OUTPUT +fi + +MAKE_DIR="$SCRIPT_DIR/../make" IDEA_MAKE="$MAKE_DIR/ide/idea/jdk" IDEA_TEMPLATE="$IDEA_MAKE/template" -cp -rn "$IDEA_TEMPLATE"/* "$IDEA_OUTPUT" +cp -r "$IDEA_TEMPLATE"/* "$IDEA_OUTPUT" #override template if [ -d "$TEMPLATES_OVERRIDE" ] ; then @@ -101,31 +86,31 @@ if [ -d "$TEMPLATES_OVERRIDE" ] ; then done fi -if [ "$VERBOSE" = true ] ; then - echo "Will generate IDEA project files in \"$IDEA_OUTPUT\" for project \"$TOPLEVEL_DIR\"" +if [ "$VERBOSE" = "true" ] ; then + echo "output dir: $IDEA_OUTPUT" + echo "idea template dir: $IDEA_TEMPLATE" fi -cd $TOP ; make -f "$IDEA_MAKE/idea.gmk" -I "$TOPLEVEL_DIR" idea \ - MAKEOVERRIDES= IDEA_OUTPUT_PARENT="$IDEA_OUTPUT_PARENT" OUT="$IDEA_OUTPUT/env.cfg" MODULES="$*" || exit 1 +cd $TOP ; make -f "$IDEA_MAKE/idea.gmk" -I $MAKE_DIR/.. idea MAKEOVERRIDES= OUT=$IDEA_OUTPUT/env.cfg MODULES="$*" || exit 1 cd $SCRIPT_DIR . $IDEA_OUTPUT/env.cfg -# Expect MODULES, MODULE_NAMES, RELATIVE_PROJECT_DIR, RELATIVE_BUILD_DIR to be set -if [ "xMODULES" = "x" ] ; then - echo "FATAL: MODULES is empty" >&2; exit 1 +# Expect MODULE_ROOTS, MODULE_NAMES, BOOT_JDK & SPEC to be set +if [ "x$MODULE_ROOTS" = "x" ] ; then + echo "FATAL: MODULE_ROOTS is empty" >&2; exit 1 fi if [ "x$MODULE_NAMES" = "x" ] ; then echo "FATAL: MODULE_NAMES is empty" >&2; exit 1 fi -if [ "x$RELATIVE_PROJECT_DIR" = "x" ] ; then - echo "FATAL: RELATIVE_PROJECT_DIR is empty" >&2; exit 1 +if [ "x$BOOT_JDK" = "x" ] ; then + echo "FATAL: BOOT_JDK is empty" >&2; exit 1 fi -if [ "x$RELATIVE_BUILD_DIR" = "x" ] ; then - echo "FATAL: RELATIVE_BUILD_DIR is empty" >&2; exit 1 +if [ "x$SPEC" = "x" ] ; then + echo "FATAL: SPEC is empty" >&2; exit 1 fi if [ -d "$TOPLEVEL_DIR/.hg" ] ; then @@ -136,29 +121,6 @@ if [ -d "$TOPLEVEL_DIR/.git" ] ; then VCS_TYPE="Git" fi -if [ "$ABSOLUTE_PATHS" = true ] ; then - if [ "x$PATHTOOL" != "x" ]; then - PROJECT_DIR="`$PATHTOOL -am $TOPLEVEL_DIR`" - else - PROJECT_DIR="$TOPLEVEL_DIR" - fi - MODULE_DIR="$PROJECT_DIR" - cd "$TOPLEVEL_DIR" && cd "$RELATIVE_BUILD_DIR" && BUILD_DIR="`pwd`" -else - if [ "$RELATIVE_PROJECT_DIR" = "." ] ; then - PROJECT_DIR="" - else - PROJECT_DIR="/$RELATIVE_PROJECT_DIR" - fi - MODULE_DIR="\$MODULE_DIR\$$PROJECT_DIR" - PROJECT_DIR="\$PROJECT_DIR\$$PROJECT_DIR" - BUILD_DIR="\$PROJECT_DIR\$/$RELATIVE_BUILD_DIR" -fi -if [ "$VERBOSE" = true ] ; then - echo "Project root: $PROJECT_DIR" - echo "Generating IDEA project files..." -fi - ### Replace template variables NUM_REPLACEMENTS=0 @@ -182,82 +144,105 @@ add_replacement() { eval TO$NUM_REPLACEMENTS='$2' } -add_replacement "###PROJECT_DIR###" "$PROJECT_DIR" -add_replacement "###MODULE_DIR###" "$MODULE_DIR" add_replacement "###MODULE_NAMES###" "$MODULE_NAMES" add_replacement "###VCS_TYPE###" "$VCS_TYPE" -add_replacement "###BUILD_DIR###" "$BUILD_DIR" -if [ "x$PATHTOOL" != "x" ]; then - add_replacement "###BASH_RUNNER_PREFIX###" "\$PROJECT_DIR\$/.idea/bash.bat" -else - add_replacement "###BASH_RUNNER_PREFIX###" "" -fi -if [ "x$PATHTOOL" != "x" ]; then +SPEC_DIR=`dirname $SPEC` +if [ "x$CYGPATH" != "x" ]; then + add_replacement "###BUILD_DIR###" "`cygpath -am $SPEC_DIR`" + add_replacement "###IMAGES_DIR###" "`cygpath -am $SPEC_DIR`/images/jdk" + add_replacement "###ROOT_DIR###" "`cygpath -am $TOPLEVEL_DIR`" + add_replacement "###IDEA_DIR###" "`cygpath -am $IDEA_OUTPUT`" if [ "x$JT_HOME" = "x" ]; then add_replacement "###JTREG_HOME###" "" else - add_replacement "###JTREG_HOME###" "`$PATHTOOL -am $JT_HOME`" + add_replacement "###JTREG_HOME###" "`cygpath -am $JT_HOME`" + fi +elif [ "x$WSL_DISTRO_NAME" != "x" ]; then + add_replacement "###BUILD_DIR###" "`wslpath -am $SPEC_DIR`" + add_replacement "###IMAGES_DIR###" "`wslpath -am $SPEC_DIR`/images/jdk" + add_replacement "###ROOT_DIR###" "`wslpath -am $TOPLEVEL_DIR`" + add_replacement "###IDEA_DIR###" "`wslpath -am $IDEA_OUTPUT`" + if [ "x$JT_HOME" = "x" ]; then + add_replacement "###JTREG_HOME###" "" + else + add_replacement "###JTREG_HOME###" "`wslpath -am $JT_HOME`" fi else + add_replacement "###BUILD_DIR###" "$SPEC_DIR" add_replacement "###JTREG_HOME###" "$JT_HOME" + add_replacement "###IMAGES_DIR###" "$SPEC_DIR/images/jdk" + add_replacement "###ROOT_DIR###" "$TOPLEVEL_DIR" + add_replacement "###IDEA_DIR###" "$IDEA_OUTPUT" fi -MODULE_IMLS="" -TEST_MODULE_DEPENDENCIES="" -for module in $MODULE_NAMES; do - MODULE_IMLS="$MODULE_IMLS " - TEST_MODULE_DEPENDENCIES="$TEST_MODULE_DEPENDENCIES " +SOURCE_PREFIX="" + +for root in $MODULE_ROOTS; do + if [ "x$CYGPATH" != "x" ]; then + root=`cygpath -am $root` + elif [ "x$WSL_DISTRO_NAME" != "x" ]; then + root=`wslpath -am $root` + fi + + VM_CI="jdk.internal.vm.ci/share/classes" + VM_COMPILER="src/jdk.internal.vm.compiler/share/classes" + if test "${root#*$VM_CI}" != "$root" || test "${root#*$VM_COMPILER}" != "$root"; then + for subdir in "$root"/*; do + if [ -d "$subdir" ]; then + SOURCES=$SOURCES" $SOURCE_PREFIX""$subdir"/src"$SOURCE_POSTFIX" + fi + done + else + SOURCES=$SOURCES" $SOURCE_PREFIX""$root""$SOURCE_POSTFIX" + fi done -add_replacement "###MODULE_IMLS###" "$MODULE_IMLS" -add_replacement "###TEST_MODULE_DEPENDENCIES###" "$TEST_MODULE_DEPENDENCIES" + +add_replacement "###SOURCE_ROOTS###" "$SOURCES" replace_template_dir "$IDEA_OUTPUT" -### Generate module project files +### Compile the custom Logger -if [ "$VERBOSE" = true ] ; then - echo "Generating project modules:" - fi -( -DEFAULT_IFS="$IFS" -IFS='#' -for value in $MODULES; do - ( - eval "$value" - if [ "$VERBOSE" = true ] ; then - echo " $module" - fi - add_replacement "###MODULE_CONTENT###" "src/$module" - SOURCE_DIRS="" - IFS=' ' - for dir in $moduleSrcDirs; do - case $dir in # Exclude generated sources to avoid module-info conflicts, see https://youtrack.jetbrains.com/issue/IDEA-185108 - "src/"*) SOURCE_DIRS="$SOURCE_DIRS " - esac - done - add_replacement "###SOURCE_DIRS###" "$SOURCE_DIRS" - DEPENDENCIES="" - for dep in $moduleDependencies; do - case $MODULE_NAMES in # Exclude skipped modules from dependencies - *"$dep"*) DEPENDENCIES="$DEPENDENCIES " - esac - done - add_replacement "###DEPENDENCIES###" "$DEPENDENCIES" - cp "$IDEA_OUTPUT/module.iml" "$IDEA_OUTPUT/$module.iml" - IFS="$DEFAULT_IFS" - replace_template_file "$IDEA_OUTPUT/$module.iml" - ) -done -) -rm "$IDEA_OUTPUT/module.iml" +CLASSES=$IDEA_OUTPUT/classes -### Create shell script runner for Windows - -if [ "x$PATHTOOL" != "x" ]; then - echo "@echo off" > "$IDEA_OUTPUT/bash.bat" - if [ "x$WSL_DISTRO_NAME" != "x" ] ; then - echo "wsl -d $WSL_DISTRO_NAME --cd \"%cd%\" -e %*" >> "$IDEA_OUTPUT/bash.bat" - else - echo "$WINENV_ROOT\bin\bash.exe -l -c \"cd %CD:\=/%/ && %*\"" >> "$IDEA_OUTPUT/bash.bat" - fi +if [ "x$ANT_HOME" = "x" ] ; then + # try some common locations, before giving up + if [ -f "/usr/share/ant/lib/ant.jar" ] ; then + ANT_HOME="/usr/share/ant" + elif [ -f "/usr/local/Cellar/ant/1.9.4/libexec/lib/ant.jar" ] ; then + ANT_HOME="/usr/local/Cellar/ant/1.9.4/libexec" + else + echo "FATAL: cannot find ant. Try setting ANT_HOME." >&2; exit 1 + fi fi +CP=$ANT_HOME/lib/ant.jar +rm -rf $CLASSES; mkdir $CLASSES + +if [ "x$CYGPATH" != "x" ] ; then ## CYGPATH may be set in env.cfg + JAVAC_SOURCE_FILE=`cygpath -am $IDEA_OUTPUT/src/idea/IdeaLoggerWrapper.java` + JAVAC_SOURCE_PATH=`cygpath -am $IDEA_OUTPUT/src` + JAVAC_CLASSES=`cygpath -am $CLASSES` + JAVAC_CP=`cygpath -am $CP` + JAVAC=javac +elif [ "x$WSL_DISTRO_NAME" != "x" ]; then + JAVAC_SOURCE_FILE=`realpath --relative-to=./ $IDEA_OUTPUT/src/idea/IdeaLoggerWrapper.java` + JAVAC_SOURCE_PATH=`realpath --relative-to=./ $IDEA_OUTPUT/src` + JAVAC_CLASSES=`realpath --relative-to=./ $CLASSES` + ANT_TEMP=`mktemp -d -p ./` + cp $ANT_HOME/lib/ant.jar $ANT_TEMP/ant.jar + JAVAC_CP=$ANT_TEMP/ant.jar + JAVAC=javac.exe +else + JAVAC_SOURCE_FILE=$IDEA_OUTPUT/src/idea/IdeaLoggerWrapper.java + JAVAC_SOURCE_PATH=$IDEA_OUTPUT/src + JAVAC_CLASSES=$CLASSES + JAVAC_CP=$CP + JAVAC=javac +fi + +$BOOT_JDK/bin/$JAVAC -d $JAVAC_CLASSES -sourcepath $JAVAC_SOURCE_PATH -cp $JAVAC_CP $JAVAC_SOURCE_FILE + +if [ "x$WSL_DISTRO_NAME" != "x" ]; then + rm -rf $ANT_TEMP +fi \ No newline at end of file diff --git a/make/autoconf/jvm-features.m4 b/make/autoconf/jvm-features.m4 index fd9ac811b53..a4d0bf62ec2 100644 --- a/make/autoconf/jvm-features.m4 +++ b/make/autoconf/jvm-features.m4 @@ -542,6 +542,9 @@ AC_DEFUN([JVM_FEATURES_VERIFY], if ! JVM_FEATURES_IS_ACTIVE(jvmci); then INCLUDE_JVMCI="false" fi + if JVM_FEATURES_IS_ACTIVE(compiler2); then + INCLUDE_COMPILER2="true" + fi # Verify that we have at least one gc selected (i.e., feature named "*gc"). if ! JVM_FEATURES_IS_ACTIVE(.*gc); then @@ -565,6 +568,7 @@ AC_DEFUN_ONCE([JVM_FEATURES_SETUP], # missing any of them. ENABLE_CDS="true" INCLUDE_JVMCI="true" + INCLUDE_COMPILER2="false" for variant in $JVM_VARIANTS; do # Figure out if any features are unavailable, or should be filtered out @@ -601,5 +605,6 @@ AC_DEFUN_ONCE([JVM_FEATURES_SETUP], AC_SUBST(JVM_FEATURES_custom) AC_SUBST(INCLUDE_JVMCI) + AC_SUBST(INCLUDE_COMPILER2) ]) diff --git a/make/autoconf/spec.gmk.in b/make/autoconf/spec.gmk.in index d1e6cd3b2ff..29445c8c24f 100644 --- a/make/autoconf/spec.gmk.in +++ b/make/autoconf/spec.gmk.in @@ -853,6 +853,7 @@ PNG_CFLAGS:=@PNG_CFLAGS@ INCLUDE_SA=@INCLUDE_SA@ INCLUDE_JVMCI=@INCLUDE_JVMCI@ +INCLUDE_COMPILER2=@INCLUDE_COMPILER2@ OS_VERSION_MAJOR:=@OS_VERSION_MAJOR@ OS_VERSION_MINOR:=@OS_VERSION_MINOR@ diff --git a/make/ide/idea/jdk/build.xml b/make/ide/idea/jdk/build.xml new file mode 100644 index 00000000000..0292f0f5d35 --- /dev/null +++ b/make/ide/idea/jdk/build.xml @@ -0,0 +1,42 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/make/ide/idea/jdk/idea.gmk b/make/ide/idea/jdk/idea.gmk index a729c96bd25..310b582591c 100644 --- a/make/ide/idea/jdk/idea.gmk +++ b/make/ide/idea/jdk/idea.gmk @@ -46,16 +46,13 @@ else #with SPEC endif idea: - $(ECHO) "MODULES=\"$(foreach mod, $(SEL_MODULES), \ - module='$(mod)' \ - moduleSrcDirs='$(foreach m,$(call FindModuleSrcDirs,$(mod)),$(call RelativePath,$m,$(topdir)))' \ - moduleDependencies='$(call FindTransitiveDepsForModule,$(mod))' \ - #)\"" > $(OUT) + $(ECHO) "SUPPORT=$(SUPPORT_OUTPUTDIR)" >> $(OUT) + $(ECHO) "MODULE_ROOTS=\"$(foreach mod, $(SEL_MODULES), $(call FindModuleSrcDirs,$(mod)))\"" >> $(OUT) $(ECHO) "MODULE_NAMES=\"$(strip $(foreach mod, $(SEL_MODULES), $(mod)))\"" >> $(OUT) - $(ECHO) "RELATIVE_PROJECT_DIR=\"$(call RelativePath,$(topdir),$(IDEA_OUTPUT_PARENT))\"" >> $(OUT) - $(ECHO) "RELATIVE_BUILD_DIR=\"$(call RelativePath,$(OUTPUTDIR),$(IDEA_OUTPUT_PARENT))\"" >> $(OUT) - $(ECHO) "PATHTOOL=\"$(PATHTOOL)\"" >> $(OUT) + $(ECHO) "SEL_MODULES=\"$(SEL_MODULES)\"" >> $(OUT) + $(ECHO) "BOOT_JDK=\"$(BOOT_JDK)\"" >> $(OUT) + $(ECHO) "CYGPATH=\"$(PATHTOOL)\"" >> $(OUT) + $(ECHO) "SPEC=\"$(SPEC)\"" >> $(OUT) $(ECHO) "JT_HOME=\"$(JT_HOME)\"" >> $(OUT) - $(ECHO) "WINENV_ROOT=\"$(WINENV_ROOT)\"" >> $(OUT) endif diff --git a/make/ide/idea/jdk/template/ant.xml b/make/ide/idea/jdk/template/ant.xml new file mode 100644 index 00000000000..9cb90246ea0 --- /dev/null +++ b/make/ide/idea/jdk/template/ant.xml @@ -0,0 +1,14 @@ + + + + + + + + + + + + + + diff --git a/make/ide/idea/jdk/template/compiler.xml b/make/ide/idea/jdk/template/compiler.xml index 9281fa10db7..eef129e7b87 100644 --- a/make/ide/idea/jdk/template/compiler.xml +++ b/make/ide/idea/jdk/template/compiler.xml @@ -3,10 +3,10 @@