git: 1729d2f741a1 - main - Merge bmake-20260508

From: Simon J. Gerraty <sjg_at_FreeBSD.org>
Date: Wed, 13 May 2026 04:31:48 UTC
The branch main has been updated by sjg:

URL: https://cgit.FreeBSD.org/src/commit/?id=1729d2f741a12a42c61ed5308ee156a0d1cd1918

commit 1729d2f741a12a42c61ed5308ee156a0d1cd1918
Merge: 9cc9b8b37284 ef402bba8426
Author:     Simon J. Gerraty <sjg@FreeBSD.org>
AuthorDate: 2026-05-13 04:24:08 +0000
Commit:     Simon J. Gerraty <sjg@FreeBSD.org>
CommitDate: 2026-05-13 04:26:44 +0000

    Merge bmake-20260508
    
    Merge commit 'ef402bba84260816d3e8d6e2439b0bc7eddc9446'

 contrib/bmake/ChangeLog            | 16 ++++++++++++++++
 contrib/bmake/Makefile.config.in   |  1 +
 contrib/bmake/VERSION              |  2 +-
 contrib/bmake/arch.c               | 16 ++++++++--------
 contrib/bmake/bmake.1              |  6 +++---
 contrib/bmake/bmake.cat1           | 22 ++++++++++++----------
 contrib/bmake/cond.c               | 12 +++++-------
 contrib/bmake/configure            | 35 +++++++++++++++++++++++++----------
 contrib/bmake/configure.in         | 21 ++++++++++++++++++---
 contrib/bmake/dir.c                |  8 ++++----
 contrib/bmake/for.c                | 14 +++++++-------
 contrib/bmake/job.c                | 11 +++++------
 contrib/bmake/main.c               |  6 +++---
 contrib/bmake/make-bootstrap.sh.in |  4 +++-
 contrib/bmake/make.1               |  6 +++---
 contrib/bmake/make.c               | 13 ++++++-------
 contrib/bmake/make.h               | 14 +++++++-------
 contrib/bmake/meta.c               |  8 +++-----
 contrib/bmake/mk/ChangeLog         | 26 ++++++++++++++++++++++++++
 contrib/bmake/mk/dirdeps.mk        | 23 ++++++++++++++---------
 contrib/bmake/mk/gendirdeps.mk     |  8 ++++----
 contrib/bmake/mk/install-mk        |  4 ++--
 contrib/bmake/mk/lib.mk            |  4 ++--
 contrib/bmake/mk/meta.sys.mk       |  8 ++++++--
 contrib/bmake/mk/sys.dependfile.mk |  4 ++--
 contrib/bmake/mk/sys.dirdeps.mk    |  5 +++--
 contrib/bmake/mk/sys.mk            | 10 ++++++++--
 contrib/bmake/mk/sys.vars.mk       |  4 ++--
 contrib/bmake/parse.c              |  6 +++---
 contrib/bmake/var.c                | 13 ++++++-------
 usr.bin/bmake/Makefile.config      |  3 ++-
 usr.bin/bmake/config.h             |  4 ++--
 32 files changed, 212 insertions(+), 125 deletions(-)

diff --cc usr.bin/bmake/Makefile.config
index 5ba662b3145e,000000000000..17005c8109db
mode 100644,000000..100644
--- a/usr.bin/bmake/Makefile.config
+++ b/usr.bin/bmake/Makefile.config
@@@ -1,28 -1,0 +1,29 @@@
 +# This is a generated file, do NOT edit!
 +# See contrib/bmake/bsd.after-import.mk
 +#
 +
 +SRCTOP?= ${.CURDIR:H:H}
 +
 +# things set by configure
 +
- _MAKE_VERSION?=20260313
++_MAKE_VERSION?=20260508
 +
 +prefix?= /usr
 +srcdir= ${SRCTOP}/contrib/bmake
 +CC?= cc
 +MAKE_OS?= 
 +DEFAULT_SYS_PATH?= .../share/mk:/usr/share/mk
