Skip to content
This repository was archived by the owner on Sep 19, 2023. It is now read-only.

Commit 9ae9af9

Browse files
committed
8289735: UTIL_LOOKUP_PROGS fails on pathes with space
8306976: UTIL_REQUIRE_SPECIAL warning on grep Reviewed-by: mbaesken Backport-of: bad6aa68e4d491e819ab22e91dd5d65bb094120e
1 parent 12d24f2 commit 9ae9af9

File tree

4 files changed

+30
-15
lines changed

4 files changed

+30
-15
lines changed

make/autoconf/basic.m4

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -60,6 +60,7 @@ AC_DEFUN([BASIC_CHECK_LEFTOVER_OVERRIDDEN],
6060

6161
###############################################################################
6262
# Setup basic configuration paths, and platform-specific stuff related to PATHs.
63+
# Make sure to only use tools set up in BASIC_SETUP_FUNDAMENTAL_TOOLS.
6364
AC_DEFUN_ONCE([BASIC_SETUP_PATHS],
6465
[
6566
# Save the current directory this script was started from

make/autoconf/basic_tools.m4

Lines changed: 26 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -29,8 +29,8 @@
2929
RECOMMENDED_PANDOC_VERSION=2.19.2
3030

3131
###############################################################################
32-
# Setup the most fundamental tools that relies on not much else to set up,
33-
# but is used by much of the early bootstrap code.
32+
# Setup the most fundamental tools, used for setting up build platform and
33+
# path handling.
3434
AC_DEFUN_ONCE([BASIC_SETUP_FUNDAMENTAL_TOOLS],
3535
[
3636
# Bootstrapping: These tools are needed by UTIL_LOOKUP_PROGS
@@ -42,15 +42,35 @@ AC_DEFUN_ONCE([BASIC_SETUP_FUNDAMENTAL_TOOLS],
4242
UTIL_CHECK_NONEMPTY(FILE)
4343
AC_PATH_PROGS(LDD, ldd)
4444
45-
# First are all the fundamental required tools.
45+
# Required tools
46+
UTIL_REQUIRE_PROGS(ECHO, echo)
47+
UTIL_REQUIRE_PROGS(TR, tr)
48+
UTIL_REQUIRE_PROGS(UNAME, uname)
49+
UTIL_REQUIRE_PROGS(WC, wc)
50+
51+
# Required tools with some special treatment
52+
UTIL_REQUIRE_SPECIAL(GREP, [AC_PROG_GREP])
53+
UTIL_REQUIRE_SPECIAL(EGREP, [AC_PROG_EGREP])
54+
UTIL_REQUIRE_SPECIAL(SED, [AC_PROG_SED])
55+
56+
# Tools only needed on some platforms
57+
UTIL_LOOKUP_PROGS(PATHTOOL, cygpath wslpath)
58+
UTIL_LOOKUP_PROGS(CMD, cmd.exe, $PATH:/cygdrive/c/windows/system32:/mnt/c/windows/system32:/c/windows/system32)
59+
])
60+
61+
###############################################################################
62+
# Setup further tools that should be resolved early but after setting up
63+
# build platform and path handling.
64+
AC_DEFUN_ONCE([BASIC_SETUP_TOOLS],
65+
[
66+
# Required tools
4667
UTIL_REQUIRE_PROGS(BASH, bash)
4768
UTIL_REQUIRE_PROGS(CAT, cat)
4869
UTIL_REQUIRE_PROGS(CHMOD, chmod)
4970
UTIL_REQUIRE_PROGS(CP, cp)
5071
UTIL_REQUIRE_PROGS(CUT, cut)
5172
UTIL_REQUIRE_PROGS(DATE, date)
5273
UTIL_REQUIRE_PROGS(DIFF, gdiff diff)
53-
UTIL_REQUIRE_PROGS(ECHO, echo)
5474
UTIL_REQUIRE_PROGS(EXPR, expr)
5575
UTIL_REQUIRE_PROGS(FIND, find)
5676
UTIL_REQUIRE_PROGS(GUNZIP, gunzip)
@@ -72,27 +92,19 @@ AC_DEFUN_ONCE([BASIC_SETUP_FUNDAMENTAL_TOOLS],
7292
UTIL_REQUIRE_PROGS(TAR, gtar tar)
7393
UTIL_REQUIRE_PROGS(TEE, tee)
7494
UTIL_REQUIRE_PROGS(TOUCH, touch)
75-
UTIL_REQUIRE_PROGS(TR, tr)
76-
UTIL_REQUIRE_PROGS(UNAME, uname)
77-
UTIL_REQUIRE_PROGS(WC, wc)
7895
UTIL_REQUIRE_PROGS(XARGS, xargs)
7996
80-
# Then required tools that require some special treatment.
81-
UTIL_REQUIRE_SPECIAL(GREP, [AC_PROG_GREP])
82-
UTIL_REQUIRE_SPECIAL(EGREP, [AC_PROG_EGREP])
97+
# Required tools with some special treatment
8398
UTIL_REQUIRE_SPECIAL(FGREP, [AC_PROG_FGREP])
84-
UTIL_REQUIRE_SPECIAL(SED, [AC_PROG_SED])
8599
86100
# Optional tools, we can do without them
87101
UTIL_LOOKUP_PROGS(DF, df)
88102
UTIL_LOOKUP_PROGS(GIT, git)
89103
UTIL_LOOKUP_PROGS(NICE, nice)
90104
UTIL_LOOKUP_PROGS(READLINK, greadlink readlink)
91105
92-
# These are only needed on some platforms
93-
UTIL_LOOKUP_PROGS(PATHTOOL, cygpath wslpath)
106+
# Tools only needed on some platforms
94107
UTIL_LOOKUP_PROGS(LSB_RELEASE, lsb_release)
95-
UTIL_LOOKUP_PROGS(CMD, cmd.exe, $PATH:/cygdrive/c/windows/system32:/mnt/c/windows/system32:/c/windows/system32)
96108
97109
# For compare.sh only
98110
UTIL_LOOKUP_PROGS(CMP, cmp)

make/autoconf/configure.ac

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -86,6 +86,7 @@ PLATFORM_SETUP_OPENJDK_BUILD_AND_TARGET
8686

8787
# Continue setting up basic stuff. Most remaining code require fundamental tools.
8888
BASIC_SETUP_PATHS
89+
BASIC_SETUP_TOOLS
8990

9091
# Check if it's a pure open build or if custom sources are to be used.
9192
JDKOPT_SETUP_OPEN_OR_CUSTOM

make/autoconf/platform.m4

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -640,6 +640,7 @@ AC_DEFUN([PLATFORM_SET_MODULE_TARGET_OS_VALUES],
640640
])
641641

642642
#%%% Build and target systems %%%
643+
# Make sure to only use tools set up in BASIC_SETUP_FUNDAMENTAL_TOOLS.
643644
AC_DEFUN_ONCE([PLATFORM_SETUP_OPENJDK_BUILD_AND_TARGET],
644645
[
645646
# Figure out the build and target systems. # Note that in autoconf terminology, "build" is obvious, but "target"
@@ -723,7 +724,7 @@ AC_DEFUN_ONCE([PLATFORM_SETUP_OPENJDK_TARGET_ENDIANNESS],
723724
[
724725
###############################################################################
725726
#
726-
# Is the target little of big endian?
727+
# Is the target little or big endian?
727728
#
728729
AC_C_BIGENDIAN([ENDIAN="big"],[ENDIAN="little"],[ENDIAN="unknown"],[ENDIAN="universal_endianness"])
729730

0 commit comments

Comments
 (0)