git: d5e0a182cf15 - main - Update to bmake-20240108

From: Simon J. Gerraty <sjg_at_FreeBSD.org>
Date: Sun, 14 Jan 2024 01:31:33 UTC
The branch main has been updated by sjg:

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

commit d5e0a182cf153f8993a633b93d9220c99a89e760
Merge: 6b1c534927ad 7a05a7153af6
Author:     Simon J. Gerraty <sjg@FreeBSD.org>
AuthorDate: 2024-01-14 01:31:01 +0000
Commit:     Simon J. Gerraty <sjg@FreeBSD.org>
CommitDate: 2024-01-14 01:31:01 +0000

    Update to bmake-20240108

 contrib/bmake/ChangeLog                            | 102 +++
 contrib/bmake/README                               |  17 +-
 contrib/bmake/VERSION                              |   2 +-
 contrib/bmake/arch.c                               |  10 +-
 contrib/bmake/bmake.1                              |   6 +-
 contrib/bmake/bmake.cat1                           |   6 +-
 contrib/bmake/boot-strap                           |  16 +-
 contrib/bmake/bsd.after-import.mk                  |  17 +-
 contrib/bmake/buf.c                                |   6 +-
 contrib/bmake/buf.h                                |   4 +-
 contrib/bmake/compat.c                             |  65 +-
 contrib/bmake/cond.c                               | 111 ++--
 contrib/bmake/configure                            |  34 +-
 contrib/bmake/configure.in                         |  16 +-
 contrib/bmake/dir.c                                | 330 +++-------
 contrib/bmake/for.c                                |  14 +-
 contrib/bmake/hash.c                               |  28 +-
 contrib/bmake/hash.h                               |  21 +-
 contrib/bmake/job.c                                | 139 ++--
 contrib/bmake/job.h                                |   6 +-
 contrib/bmake/lst.c                                |  22 +-
 contrib/bmake/lst.h                                |   8 +-
 contrib/bmake/main.c                               | 156 ++---
 contrib/bmake/make.1                               |   6 +-
 contrib/bmake/make.c                               |  28 +-
 contrib/bmake/make.h                               |   5 +-
 contrib/bmake/meta.c                               |   6 +-
 contrib/bmake/mk/ChangeLog                         |  42 ++
 contrib/bmake/mk/compiler.mk                       |   4 +-
 contrib/bmake/mk/dirdeps.mk                        |  17 +-
 contrib/bmake/mk/dpadd.mk                          |  14 +-
 contrib/bmake/mk/gendirdeps.mk                     |   6 +-
 contrib/bmake/mk/host-target.mk                    |   7 +-
 contrib/bmake/mk/init.mk                           |   8 +-
 contrib/bmake/mk/install-mk                        |   4 +-
 contrib/bmake/mk/jobs.mk                           |   5 +-
 contrib/bmake/mk/lib.mk                            |  25 +-
 contrib/bmake/mk/man.mk                            |  93 ++-
 contrib/bmake/mk/meta.autodep.mk                   |   4 +-
 contrib/bmake/mk/own.mk                            |   3 +-
 contrib/bmake/mk/prog.mk                           |   5 +-
 contrib/bmake/mk/rst2htm.mk                        |   3 +-
 contrib/bmake/os.sh                                |   0
 contrib/bmake/parse.c                              | 279 +++------
 contrib/bmake/str.c                                |  77 ++-
 contrib/bmake/str.h                                |  29 +-
 contrib/bmake/suff.c                               | 168 ++---
 contrib/bmake/unit-tests/Makefile                  |   9 +-
 contrib/bmake/unit-tests/cmd-errors-jobs.exp       |   2 +-
 contrib/bmake/unit-tests/cmd-errors-lint.exp       |   2 +-
 contrib/bmake/unit-tests/cmd-errors.exp            |   2 +-
 contrib/bmake/unit-tests/cmdline-undefined.mk      |   4 +-
 contrib/bmake/unit-tests/comment.mk                |   4 +-
 contrib/bmake/unit-tests/cond-cmp-string.mk        |  14 +-
 contrib/bmake/unit-tests/cond-cmp-unary.mk         |   8 +-
 contrib/bmake/unit-tests/cond-eof.mk               |   4 +-
 contrib/bmake/unit-tests/cond-func-defined.exp     |   2 +-
 contrib/bmake/unit-tests/cond-func-defined.mk      |   8 +-
 contrib/bmake/unit-tests/cond-func-empty.mk        |  16 +-
 contrib/bmake/unit-tests/cond-func-exists.mk       |   6 +-
 contrib/bmake/unit-tests/cond-func.mk              |   4 +-
 contrib/bmake/unit-tests/cond-late.exp             |   2 +-
 contrib/bmake/unit-tests/cond-late.mk              |   6 +-
 contrib/bmake/unit-tests/cond-op-and.mk            |   8 +-
 contrib/bmake/unit-tests/cond-op-or.mk             |   8 +-
 contrib/bmake/unit-tests/cond-short.exp            |   2 +-
 contrib/bmake/unit-tests/cond-short.mk             |  23 +-
 contrib/bmake/unit-tests/cond-token-number.mk      |   6 +-
 contrib/bmake/unit-tests/cond-token-plain.exp      |   4 +-
 contrib/bmake/unit-tests/cond-token-plain.mk       |  16 +-
 contrib/bmake/unit-tests/cond-token-string.exp     |   2 +-
 contrib/bmake/unit-tests/cond-token-string.mk      |  10 +-
 contrib/bmake/unit-tests/cond-token-var.mk         |  16 +-
 contrib/bmake/unit-tests/dep-var.exp               |   2 +-
 contrib/bmake/unit-tests/dep-var.mk                |  10 +-
 contrib/bmake/unit-tests/depsrc-ignore.exp         |   2 +-
 .../bmake/unit-tests/deptgt-delete_on_error.exp    |   2 +-
 contrib/bmake/unit-tests/deptgt-makeflags.exp      |   2 +-
 contrib/bmake/unit-tests/deptgt-makeflags.mk       |   6 +-
 contrib/bmake/unit-tests/deptgt.mk                 |   6 +-
 contrib/bmake/unit-tests/dir.mk                    |   4 +-
 contrib/bmake/unit-tests/directive-else.mk         |   4 +-
 .../bmake/unit-tests/directive-export-gmake.exp    |   1 +
 contrib/bmake/unit-tests/directive-export-gmake.mk |  25 +-
 contrib/bmake/unit-tests/directive-export.exp      |   6 +-
 contrib/bmake/unit-tests/directive-export.mk       |  10 +-
 contrib/bmake/unit-tests/directive-for-empty.mk    |  12 +-
 contrib/bmake/unit-tests/directive-for-errors.mk   |  14 +-
 contrib/bmake/unit-tests/directive-for-escape.exp  |   4 +-
 contrib/bmake/unit-tests/directive-for-escape.mk   |  12 +-
 contrib/bmake/unit-tests/directive-for-if.mk       |   4 +-
 contrib/bmake/unit-tests/directive-for.exp         |  19 +-
 contrib/bmake/unit-tests/directive-for.mk          |  27 +-
 contrib/bmake/unit-tests/directive-ifmake.mk       |   4 +-
 contrib/bmake/unit-tests/directive-ifndef.mk       |  36 +-
 .../bmake/unit-tests/directive-include-guard.exp   |  16 +
 .../bmake/unit-tests/directive-include-guard.mk    | 188 ++++--
 contrib/bmake/unit-tests/directive-warning.mk      |   4 +-
 contrib/bmake/unit-tests/directive.mk              |   4 +-
 contrib/bmake/unit-tests/escape.exp                |  36 +-
 contrib/bmake/unit-tests/escape.mk                 |   7 +-
 contrib/bmake/unit-tests/hanoi-include.mk          |   7 +-
 contrib/bmake/unit-tests/jobs-error-indirect.exp   |   2 +-
 .../bmake/unit-tests/jobs-error-nested-make.exp    |   2 +-
 contrib/bmake/unit-tests/jobs-error-nested.exp     |   4 +-
 contrib/bmake/unit-tests/lint.mk                   |   4 +-
 contrib/bmake/unit-tests/moderrs.exp               |  20 +-
 contrib/bmake/unit-tests/moderrs.mk                |   6 +-
 contrib/bmake/unit-tests/opt-debug-file.mk         |   4 +-
 contrib/bmake/unit-tests/opt-debug-jobs.mk         |   4 +-
 contrib/bmake/unit-tests/opt-debug-lint.mk         |   6 +-
 contrib/bmake/unit-tests/opt-debug-loud.mk         |   6 +-
 contrib/bmake/unit-tests/opt-debug-var.mk          |   4 +-
 contrib/bmake/unit-tests/parse-var.mk              |   6 +-
 contrib/bmake/unit-tests/recursive.exp             |   4 +-
 contrib/bmake/unit-tests/recursive.mk              |  15 +-
 contrib/bmake/unit-tests/sh-dots.mk                |   6 +-
 contrib/bmake/unit-tests/sh-leading-hyphen.exp     |   2 +-
 contrib/bmake/unit-tests/shell-sh.mk               |   4 +-
 contrib/bmake/unit-tests/unexport.mk               |   4 +-
 contrib/bmake/unit-tests/var-eval-short.mk         |   4 +-
 contrib/bmake/unit-tests/var-op-append.mk          |  33 +-
 contrib/bmake/unit-tests/var-op-assign.mk          |   4 +-
 contrib/bmake/unit-tests/var-op-default.mk         |   8 +-
 contrib/bmake/unit-tests/var-op-expand.mk          |   6 +-
 contrib/bmake/unit-tests/var-op-shell.mk           |  20 +-
 contrib/bmake/unit-tests/var-readonly.exp          |   3 +
 contrib/bmake/unit-tests/var-readonly.mk           |   4 +-
 contrib/bmake/unit-tests/var-recursive.exp         |   8 +-
 contrib/bmake/unit-tests/var-recursive.mk          |   4 +-
 contrib/bmake/unit-tests/var-scope-cmdline.mk      |   4 +-
 .../bmake/unit-tests/var-scope-local-legacy.exp    |   2 +-
 contrib/bmake/unit-tests/var-scope-local-legacy.mk |  22 +-
 contrib/bmake/unit-tests/var-scope-local.exp       |   4 +-
 contrib/bmake/unit-tests/var-scope-local.mk        |  12 +-
 contrib/bmake/unit-tests/vardebug.exp              |  20 +-
 contrib/bmake/unit-tests/vardebug.mk               |  29 +-
 contrib/bmake/unit-tests/varmisc.exp               |   5 +-
 contrib/bmake/unit-tests/varmisc.mk                |  28 +-
 contrib/bmake/unit-tests/varmod-assign.exp         |  32 +
 contrib/bmake/unit-tests/varmod-assign.mk          |  71 ++-
 contrib/bmake/unit-tests/varmod-defined.exp        |   2 +-
 contrib/bmake/unit-tests/varmod-defined.mk         |  10 +-
 contrib/bmake/unit-tests/varmod-edge.exp           |   2 +-
 contrib/bmake/unit-tests/varmod-edge.mk            |   8 +-
 contrib/bmake/unit-tests/varmod-gmtime.mk          |  15 +-
 contrib/bmake/unit-tests/varmod-ifelse.exp         |  20 +-
 contrib/bmake/unit-tests/varmod-ifelse.mk          |  36 +-
 contrib/bmake/unit-tests/varmod-indirect.mk        |  24 +-
 contrib/bmake/unit-tests/varmod-l-name-to-value.mk |   4 +-
 contrib/bmake/unit-tests/varmod-localtime.mk       |   4 +-
 contrib/bmake/unit-tests/varmod-loop-varname.mk    |   4 +-
 contrib/bmake/unit-tests/varmod-loop.mk            |   6 +-
 contrib/bmake/unit-tests/varmod-match-escape.mk    |  20 +-
 contrib/bmake/unit-tests/varmod-match.exp          |  33 +-
 contrib/bmake/unit-tests/varmod-match.mk           | 317 ++++++----
 contrib/bmake/unit-tests/varmod-mtime.exp          |  16 +-
 contrib/bmake/unit-tests/varmod-mtime.mk           |  45 +-
 contrib/bmake/unit-tests/varmod-order.exp          |   6 +-
 contrib/bmake/unit-tests/varmod-range.exp          |  21 +-
 contrib/bmake/unit-tests/varmod-range.mk           |  26 +-
 contrib/bmake/unit-tests/varmod-subst-regex.mk     |  57 +-
 contrib/bmake/unit-tests/varmod-subst.mk           |  46 +-
 contrib/bmake/unit-tests/varmod-sysv.mk            |  10 +-
 contrib/bmake/unit-tests/varmod-to-separator.mk    |   4 +-
 contrib/bmake/unit-tests/varmod-undefined.mk       |   6 +-
 contrib/bmake/unit-tests/varmod.mk                 |   6 +-
 contrib/bmake/unit-tests/varname-dot-shell.exp     |  10 +-
 contrib/bmake/unit-tests/varname-dot-suffixes.exp  |  20 +-
 contrib/bmake/unit-tests/varname-dot-suffixes.mk   |  19 +-
 contrib/bmake/unit-tests/varname-empty.exp         |  24 +-
 contrib/bmake/unit-tests/varname-empty.mk          |   4 +-
 .../varname-make_print_var_on_error-jobs.mk        |   4 +-
 contrib/bmake/unit-tests/varname.mk                |   4 +-
 contrib/bmake/unit-tests/varparse-dynamic.mk       |   4 +-
 contrib/bmake/unit-tests/varparse-errors.exp       |  28 +-
 contrib/bmake/unit-tests/varparse-errors.mk        |   8 +-
 contrib/bmake/unit-tests/varparse-mod.mk           |   6 +-
 contrib/bmake/unit-tests/varparse-undef-partial.mk |  13 +-
 contrib/bmake/util.c                               |  96 ++-
 contrib/bmake/var.c                                | 696 +++++++++------------
 usr.bin/bmake/Makefile.config                      |   2 +-
 usr.bin/bmake/config.h                             |   4 +-
 usr.bin/bmake/unit-tests/Makefile                  |   9 +-
 184 files changed, 2585 insertions(+), 2176 deletions(-)