++MAKE_SAVE_DOLLARS_DEFAULT?= no
 +
 +EGREP= egrep
 +CPPFLAGS+= 
 +CFLAGS+= ${CPPFLAGS} -DHAVE_CONFIG_H
 +LDFLAGS+= 
 +LIBOBJS+=  ${LIBOBJDIR}stresep$U.o
 +LDADD+= 
 +USE_META?= yes
 +USE_FILEMON?= dev
 +FILEMON_H?= /usr/include/dev/filemon/filemon.h
 +BMAKE_PATH_MAX?= 1024
 +# used if MAXPATHLEN not defined
 +CPPFLAGS+= -DBMAKE_PATH_MAX=${BMAKE_PATH_MAX}
diff --cc usr.bin/bmake/config.h
index fecfc2be4adb,000000000000..4e4b7c9da809
mode 100644,000000..100644
--- a/usr.bin/bmake/config.h
+++ b/usr.bin/bmake/config.h
@@@ -1,449 -1,0 +1,449 @@@
 +/* config.h.  Generated from config.h.in by configure.  */
 +/* config.h.in.  Generated from configure.in by autoheader.  */
 +
 +/* Define if building universal (internal helper macro) */
 +/* #undef AC_APPLE_UNIVERSAL_BUILD */
 +
 +/* Path of default shell */
 +/* #undef DEFSHELL_CUSTOM */
 +
 +/* Shell spec to use by default */
 +/* #undef DEFSHELL_INDEX */
 +
 +/* Path of default shell */
 +/* #undef DEFSHELL_PATH */
 +
 +/* Define to 1 if you have the <ar.h> header file. */
 +#define HAVE_AR_H 1
 +
 +/* Define to 1 if you have the declaration of 'sys_siglist', and to 0 if you
 +   don't. */
 +#define HAVE_DECL_SYS_SIGLIST 1
 +
 +/* Define to 1 if you have the <dirent.h> header file, and it defines 'DIR'.
 +   */
 +#define HAVE_DIRENT_H 1
 +
 +/* Define to 1 if you have the 'dirname' function. */
 +#define HAVE_DIRNAME 1
 +
 +/* Define to 1 if you don't have 'vprintf' but do have '_doprnt.' */
 +/* #undef HAVE_DOPRNT */
 +
 +/* Define to 1 if you have the 'err' function. */
 +#define HAVE_ERR 1
 +
 +/* Define to 1 if you have the 'errx' function. */
 +#define HAVE_ERRX 1
 +
 +/* Define to 1 if you have the <err.h> header file. */
 +#define HAVE_ERR_H 1
 +
 +/* Define to 1 if you have the <fcntl.h> header file. */
 +#define HAVE_FCNTL_H 1
 +
 +/* Define to 1 if you have the 'fork' function. */
 +#define HAVE_FORK 1
 +
 +/* Define to 1 if you have the 'getcwd' function. */
 +#define HAVE_GETCWD 1
 +
 +/* Define to 1 if you have the 'getenv' function. */
 +#define HAVE_GETENV 1
 +
 +/* Define to 1 if you have the 'getopt' function. */
 +#define HAVE_GETOPT 1
 +
 +/* Define to 1 if you have the 'getwd' function. */
 +#define HAVE_GETWD 1
 +
 +/* Define to 1 if you have the <inttypes.h> header file. */
 +#define HAVE_INTTYPES_H 1
 +
 +/* Define to 1 if you have the 'killpg' function. */
 +#define HAVE_KILLPG 1
 +
 +/* Define to 1 if you have the <libgen.h> header file. */
 +#define HAVE_LIBGEN_H 1
 +
 +/* Define to 1 if you have the <limits.h> header file. */
 +#define HAVE_LIMITS_H 1
 +
 +/* Define to 1 if the system has the type 'long long int'. */
 +#define HAVE_LONG_LONG_INT 1
 +
 +/* Define to 1 if you have the <minix/config.h> header file. */
 +/* #undef HAVE_MINIX_CONFIG_H */
 +
 +/* Define to 1 if you have the <ndir.h> header file, and it defines 'DIR'. */
 +/* #undef HAVE_NDIR_H */
 +
 +/* Define to 1 if you have the <paths.h> header file. */
 +#define HAVE_PATHS_H 1
 +
 +/* Define to 1 if you have the <poll.h> header file. */
 +#define HAVE_POLL_H 1
 +
 +/* Define to 1 if you have the 'putenv' function. */
 +#define HAVE_PUTENV 1
 +
 +/* Define to 1 if you have the <ranlib.h> header file. */
 +#define HAVE_RANLIB_H 1
 +
 +/* Define to 1 if you have the 'realpath' function. */
 +#define HAVE_REALPATH 1
 +
 +/* Define to 1 if you have the <regex.h> header file. */
 +#define HAVE_REGEX_H 1
 +
 +/* Define to 1 if you have the 'select' function. */
 +#define HAVE_SELECT 1
 +
 +/* Define to 1 if you have the 'setenv' function. */
 +#define HAVE_SETENV 1
 +
 +/* Define to 1 if you have the 'setpgid' function. */
 +#define HAVE_SETPGID 1
 +
 +/* Define to 1 if you have the 'setrlimit' function. */
 +#define HAVE_SETRLIMIT 1
 +
 +/* Define to 1 if you have the 'setsid' function. */
 +#define HAVE_SETSID 1
 +
 +/* Define to 1 if you have the 'sigaction' function. */
 +#define HAVE_SIGACTION 1
 +
 +/* Define to 1 if you have the 'sigaddset' function. */
 +#define HAVE_SIGADDSET 1
 +
 +/* Define to 1 if you have the 'sigpending' function. */
 +#define HAVE_SIGPENDING 1
 +
 +/* Define to 1 if you have the 'sigprocmask' function. */
 +#define HAVE_SIGPROCMASK 1
 +
 +/* Define to 1 if you have the 'sigsetmask' function. */
 +#define HAVE_SIGSETMASK 1
 +
 +/* Define to 1 if you have the 'sigsuspend' function. */
 +#define HAVE_SIGSUSPEND 1
 +
 +/* Define to 1 if you have the 'sigvec' function. */
 +#define HAVE_SIGVEC 1
 +
 +/* Define to 1 if the system has the type 'sig_atomic_t'. */
 +#define HAVE_SIG_ATOMIC_T 1
 +
 +/* Define to 1 if you have the 'snprintf' function. */
 +#define HAVE_SNPRINTF 1
 +
 +/* Define to 1 if you have the <stdint.h> header file. */
 +#define HAVE_STDINT_H 1
 +
 +/* Define to 1 if you have the <stdio.h> header file. */
 +#define HAVE_STDIO_H 1
 +
 +/* Define to 1 if you have the <stdlib.h> header file. */
 +#define HAVE_STDLIB_H 1
 +
 +/* Define to 1 if you have the 'strerror' function. */
 +#define HAVE_STRERROR 1
 +
 +/* Define to 1 if you have the 'stresep' function. */
 +/* #undef HAVE_STRESEP */
 +
 +/* Define to 1 if you have the 'strftime' function. */
 +#define HAVE_STRFTIME 1
 +
 +/* Define to 1 if you have the <strings.h> header file. */
 +#define HAVE_STRINGS_H 1
 +
 +/* Define to 1 if you have the <string.h> header file. */
 +#define HAVE_STRING_H 1
 +
 +/* Define to 1 if you have the 'strlcpy' function. */
 +#define HAVE_STRLCPY 1
 +
 +/* Define to 1 if you have the 'strsep' function. */
 +#define HAVE_STRSEP 1
 +
 +/* Define to 1 if you have the 'strtod' function. */
 +#define HAVE_STRTOD 1
 +
 +/* Define to 1 if you have the 'strtol' function. */
 +#define HAVE_STRTOL 1
 +
 +/* Define to 1 if you have the 'strtoll' function. */
 +#define HAVE_STRTOLL 1
 +
 +/* Define to 1 if you have the 'strtoul' function. */
 +#define HAVE_STRTOUL 1
 +
 +/* Define to 1 if you have the 'sysctl' function. */
 +#define HAVE_SYSCTL 1
 +
 +/* Define to 1 if you have the <sys/dir.h> header file, and it defines 'DIR'.
 +   */
 +/* #undef HAVE_SYS_DIR_H */
 +
 +/* Define to 1 if you have the <sys/mman.h> header file. */
 +#define HAVE_SYS_MMAN_H 1
 +
 +/* Define to 1 if you have the <sys/ndir.h> header file, and it defines 'DIR'.
 +   */
 +/* #undef HAVE_SYS_NDIR_H */
 +
 +/* Define to 1 if you have the <sys/param.h> header file. */
 +#define HAVE_SYS_PARAM_H 1
 +
 +/* Define to 1 if you have the <sys/select.h> header file. */
 +#define HAVE_SYS_SELECT_H 1
 +
 +/* Define to 1 if you have the <sys/socket.h> header file. */
 +#define HAVE_SYS_SOCKET_H 1
 +
 +/* Define to 1 if you have the <sys/stat.h> header file. */
 +#define HAVE_SYS_STAT_H 1
 +
 +/* Define to 1 if you have the <sys/sysctl.h> header file. */
 +#define HAVE_SYS_SYSCTL_H 1
 +
 +/* Define to 1 if you have the <sys/time.h> header file. */
 +#define HAVE_SYS_TIME_H 1
 +
 +/* Define to 1 if you have the <sys/types.h> header file. */
 +#define HAVE_SYS_TYPES_H 1
 +
 +/* Define to 1 if you have the <sys/uio.h> header file. */
 +#define HAVE_SYS_UIO_H 1
 +
 +/* Define to 1 if you have <sys/wait.h> that is POSIX.1 compatible. */
 +#define HAVE_SYS_WAIT_H 1
 +
 +/* Define to 1 if you have the <unistd.h> header file. */
 +#define HAVE_UNISTD_H 1
 +
 +/* Define to 1 if you have the 'unsetenv' function. */
 +#define HAVE_UNSETENV 1
 +
 +/* Define to 1 if the system has the type 'unsigned long long int'. */
 +#define HAVE_UNSIGNED_LONG_LONG_INT 1
 +
 +/* Define to 1 if you have the <utime.h> header file. */
 +#define HAVE_UTIME_H 1
 +
 +/* Define to 1 if you have the 'vfork' function. */
 +#define HAVE_VFORK 1
 +
 +/* Define to 1 if you have the <vfork.h> header file. */
 +/* #undef HAVE_VFORK_H */
 +
 +/* Define to 1 if you have the 'vprintf' function. */
 +#define HAVE_VPRINTF 1
 +
 +/* Define to 1 if you have the 'vsnprintf' function. */
 +#define HAVE_VSNPRINTF 1
 +
 +/* Define to 1 if you have the 'wait3' function. */
 +#define HAVE_WAIT3 1
 +
 +/* Define to 1 if you have the 'wait4' function. */
 +#define HAVE_WAIT4 1
 +
 +/* Define to 1 if you have the 'waitpid' function. */
 +#define HAVE_WAITPID 1
 +
 +/* Define to 1 if you have the 'warn' function. */
 +#define HAVE_WARN 1
 +
 +/* Define to 1 if you have the 'warnx' function. */
 +#define HAVE_WARNX 1
 +
 +/* Define to 1 if you have the <wchar.h> header file. */
 +#define HAVE_WCHAR_H 1
 +
 +/* Define to 1 if 'fork' works. */
 +#define HAVE_WORKING_FORK 1
 +
 +/* Define to 1 if 'vfork' works. */
 +#define HAVE_WORKING_VFORK 1
 +
 +/* define if your compiler has __attribute__ */
 +#define HAVE___ATTRIBUTE__ 1
 +
 +/* Define to the address where bug reports for this package should be sent. */
 +#define PACKAGE_BUGREPORT "sjg@NetBSD.org"
 +
 +/* Define to the full name of this package. */
 +#define PACKAGE_NAME "bmake"
 +
 +/* Define to the full name and version of this package. */
