From 43200d916daecc54a44b5e2b68d13f3e7dbc62b3 Mon Sep 17 00:00:00 2001 From: dcubed Date: Thu, 25 Mar 2010 16:27:12 -0700 Subject: [PATCH] 6938185: 3/4 6923488 breaks Windows command shell builds Summary: Fix build.bat so invoking command shell doesn't exit on error. Fix dirname assumptions. Document some MKS environment dependencies. Reviewed-by: coleenp --- make/windows/build.bat | 7 +++++-- make/windows/build.make | 3 +++ make/windows/create.bat | 3 +++ make/windows/get_msc_ver.sh | 10 ++++++++-- 4 files changed, 19 insertions(+), 4 deletions(-) diff --git a/make/windows/build.bat b/make/windows/build.bat index d8da75ec1..4368f17e8 100644 --- a/make/windows/build.bat +++ b/make/windows/build.bat @@ -28,6 +28,9 @@ REM REM Since we don't have uname and we could be cross-compiling, REM Use the compiler to determine which ARCH we are building REM +REM Note: Running this batch file from the Windows command shell requires +REM that "grep" be accessible on the PATH. An MKS install does this. +REM cl 2>&1 | grep "IA-64" >NUL if %errorlevel% == 0 goto isia64 cl 2>&1 | grep "AMD64" >NUL @@ -109,7 +112,7 @@ echo workspace is source directory without trailing slash, echo bootstrap_dir is a full path to a JDK in which bin/java echo and bin/javac are present and working, and build_id is an echo optional build identifier displayed by java -version -exit 1 +exit /b 1 :end -exit %errorlevel% +exit /b %errorlevel% diff --git a/make/windows/build.make b/make/windows/build.make index b8e286abf..dbb2a7a3e 100644 --- a/make/windows/build.make +++ b/make/windows/build.make @@ -27,6 +27,9 @@ # environment variables (Variant, WorkSpace, BootStrapDir, BuildUser, HOTSPOT_BUILD_VERSION) # are passed in as command line arguments. +# Note: Running nmake or build.bat from the Windows command shell requires +# that "sh" be accessible on the PATH. An MKS install does this. + # SA components are built if BUILD_WIN_SA=1 is specified. # See notes in README. This produces files: # 1. sa-jdi.jar - This is built before building jvm.dll diff --git a/make/windows/create.bat b/make/windows/create.bat index 0f208806b..4d66df858 100644 --- a/make/windows/create.bat +++ b/make/windows/create.bat @@ -36,6 +36,9 @@ REM REM Since we don't have uname and we could be cross-compiling, REM Use the compiler to determine which ARCH we are building REM +REM Note: Running this batch file from the Windows command shell requires +REM that "grep" be accessible on the PATH. An MKS install does this. +REM cl 2>&1 | grep "IA-64" >NUL if %errorlevel% == 0 goto isia64 cl 2>&1 | grep "AMD64" >NUL diff --git a/make/windows/get_msc_ver.sh b/make/windows/get_msc_ver.sh index ac5db63b9..ee1357677 100644 --- a/make/windows/get_msc_ver.sh +++ b/make/windows/get_msc_ver.sh @@ -48,6 +48,7 @@ else TOOL_DIR=`dirname "$SH"` fi +DIRNAME="$TOOL_DIR/dirname" HEAD="$TOOL_DIR/head" ECHO="$TOOL_DIR/echo" EXPR="$TOOL_DIR/expr" @@ -76,8 +77,13 @@ if [ "x$FORCE_LINK_VER" != "x" ]; then else # use the "link" command that is co-located with the "cl" command cl_cmd=`which cl` - cl_dir=`dirname $cl_cmd` - LINK_VER_RAW=`$cl_dir/link 2>&1 | "$HEAD" -n 1 | "$SED" 's/.*Version[\ ]*\([0-9][0-9.]*\).*/\1/'` + if [ "x$cl_cmd" != "x" ]; then + link_cmd=`$DIRNAME "$cl_cmd"`/link + else + # which can't find "cl" so just use which ever "link" we find + link_cmd="link" + fi + LINK_VER_RAW=`"$link_cmd" 2>&1 | "$HEAD" -n 1 | "$SED" 's/.*Version[\ ]*\([0-9][0-9.]*\).*/\1/'` LINK_VER_MAJOR=`"$ECHO" $LINK_VER_RAW | "$CUT" -d'.' -f1` LINK_VER_MINOR=`"$ECHO" $LINK_VER_RAW | "$CUT" -d'.' -f2` LINK_VER_MICRO=`"$ECHO" $LINK_VER_RAW | "$CUT" -d'.' -f3` -- GitLab