diff --cc contrib/bmake/job.c
index 22e21192281b,21b119ed6865..21582bb918eb
--- a/contrib/bmake/job.c
+++ b/contrib/bmake/job.c
@@@ -258,25 -257,7 +257,23 @@@ typedef struct ShellWriter 
  
  } ShellWriter;
  
 +/*
 + * FreeBSD: traditionally .MAKE is not required to
 + * pass jobs queue to sub-makes.
 + * Use .MAKE.ALWAYS_PASS_JOB_QUEUE=no to disable.
 + */
 +#define MAKE_ALWAYS_PASS_JOB_QUEUE "${.MAKE.ALWAYS_PASS_JOB_QUEUE:U}"
 +static bool Always_pass_job_queue = true;
 +/*
 + * FreeBSD: aborting entire parallel make isn't always
 + * desired. When doing tinderbox for example, failure of
 + * one architecture should not stop all.
 + * We still want to bail on interrupt though.
 + */
 +#define MAKE_JOB_ERROR_TOKEN "${MAKE_JOB_ERROR_TOKEN:U}"
 +static bool Job_error_token = true;
 +
- /*
-  * error handling variables
-  */
+ /* error handling variables */
  static int job_errors = 0;	/* number of errors reported */
  static enum {			/* Why is the make aborting? */
  	ABORT_NONE,
@@@ -1498,11 -1470,8 +1486,9 @@@ JobExec(Job *job, char **argv
  		if (lseek(0, 0, SEEK_SET) == -1)
  			execDie("lseek to 0", "stdin");
  
 -		if (job->node->type & (OP_MAKE | OP_SUBMAKE)) {
 +		if (Always_pass_job_queue ||
 +		    (job->node->type & (OP_MAKE | OP_SUBMAKE))) {
- 			/*
- 			 * Pass job token pipe to submakes.
- 			 */
+ 			/* Pass job token pipe to submakes. */
  			if (fcntl(tokenWaitJob.inPipe, F_SETFD, 0) == -1)
  				execDie("clear close-on-exec",
  				    "tokenWaitJob.inPipe");
diff --cc contrib/bmake/mk/install-mk
index b042f99671a8,357afd171e8c..357afd171e8c
mode 100644,100755..100755
--- a/contrib/bmake/mk/install-mk
+++ b/contrib/bmake/mk/install-mk
diff --cc contrib/bmake/os.sh
index 78b2de95a679,78b2de95a679..78b2de95a679
mode 100644,100755..100755
--- a/contrib/bmake/os.sh
+++ b/contrib/bmake/os.sh
diff --cc usr.bin/bmake/Makefile.config
index c31d0790ed9e,000000000000..4062f175f763
mode 100644,000000..100644
--- a/usr.bin/bmake/Makefile.config
+++ b/usr.bin/bmake/Makefile.config
@@@ -1,27 -1,0 +1,27 @@@
 +# 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?=20230909
++_MAKE_VERSION?=20240108
 +
 +prefix?= /usr
 +srcdir= ${SRCTOP}/contrib/bmake
 +CC?= cc
 +DEFAULT_SYS_PATH?= .../share/mk:/usr/share/mk
 +
 +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 af8b4c8e02ba,000000000000..b9e169fad867
mode 100644,000000..100644
--- a/usr.bin/bmake/config.h
+++ b/usr.bin/bmake/config.h
@@@ -1,445 -1,0 +1,445 @@@
 +/* 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 `mmap' function. */
 +#define HAVE_MMAP 1
 +
 +/* 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 `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 20230723"
++#define PACKAGE_STRING "bmake 20240101"
 +
 +/* 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 "20230723"
++#define PACKAGE_VERSION "20240101"
 +
 +/* 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 C90 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 3, Interix.  */
 +#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 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 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 to `unsigned int' if <sys/types.h> does not 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 */
diff --cc usr.bin/bmake/unit-tests/Makefile
index c5cc7646efed,000000000000..cf6c85809b9c
mode 100644,000000..100644
--- a/usr.bin/bmake/unit-tests/Makefile
+++ b/usr.bin/bmake/unit-tests/Makefile
@@@ -1,885 -1,0 +1,886 @@@
 +# This is a generated file, do NOT edit!
 +# See contrib/bmake/bsd.after-import.mk
 +#
- # $Id: Makefile,v 1.207 2023/09/09 16:44:03 sjg Exp $
++# $Id: Makefile,v 1.210 2024/01/08 18:28:08 sjg Exp $
 +#
- # $NetBSD: Makefile,v 1.341 2023/09/09 16:41:04 sjg Exp $
++# $NetBSD: Makefile,v 1.342 2024/01/07 02:07:44 sjg Exp $
 +#
 +# Unit tests for make(1)
 +#
 +# The main targets are:
 +#
 +# all:
 +#	run all the tests
 +# test:
 +#	run 'all', and compare to expected results
 +# accept:
 +#	move generated output to expected results
 +#
 +# Settable variables
 +#
 +# TEST_MAKE
 +#	The make program to be tested.
 +#
 +#
 +# Adding a test case
 +#
 +# Each feature should get its own set of tests in its own suitably
 +# named makefile (*.mk), with its own set of expected results (*.exp),
 +# and it should be added to the TESTS list.
 +#
 +
 +.MAIN: all
 +
 +# we use these below but we might be an older make
 +.MAKE.OS?= ${uname -s:L:sh}
 +.MAKE.UID?= ${id -u:L:sh}
 +
 +# for many tests we need a TMPDIR that will not collide
 +# with other users.
 +.if ${.OBJDIR} != ${.CURDIR}
 +# easy
 +TMPDIR:=	${.OBJDIR}/tmp
 +.elif defined(TMPDIR)
 +TMPDIR:=	${TMPDIR}/uid${.MAKE.UID}
 +.else
 +TMPDIR:=	/tmp/uid${.MAKE.UID}
 +.endif
 +# make sure it exists
 +.if !exist(${TMPDIR})
 +_!= mkdir -p ${TMPDIR}
 +.endif
 +
 +# Each test is in a sub-makefile.
 +# Keep the list sorted.
 +# Any test that is commented out must be ignored in
 +# src/tests/usr.bin/make/t_make.sh as well.
 +#TESTS+=		archive
 +#TESTS+=		archive-suffix
 +TESTS+=		cmd-errors
 +TESTS+=		cmd-errors-jobs
 +TESTS+=		cmd-errors-lint
 +TESTS+=		cmd-interrupt
 +TESTS+=		cmdline
 +TESTS+=		cmdline-redirect-stdin
 +TESTS+=		cmdline-undefined
 +TESTS+=		comment
 +TESTS+=		compat-error
 +TESTS+=		cond-cmp-numeric
 +TESTS+=		cond-cmp-numeric-eq
 +TESTS+=		cond-cmp-numeric-ge
 +TESTS+=		cond-cmp-numeric-gt
 +TESTS+=		cond-cmp-numeric-le
 +TESTS+=		cond-cmp-numeric-lt
 +TESTS+=		cond-cmp-numeric-ne
 +TESTS+=		cond-cmp-string
 +TESTS+=		cond-cmp-unary
 +TESTS+=		cond-eof
 +TESTS+=		cond-func
 +TESTS+=		cond-func-commands
 +TESTS+=		cond-func-defined
 +TESTS+=		cond-func-empty
 +TESTS+=		cond-func-exists
 +TESTS+=		cond-func-make
 +TESTS+=		cond-func-make-main
 +TESTS+=		cond-func-target
 +TESTS+=		cond-late
 +TESTS+=		cond-op
 +TESTS+=		cond-op-and
 +TESTS+=		cond-op-and-lint
 +TESTS+=		cond-op-not
 +TESTS+=		cond-op-or
 +TESTS+=		cond-op-or-lint
 +TESTS+=		cond-op-parentheses
 +TESTS+=		cond-short
 +TESTS+=		cond-token-number
 +TESTS+=		cond-token-plain
 +TESTS+=		cond-token-string
 +TESTS+=		cond-token-var
 +TESTS+=		cond-undef-lint
 +TESTS+=		counter
 +TESTS+=		counter-append
 +TESTS+=		dep
 +TESTS+=		dep-colon
 +TESTS+=		dep-colon-bug-cross-file
 +TESTS+=		dep-double-colon
 +TESTS+=		dep-double-colon-indep
 +TESTS+=		dep-duplicate
 +TESTS+=		dep-exclam
 +TESTS+=		dep-none
 +TESTS+=		dep-op-missing
 +TESTS+=		dep-percent
 +TESTS+=		dep-var
 +TESTS+=		dep-wildcards
 +TESTS+=		depsrc
 +TESTS+=		depsrc-end
 +TESTS+=		depsrc-exec
 +TESTS+=		depsrc-ignore
 +TESTS+=		depsrc-made
 +TESTS+=		depsrc-make
 +TESTS+=		depsrc-meta
 +TESTS+=		depsrc-nometa
 +TESTS+=		depsrc-nometa_cmp
 +TESTS+=		depsrc-nopath
 +TESTS+=		depsrc-notmain
 +TESTS+=		depsrc-optional
 +TESTS+=		depsrc-phony
 +TESTS+=		depsrc-precious
 +TESTS+=		depsrc-recursive
 +TESTS+=		depsrc-silent
 +TESTS+=		depsrc-use
 +TESTS+=		depsrc-usebefore
 +TESTS+=		depsrc-usebefore-double-colon
 +TESTS+=		depsrc-wait
 +TESTS+=		deptgt
 +TESTS+=		deptgt-begin
 +TESTS+=		deptgt-begin-fail
 +TESTS+=		deptgt-begin-fail-indirect
 +TESTS+=		deptgt-default
 +TESTS+=		deptgt-delete_on_error
 +TESTS+=		deptgt-end
 +TESTS+=		deptgt-end-fail
 +TESTS+=		deptgt-end-fail-all
 +TESTS+=		deptgt-end-fail-indirect
 +TESTS+=		deptgt-end-jobs
 +TESTS+=		deptgt-error
 +TESTS+=		deptgt-ignore
 +TESTS+=		deptgt-interrupt
 +TESTS+=		deptgt-main
 +TESTS+=		deptgt-makeflags
 +TESTS+=		deptgt-no_parallel
 +TESTS+=		deptgt-nopath
 +TESTS+=		deptgt-notparallel
 +TESTS+=		deptgt-objdir
 +TESTS+=		deptgt-order
 +TESTS+=		deptgt-path
 +TESTS+=		deptgt-path-suffix
 +TESTS+=		deptgt-phony
 +TESTS+=		deptgt-posix
 +TESTS+=		deptgt-precious
 +TESTS+=		deptgt-shell
 +TESTS+=		deptgt-silent
 +TESTS+=		deptgt-silent-jobs
 +TESTS+=		deptgt-stale
 +TESTS+=		deptgt-suffixes
 +TESTS+=		dir
 +TESTS+=		dir-expand-path
 +TESTS+=		directive
 +TESTS+=		directive-dinclude
 +TESTS+=		directive-elif
 +TESTS+=		directive-elifdef
 +TESTS+=		directive-elifmake
 +TESTS+=		directive-elifndef
 +TESTS+=		directive-elifnmake
 +TESTS+=		directive-else
 +TESTS+=		directive-endfor
 +TESTS+=		directive-endif
 +TESTS+=		directive-error
 +TESTS+=		directive-export
 +TESTS+=		directive-export-env
 +TESTS+=		directive-export-impl
 +TESTS+=		directive-export-gmake
 +TESTS+=		directive-export-literal
 +TESTS+=		directive-for
 +TESTS+=		directive-for-break
 +TESTS+=		directive-for-empty
 +TESTS+=		directive-for-errors
 +TESTS+=		directive-for-escape
 +TESTS+=		directive-for-generating-endif
 +TESTS+=		directive-for-if
 +TESTS+=		directive-for-lines
 +TESTS+=		directive-for-null
 +TESTS+=		directive-hyphen-include
 +TESTS+=		directive-if
 +TESTS+=		directive-if-nested
 +TESTS+=		directive-ifdef
 +TESTS+=		directive-ifmake
 +TESTS+=		directive-ifndef
 +TESTS+=		directive-ifnmake
 +TESTS+=		directive-include
 +TESTS+=		directive-include-fatal
 +TESTS+=		directive-include-guard
 +TESTS+=		directive-info
 +TESTS+=		directive-misspellings
 +TESTS+=		directive-sinclude
 +TESTS+=		directive-undef
 +TESTS+=		directive-unexport
 +TESTS+=		directive-unexport-env
 +TESTS+=		directive-warning
 +TESTS+=		dollar
 +TESTS+=		doterror
 +TESTS+=		dotwait
 +TESTS+=		error
 +TESTS+=		# escape	# broken by reverting POSIX changes
 +TESTS+=		export
 +TESTS+=		export-all
 +TESTS+=		export-env
 +TESTS+=		export-variants
 +TESTS+=		gnode-submake
 +TESTS+=		hanoi-include
 +TESTS+=		impsrc
 +TESTS+=		include-main
 +TESTS+=		job-flags
- #TESTS+=		job-output-long-lines
++TESTS+=		job-output-long-lines
 +TESTS+=		job-output-null
 +TESTS+=		jobs-empty-commands
 +TESTS+=		jobs-empty-commands-error
 +TESTS+=		jobs-error-indirect
 +TESTS+=		jobs-error-nested
 +TESTS+=		jobs-error-nested-make
 +TESTS+=		lint
 +TESTS+=		make-exported
 +TESTS+=		meta-cmd-cmp
 +TESTS+=		moderrs
 +TESTS+=		modmisc
 +.if ${.MAKE.UID} > 0
 +TESTS+=		objdir-writable
 +.endif
*** 650 LINES SKIPPED ***