- #define PACKAGE_STRING "bmake 20251111"
++#define PACKAGE_STRING "bmake 20260406"
 +
 +/* Define to the one symbol short name of this package. */
 +#define PACKAGE_TARNAME "bmake"
 +
 +/* Define to the home page for this package. */
 +#define PACKAGE_URL ""
 +
 +/* Define to the version of this package. */
- #define PACKAGE_VERSION "20251111"
++#define PACKAGE_VERSION "20260406"
 +
 +/* Define to 1 if the 'S_IS*' macros in <sys/stat.h> do not work properly. */
 +/* #undef STAT_MACROS_BROKEN */
 +
 +/* Define to 1 if all of the C89 standard headers exist (not just the ones
 +   required in a freestanding environment). This macro is provided for
 +   backward compatibility; new code need not use it. */
 +#define STDC_HEADERS 1
 +
 +/* Define to 1 if your <sys/time.h> declares 'struct tm'. */
 +/* #undef TM_IN_SYS_TIME */
 +
 +/* Enable extensions on AIX, Interix, z/OS.  */
 +#ifndef _ALL_SOURCE
 +# define _ALL_SOURCE 1
 +#endif
 +/* Enable general extensions on macOS.  */
 +#ifndef _DARWIN_C_SOURCE
 +# define _DARWIN_C_SOURCE 1
 +#endif
 +/* Enable general extensions on Solaris.  */
 +#ifndef __EXTENSIONS__
 +# define __EXTENSIONS__ 1
 +#endif
 +/* Enable GNU extensions on systems that have them.  */
 +#ifndef _GNU_SOURCE
 +# define _GNU_SOURCE 1
 +#endif
 +/* Enable X/Open compliant socket functions that do not require linking
 +   with -lxnet on HP-UX 11.11.  */
 +#ifndef _HPUX_ALT_XOPEN_SOCKET_API
 +# define _HPUX_ALT_XOPEN_SOCKET_API 1
 +#endif
 +/* Identify the host operating system as Minix.
 +   This macro does not affect the system headers' behavior.
 +   A future release of Autoconf may stop defining this macro.  */
 +#ifndef _MINIX
 +/* # undef _MINIX */
 +#endif
 +/* Enable general extensions on NetBSD.
 +   Enable NetBSD compatibility extensions on Minix.  */
 +#ifndef _NETBSD_SOURCE
 +# define _NETBSD_SOURCE 1
 +#endif
 +/* Enable OpenBSD compatibility extensions on NetBSD.
 +   Oddly enough, this does nothing on OpenBSD.  */
 +#ifndef _OPENBSD_SOURCE
 +# define _OPENBSD_SOURCE 1
 +#endif
 +/* Define to 1 if needed for POSIX-compatible behavior.  */
 +#ifndef _POSIX_SOURCE
 +/* # undef _POSIX_SOURCE */
 +#endif
 +/* Define to 2 if needed for POSIX-compatible behavior.  */
 +#ifndef _POSIX_1_SOURCE
 +/* # undef _POSIX_1_SOURCE */
 +#endif
 +/* Enable POSIX-compatible threading on Solaris.  */
 +#ifndef _POSIX_PTHREAD_SEMANTICS
 +# define _POSIX_PTHREAD_SEMANTICS 1
 +#endif
 +/* Enable extensions specified by ISO/IEC TS 18661-5:2014.  */
 +#ifndef __STDC_WANT_IEC_60559_ATTRIBS_EXT__
 +# define __STDC_WANT_IEC_60559_ATTRIBS_EXT__ 1
 +#endif
 +/* Enable extensions specified by ISO/IEC TS 18661-1:2014.  */
 +#ifndef __STDC_WANT_IEC_60559_BFP_EXT__
 +# define __STDC_WANT_IEC_60559_BFP_EXT__ 1
 +#endif
 +/* Enable extensions specified by ISO/IEC TS 18661-2:2015.  */
 +#ifndef __STDC_WANT_IEC_60559_DFP_EXT__
 +# define __STDC_WANT_IEC_60559_DFP_EXT__ 1
 +#endif
 +/* Enable extensions specified by C23 Annex F.  */
 +#ifndef __STDC_WANT_IEC_60559_EXT__
 +# define __STDC_WANT_IEC_60559_EXT__ 1
 +#endif
 +/* Enable extensions specified by ISO/IEC TS 18661-4:2015.  */
 +#ifndef __STDC_WANT_IEC_60559_FUNCS_EXT__
 +# define __STDC_WANT_IEC_60559_FUNCS_EXT__ 1
 +#endif
 +/* Enable extensions specified by C23 Annex H and ISO/IEC TS 18661-3:2015.  */
 +#ifndef __STDC_WANT_IEC_60559_TYPES_EXT__
 +# define __STDC_WANT_IEC_60559_TYPES_EXT__ 1
 +#endif
 +/* Enable extensions specified by ISO/IEC TR 24731-2:2010.  */
 +#ifndef __STDC_WANT_LIB_EXT2__
 +# define __STDC_WANT_LIB_EXT2__ 1
 +#endif
 +/* Enable extensions specified by ISO/IEC 24747:2009.  */
 +#ifndef __STDC_WANT_MATH_SPEC_FUNCS__
 +# define __STDC_WANT_MATH_SPEC_FUNCS__ 1
 +#endif
 +/* Enable extensions on HP NonStop.  */
 +#ifndef _TANDEM_SOURCE
 +# define _TANDEM_SOURCE 1
 +#endif
 +/* Enable X/Open extensions.  Define to 500 only if necessary
 +   to make mbstate_t available.  */
 +#ifndef _XOPEN_SOURCE
 +/* # undef _XOPEN_SOURCE */
 +#endif
 +
 +
 +/* Define WORDS_BIGENDIAN to 1 if your processor stores words with the most
 +   significant byte first (like Motorola and SPARC, unlike Intel). */
 +#if defined AC_APPLE_UNIVERSAL_BUILD
 +# if defined __BIG_ENDIAN__
 +#  define WORDS_BIGENDIAN 1
 +# endif
 +#else
 +# ifndef WORDS_BIGENDIAN
 +/* #  undef WORDS_BIGENDIAN */
 +# endif
 +#endif
 +
 +/* Define for Solaris 2.5.1 so the uint32_t typedef from <sys/synch.h>,
 +   <pthread.h>, or <semaphore.h> is not used. If the typedef were allowed, the
 +   #define below would cause a syntax error. */
 +/* #undef _UINT32_T */
 +
 +/* C99 function name */
 +/* #undef __func__ */
 +
 +/* Define to empty if 'const' does not conform to ANSI C. */
 +/* #undef const */
 +
 +/* Define to '__inline__' or '__inline' if that's what the C compiler
 +   calls it, or to nothing if 'inline' is not supported under any name.  */
 +#ifndef __cplusplus
 +/* #undef inline */
 +#endif
 +
 +/* Define to the type of a signed integer type of width exactly 64 bits if
 +   such a type exists and the standard includes do not define it. */
 +/* #undef int64_t */
 +
 +/* Define to 'int' if <sys/types.h> does not define. */
 +/* #undef mode_t */
 +
 +/* Define to 'long int' if <sys/types.h> does not define. */
 +/* #undef off_t */
 +
 +/* Define as a signed integer type capable of holding a process identifier. */
 +/* #undef pid_t */
 +
 +/* type that signal handlers can safely frob */
 +/* #undef sig_atomic_t */
 +
 +/* Define as 'unsigned int' if <stddef.h> doesn't define. */
 +/* #undef size_t */
 +
 +/* Define to the type of an unsigned integer type of width exactly 32 bits if
 +   such a type exists and the standard includes do not define it. */
 +/* #undef uint32_t */
 +
 +/* Define as 'fork' if 'vfork' does not work. */
 +/* #undef vfork */