Update to bmake-20131001 on the vendor branch
authorAlexandre Perrin <alex@kaworu.ch>
Thu, 21 Nov 2013 12:34:06 +0000 (13:34 +0100)
committerJohn Marino <draco@marino.st>
Sat, 23 Nov 2013 11:31:28 +0000 (12:31 +0100)
89 files changed:
contrib/bmake/ChangeLog
contrib/bmake/FILES
contrib/bmake/Makefile [new file with mode: 0644]
contrib/bmake/Makefile.config.in [new file with mode: 0644]
contrib/bmake/Makefile.in [deleted file]
contrib/bmake/bmake.1
contrib/bmake/bmake.cat1
contrib/bmake/boot-strap
contrib/bmake/bsd.after-import.mk
contrib/bmake/compat.c
contrib/bmake/cond.c
contrib/bmake/configure
contrib/bmake/configure.in
contrib/bmake/dir.c
contrib/bmake/job.c
contrib/bmake/job.h
contrib/bmake/main.c
contrib/bmake/make-bootstrap.sh.in
contrib/bmake/make.1
contrib/bmake/make.c
contrib/bmake/make.h
contrib/bmake/makefile.in [new file with mode: 0644]
contrib/bmake/meta.c
contrib/bmake/meta.h
contrib/bmake/mk/ChangeLog [new file with mode: 0644]
contrib/bmake/mk/FILES [new file with mode: 0644]
contrib/bmake/mk/README [new file with mode: 0644]
contrib/bmake/mk/auto.dep.mk [new file with mode: 0644]
contrib/bmake/mk/auto.obj.mk [new file with mode: 0644]
contrib/bmake/mk/autoconf.mk [new file with mode: 0644]
contrib/bmake/mk/autodep.mk [new file with mode: 0644]
contrib/bmake/mk/dep.mk [new file with mode: 0644]
contrib/bmake/mk/dirdeps.mk [new file with mode: 0644]
contrib/bmake/mk/doc.mk [new file with mode: 0644]
contrib/bmake/mk/dpadd.mk [new file with mode: 0644]
contrib/bmake/mk/final.mk [new file with mode: 0644]
contrib/bmake/mk/gendirdeps.mk [new file with mode: 0644]
contrib/bmake/mk/host-target.mk [new file with mode: 0644]
contrib/bmake/mk/host.libnames.mk [new file with mode: 0644]
contrib/bmake/mk/inc.mk [new file with mode: 0644]
contrib/bmake/mk/init.mk [new file with mode: 0644]
contrib/bmake/mk/install-mk [new file with mode: 0644]
contrib/bmake/mk/install-new.mk [new file with mode: 0644]
contrib/bmake/mk/java.mk [new file with mode: 0644]
contrib/bmake/mk/lib.mk [new file with mode: 0644]
contrib/bmake/mk/libnames.mk [new file with mode: 0644]
contrib/bmake/mk/libs.mk [new file with mode: 0644]
contrib/bmake/mk/links.mk [new file with mode: 0644]
contrib/bmake/mk/man.mk [new file with mode: 0644]
contrib/bmake/mk/meta.autodep.mk [new file with mode: 0644]
contrib/bmake/mk/meta.stage.mk [new file with mode: 0644]
contrib/bmake/mk/meta.subdir.mk [new file with mode: 0644]
contrib/bmake/mk/meta.sys.mk [new file with mode: 0644]
contrib/bmake/mk/meta2deps.py [new file with mode: 0755]
contrib/bmake/mk/meta2deps.sh [new file with mode: 0755]
contrib/bmake/mk/mk-files.txt [new file with mode: 0644]
contrib/bmake/mk/nls.mk [new file with mode: 0644]
contrib/bmake/mk/obj.mk [new file with mode: 0644]
contrib/bmake/mk/options.mk [new file with mode: 0644]
contrib/bmake/mk/own.mk [new file with mode: 0644]
contrib/bmake/mk/prlist.mk [new file with mode: 0644]
contrib/bmake/mk/prog.mk [new file with mode: 0644]
contrib/bmake/mk/progs.mk [new file with mode: 0644]
contrib/bmake/mk/rst2htm.mk [new file with mode: 0644]
contrib/bmake/mk/scripts.mk [new file with mode: 0644]
contrib/bmake/mk/srctop.mk [new file with mode: 0644]
contrib/bmake/mk/stage-install.sh [new file with mode: 0755]
contrib/bmake/mk/subdir.mk [new file with mode: 0644]
contrib/bmake/mk/sys.clean-env.mk [new file with mode: 0644]
contrib/bmake/mk/sys.dependfile.mk [new file with mode: 0644]
contrib/bmake/mk/sys.mk [new file with mode: 0644]
contrib/bmake/mk/sys/AIX.mk [new file with mode: 0644]
contrib/bmake/mk/sys/Darwin.mk [new file with mode: 0644]
contrib/bmake/mk/sys/Generic.mk [new file with mode: 0644]
contrib/bmake/mk/sys/HP-UX.mk [new file with mode: 0644]
contrib/bmake/mk/sys/IRIX.mk [new file with mode: 0644]
contrib/bmake/mk/sys/Linux.mk [new file with mode: 0644]
contrib/bmake/mk/sys/NetBSD.mk [new file with mode: 0644]
contrib/bmake/mk/sys/OSF1.mk [new file with mode: 0644]
contrib/bmake/mk/sys/OpenBSD.mk [new file with mode: 0644]
contrib/bmake/mk/sys/SunOS.mk [new file with mode: 0644]
contrib/bmake/mk/sys/UnixWare.mk [new file with mode: 0644]
contrib/bmake/mk/target-flags.mk [new file with mode: 0644]
contrib/bmake/mk/warnings.mk [new file with mode: 0644]
contrib/bmake/mk/yacc.mk [new file with mode: 0644]
contrib/bmake/parse.c
contrib/bmake/realpath.c
contrib/bmake/suff.c
contrib/bmake/var.c

index 933e435..b68a6e9 100644 (file)
@@ -1,3 +1,196 @@
+2013-10-01  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile (MAKE_VERSION): 20131001
+         Merge with NetBSD make, pick up
+         o main.c: for NATIVE build sysctl to get MACHINE_ARCH from
+           hw.machine_arch if necessary.
+         o meta.c: meta_oodate - need to look at src of Link and target
+           of Move as well.
+       * main.c: check that CTL_HW and HW_MACHINE_ARCH exist.
+         provide __arraycount() if needed.
+
+2013-09-04  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile (MAKE_VERSION): 20130904
+         Merge with NetBSD make, pick up
+         o Add VAR_INTERNAL context, so that internal setting of
+           MAKEFILE does not override value set by makefiles.
+
+2013-09-02  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile (MAKE_VERSION): 20130902
+         Merge with NetBSD make, pick up
+         o CompatRunCommand: only apply shellErrFlag when errCheck is true
+
+2013-08-28  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile (MAKE_VERSION): 20130828
+         Merge with NetBSD make, pick up
+         o Fix VAR :sh = syntax from Will Andrews at freebsd.org
+         o Call Job_SetPrefix() from Job_Init() so makefiles have
+           opportunity to set .MAKE.JOB.PREFIX
+
+2013-07-30  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile (MAKE_VERSION): 20130730
+         Merge with NetBSD make, pick up
+         o Allow suppression of --- job -- tokens by setting
+           .MAKE.JOB.PREFIX empty.
+
+2013-07-16  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile (MAKE_VERSION): 20130716
+         Merge with NetBSD make, pick up
+         o number of gmake compatability tweaks
+           -w for gmake style entering/leaving messages
+           if .MAKE.LEVEL > 0 indicate it in progname "make[1]" etc.
+           handle MAKEFLAGS containing only letters.
+         o when overriding a GLOBAL variable on the command line,
+           delete it from GLOBAL context so -V doesn't show the wrong
+           value.
+       
+2013-07-06  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * configure.in: We don't need MAKE_LEVEL_SAFE anymore.
+
+       * Makefile (MAKE_VERSION): 20130706
+         Merge with NetBSD make, pick up
+         o Shell_Init(): export shellErrFlag if commandShell hasErrCtl is
+           true so that CompatRunCommand() can use it, to ensure
+           consistent behavior with jobs mode.
+         o use MAKE_LEVEL_ENV to define the variable to propagate
+           .MAKE.LEVEL - currently set to MAKELEVEL (same as gmake).
+         o meta.c: use .MAKE.META.IGNORE_PATHS to allow customization of
+           paths to ignore.
+
+2013-06-04  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile (MAKE_VERSION): 20130604
+         Merge with NetBSD make, pick up
+         o job.c: JobCreatePipe: do fcntl() after any tweaking of fd's
+           to avoid leaking descriptors.
+
+2013-05-28  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile (MAKE_VERSION): 20130528
+         Merge with NetBSD make, pick up
+         o var.c: cleanup some left-overs in VarHash()
+
+2013-05-20  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile (MAKE_VERSION): 20130520
+         generate manifest from component FILES rather than have to
+         update FILES when mk/FILES changes.
+
+2013-05-18  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile (MAKE_VERSION): 20130518
+         Merge with NetBSD make, pick up
+         o suff.c: don't skip all processsing for .PHONY targets
+           else wildcard srcs do not get expanded.
+         o var.c: expand name of variable to delete if necessary.
+
+2013-03-30  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile (MAKE_VERSION): 20130330
+         Merge with NetBSD make, pick up
+         o meta.c: refine the handling of .OODATE in commands.
+           Rather than suppress command comparison for the entire script
+           as though .NOMETA_CMP had been used, only suppress it for the
+           one command line.
+           This allows something like ${.OODATE:M.NOMETA_CMP} to be used to 
+           suppress comparison of a command without otherwise affecting it.
+         o make.1: document that
+
+2013-03-22  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile (MAKE_VERSION): 20130321
+         yes, not quite right but its a cooler number.
+         Merge with NetBSD make, pick up
+         o parse.c: fix ParseGmakeExport to be portable 
+           and add a unit-test.
+       * meta.c: call meta_init() before makefiles are read and if built
+         with filemon support set .MAKE.PATH_FILEMON to _PATH_FILEMON
+         this let's makefiles test for support.
+         Call meta_mode_init() to process .MAKE.MODE.
+
+2013-03-13  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile (MAKE_VERSION): 20130305
+         Merge with NetBSD make, pick up
+         o run .STALE: target when a dependency from .depend is missing.
+         o job.c: add Job_RunTarget() for the above and .BEGIN
+
+2013-03-03  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile (MAKE_VERSION): 20130303
+         Merge with NetBSD make, pick up
+         o main.c: set .MAKE.OS to utsname.sysname
+         o job.c: more checks for read and poll errors
+         o var.c: lose VarChangeCase() saves 4% time
+
+2013-03-02  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * boot-strap: remove MAKEOBJDIRPREFIX from environment since we
+         want to use MAKEOBJDIR
+
+2013-01-27  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Merge with NetBSD make, pick up
+         o make.1: more info on how shell commands are handled.
+         o job.c,main.c: detect write errors to job pipes.
+
+2013-01-25  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile (MAKE_VERSION): 20130123
+         Merge with NetBSD make, pick up
+         o meta.c: if script uses .OODATE and meta_oodate() decides
+           rebuild is needed, .OODATE will be empty - set it to .ALLSRC.
+         o var.c: in debug output indicate which variabale modifiers
+           apply to.
+         o remove Check_Cwd logic the makefiles have been fixed.
+       
+2012-12-12  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * makefile.in: add a simple makefile for folk who insist on
+         ./configure; make; make install
+         it just runs boot-strap
+       * include mk/* to accommodate the above
+       * boot-strap:  re-work to accommodate the above
+         mksrc defaults to $Mydir/mk
+         allow op={configure,build,install,clean,all}
+         add options to facilitate install
+       * Makefile.config.in: just the bits set by configure
+       * Makefile: bump version to 20121212
+         abandon Makefile.in (NetBSD Makefile)
+         leverage mk/* instead
+       * configure.in: ensure srcdir is absolute
+
+2012-11-11  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile.in (MAKE_VERSION): 20121111
+         fix generation of bmake.cat1
+
+2012-11-09  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile.in (MAKE_VERSION): 20121109
+         Merge with NetBSD make, pick up
+         o make.c: MakeBuildChild: return 0 so search continues if a
+           .ORDER dependency is detected.
+         o unit-tests/order: test the above
+       
+2012-11-02  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile.in (MAKE_VERSION): 20121102
+         Merge with NetBSD make, pick up
+         o cond.c: allow cond_state[] to grow.
+           In meta mode with a very large tree, we can hit the limit
+           while processing dirdeps.
+       
+2012-10-25  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * Makefile.in: we need to use ${srcdir} not ${.CURDIR}
+
 2012-10-10  Simon J. Gerraty  <sjg@bad.crufty.net>
 
        * Makefile.in (MAKE_VERSION): 20121010
index 397d3a2..d4b5dca 100644 (file)
@@ -1,27 +1,26 @@
-FILES
 ChangeLog
-bmake.cat1
-boot-strap
-bsd.after-import.mk
-os.sh
-Makefile.in
+FILES
+Makefile
+Makefile.config.in
 PSD.doc/Makefile
 PSD.doc/tutorial.ms
 README
+aclocal.m4
 arch.c
+bmake.1
+bmake.cat1
+boot-strap
+bsd.after-import.mk
 buf.c
 buf.h
 compat.c
 cond.c
-make-conf.h
-make_malloc.c
-make_malloc.h
 config.h.in
 configure
-aclocal.m4
 configure.in
 dir.c
 dir.h
+dirname.c
 find_lib.sh
 for.c
 getopt.c
@@ -30,16 +29,6 @@ hash.h
 install-sh
 job.c
 job.h
-meta.c
-meta.h
-dirname.c
-realpath.c
-strlcpy.c
-strlist.c
-strlist.h
-stresep.c
-trace.c
-trace.h
 lst.h
 lst.lib/Makefile
 lst.lib/lstAppend.c
@@ -72,26 +61,36 @@ lst.lib/lstReplace.c
 lst.lib/lstSucc.c
 machine.sh
 main.c
+make-bootstrap.sh.in
+make-conf.h
 make.1
-bmake.1
 make.c
 make.h
-make-bootstrap.sh.in
+make_malloc.c
+make_malloc.h
+makefile.in
+meta.c
+meta.h
 missing/sys/cdefs.h
 mkdeps.sh
 nonints.h
+os.sh
 parse.c
 pathnames.h
 ranlib.h
+realpath.c
 setenv.c
 sigcompat.c
 sprite.h
 str.c
+stresep.c
+strlcpy.c
+strlist.c
+strlist.h
 suff.c
 targ.c
-util.c
-var.c
-wait.h
+trace.c
+trace.h
 unit-tests/Makefile.in
 unit-tests/comment
 unit-tests/cond1
@@ -100,6 +99,7 @@ unit-tests/dotwait
 unit-tests/error
 unit-tests/export
 unit-tests/export-all
+unit-tests/export-env
 unit-tests/forloop
 unit-tests/forsubst
 unit-tests/hash
@@ -110,12 +110,17 @@ unit-tests/modmisc
 unit-tests/modorder
 unit-tests/modts
 unit-tests/modword
+unit-tests/order
 unit-tests/phony-end
 unit-tests/posix
 unit-tests/qequals
+unit-tests/sunshcmd
 unit-tests/sysv
 unit-tests/ternary
 unit-tests/test.exp
 unit-tests/unexport
 unit-tests/unexport-env
 unit-tests/varcmd
+util.c
+var.c
+wait.h
diff --git a/contrib/bmake/Makefile b/contrib/bmake/Makefile
new file mode 100644 (file)
index 0000000..2ee2bf6
--- /dev/null
@@ -0,0 +1,221 @@
+#      $Id: Makefile,v 1.21 2013/10/01 15:44:05 sjg Exp $
+
+# Base version on src date
+MAKE_VERSION= 20131001
+
+PROG=  bmake
+
+SRCS= \
+       arch.c \
+       buf.c \
+       compat.c \
+       cond.c \
+       dir.c \
+       for.c \
+       hash.c \
+       job.c \
+       main.c \
+       make.c \
+       make_malloc.c \
+       meta.c \
+       parse.c \
+       str.c \
+       strlist.c \
+       suff.c \
+       targ.c \
+       trace.c \
+       util.c \
+       var.c
+
+# from lst.lib/
+SRCS+= \
+       lstAppend.c \
+       lstAtEnd.c \
+       lstAtFront.c \
+       lstClose.c \
+       lstConcat.c \
+       lstDatum.c \
+       lstDeQueue.c \
+       lstDestroy.c \
+       lstDupl.c \
+       lstEnQueue.c \
+       lstFind.c \
+       lstFindFrom.c \
+       lstFirst.c \
+       lstForEach.c \
+       lstForEachFrom.c \
+       lstInit.c \
+       lstInsert.c \
+       lstIsAtEnd.c \
+       lstIsEmpty.c \
+       lstLast.c \
+       lstMember.c \
+       lstNext.c \
+       lstOpen.c \
+       lstPrev.c \
+       lstRemove.c \
+       lstReplace.c \
+       lstSucc.c
+
+# this file gets generated by configure
+.-include "Makefile.config"
+
+.if !empty(LIBOBJS)
+SRCS+= ${LIBOBJS:T:.o=.c}
+.endif
+
+# just in case
+prefix?= /usr
+srcdir?= ${.CURDIR}
+
+DEFAULT_SYS_PATH?= .../share/mk:${prefix}/share/mk
+
+CPPFLAGS+= -DUSE_META
+CFLAGS+= ${CPPFLAGS}
+CFLAGS+= -D_PATH_DEFSYSPATH=\"${DEFAULT_SYS_PATH}\"
+CFLAGS+= -I. -I${srcdir} ${XDEFS} -DMAKE_NATIVE
+CFLAGS+= ${COPTS.${.ALLSRC:M*.c:T:u}}
+COPTS.main.c+= "-DMAKE_VERSION=\"${MAKE_VERSION}\""
+
+# meta mode can be useful even without filemon 
+FILEMON_H ?= /usr/include/dev/filemon/filemon.h
+.if exists(${FILEMON_H}) && ${FILEMON_H:T} == "filemon.h"
+COPTS.meta.c += -DHAVE_FILEMON_H -I${FILEMON_H:H}
+.endif
+
+.PATH: ${srcdir}
+.PATH: ${srcdir}/lst.lib
+
+.if make(obj) || make(clean)
+SUBDIR+= unit-tests
+.endif
+
+# start-delete1 for bsd.after-import.mk
+# we skip a lot of this when building as part of FreeBSD etc.
+
+# list of OS's which are derrived from BSD4.4
+BSD44_LIST= NetBSD FreeBSD OpenBSD DragonFly
+# we are...
+OS!= uname -s
+# are we 4.4BSD ?
+isBSD44:=${BSD44_LIST:M${OS}}
+
+.if ${isBSD44} == ""
+MANTARGET= cat
+INSTALL?=${srcdir}/install-sh
+.if (${MACHINE} == "sun386")
+# even I don't have one of these anymore :-)
+CFLAGS+= -DPORTAR
+.elif (${MACHINE} != "sunos")
+SRCS+= sigcompat.c
+CFLAGS+= -DSIGNAL_FLAGS=SA_RESTART
+.endif
+.else
+MANTARGET?= man
+.endif
+
+# turn this on by default - ignored if we are root
+WITH_INSTALL_AS_USER=
+
+# supress with -DWITHOUT_*
+OPTIONS_DEFAULT_YES+= \
+       AUTOCONF_MK \
+       INSTALL_MK \
+       PROG_LINK
+
+OPTIONS_DEFAULT_NO+= \
+       PROG_VERSION
+
+# process options now
+.include <own.mk>
+
+.if ${MK_PROG_VERSION} == "yes"
+PROG_NAME= ${PROG}-${MAKE_VERSION}
+.if ${MK_PROG_LINK} == "yes"
+SYMLINKS+= ${PROG}-${MAKE_VERSION} ${BINDIR}/${PROG}
+.endif
+.endif
+
+EXTRACT_MAN=no
+# end-delete1
+
+MAN= ${PROG}.1
+MAN1= ${MAN}
+
+.if (${PROG} != "make")
+CLEANFILES+= my.history
+.if make(${MAN}) || !exists(${srcdir}/${MAN})
+my.history: ${MAKEFILE}
+       @(echo ".Nm"; \
+       echo "is derived from NetBSD"; \
+       echo ".Xr make 1 ."; \
+       echo "It uses autoconf to facilitate portability to other platforms."; \
+       echo ".Pp") > $@
+
+.NOPATH: ${MAN}
+${MAN}:        make.1 my.history
+       @echo making $@
+       @sed -e 's/^.Nx/NetBSD/' -e '/^.Nm/s/make/${PROG}/' \
+       -e '/^.Sh HISTORY/rmy.history' \
+       -e '/^.Sh HISTORY/,$$s,^.Nm,make,' ${srcdir}/make.1 > $@
+
+all beforeinstall: ${MAN}
+_mfromdir=.
+.endif
+.endif
+
+MANTARGET?= cat
+MANDEST?= ${MANDIR}/${MANTARGET}1
+
+.if ${MANTARGET} == "cat"
+_mfromdir=${srcdir}
+.endif
+
+.include <prog.mk>
+
+CPPFLAGS+= -DMAKE_NATIVE -DHAVE_CONFIG_H
+COPTS.var.c += -Wno-cast-qual
+COPTS.job.c += -Wno-format-nonliteral
+COPTS.parse.c += -Wno-format-nonliteral
+COPTS.var.c += -Wno-format-nonliteral
+
+# Force these
+SHAREDIR= ${prefix}/share
+BINDIR= ${prefix}/bin
+MANDIR= ${SHAREDIR}/man
+
+.if !exists(.depend)
+${OBJS}: config.h
+.endif
+
+# make sure that MAKE_VERSION gets updated.
+main.o: ${SRCS} ${MAKEFILE}
+
+# start-delete2 for bsd.after-import.mk
+.if ${MK_AUTOCONF_MK} == "yes"
+.include <autoconf.mk>
+.endif
+SHARE_MK?=${SHAREDIR}/mk
+MKSRC=${srcdir}/mk
+INSTALL?=${srcdir}/install-sh
+
+.if ${MK_INSTALL_MK} == "yes"
+install: install-mk
+.endif
+
+beforeinstall:
+       test -d ${DESTDIR}${BINDIR} || ${INSTALL} -m 775 -d ${DESTDIR}${BINDIR}
+       test -d ${DESTDIR}${MANDEST} || ${INSTALL} -m 775 -d ${DESTDIR}${MANDEST}
+
+install-mk:
+.if exists(${MKSRC}/install-mk)
+       test -d ${DESTDIR}${SHARE_MK} || ${INSTALL} -m 775 -d ${DESTDIR}${SHARE_MK}
+       sh ${MKSRC}/install-mk -v -m 644 ${DESTDIR}${SHARE_MK}
+.else
+       @echo need to unpack mk.tar.gz under ${srcdir} or set MKSRC; false
+.endif
+# end-delete2
+
+# A simple unit-test driver to help catch regressions
+accept test:
+       cd ${.CURDIR}/unit-tests && MAKEFLAGS= ${.MAKE} -r -m / TEST_MAKE=${TEST_MAKE:U${.OBJDIR}/${PROG:T}} ${.TARGET}
diff --git a/contrib/bmake/Makefile.config.in b/contrib/bmake/Makefile.config.in
new file mode 100644 (file)
index 0000000..16ea66e
--- /dev/null
@@ -0,0 +1,16 @@
+# things set by configure
+
+prefix= @prefix@
+srcdir= @srcdir@
+CC?= @CC@
+MACHINE= @machine@
+MACHINE_ARCH= @machine_arch@
+DEFAULT_SYS_PATH= @default_sys_path@
+
+CPPFLAGS+= @CPPFLAGS@
+CFLAGS+= ${CPPFLAGS} @DEFS@
+LDFLAGS= @LDFLAGS@
+LIBOBJS= @LIBOBJS@
+LDADD= @LIBS@
+USE_META= @use_meta@
+FILEMON_H= @filemon_h@
diff --git a/contrib/bmake/Makefile.in b/contrib/bmake/Makefile.in
deleted file mode 100644 (file)
index 4cb55dd..0000000
+++ /dev/null
@@ -1,190 +0,0 @@
-#      $NetBSD: Makefile,v 1.56 2012/05/30 21:54:23 sjg Exp $
-#      @(#)Makefile    5.2 (Berkeley) 12/28/90
-
-#      $Id: Makefile.in,v 1.174 2012/10/10 18:46:24 sjg Exp $
-
-PROG=  bmake
-SRCS=  arch.c buf.c compat.c cond.c dir.c for.c hash.c job.c main.c \
-       make.c parse.c str.c suff.c targ.c trace.c var.c util.c 
-SRCS+=  strlist.c
-SRCS+=  make_malloc.c
-SRCS+= lstAppend.c lstAtEnd.c lstAtFront.c lstClose.c lstConcat.c \
-       lstDatum.c lstDeQueue.c lstDestroy.c lstDupl.c lstEnQueue.c \
-       lstFind.c lstFindFrom.c lstFirst.c lstForEach.c lstForEachFrom.c \
-       lstInit.c lstInsert.c lstIsAtEnd.c lstIsEmpty.c lstLast.c \
-       lstMember.c lstNext.c lstOpen.c lstRemove.c lstReplace.c lstSucc.c
-SRCS += lstPrev.c
-
-# you can use this Makefile if you have an earlier version of bmake.
-prefix= @prefix@
-srcdir= @srcdir@
-CC?= @CC@
-
-# Base version on src date
-MAKE_VERSION= 20121010
-MACHINE=@machine@
-MACHINE_ARCH=@machine_arch@
-DEFAULT_SYS_PATH = @default_sys_path@
-
-CPPFLAGS+= @CPPFLAGS@
-CFLAGS+= ${CPPFLAGS}
-CFLAGS+= -D_PATH_DEFSYSPATH=\"${DEFAULT_SYS_PATH}\"
-CFLAGS+= -I. -I${srcdir} @DEFS@ ${XDEFS} -DMAKE_NATIVE
-CFLAGS+= ${CFLAGS_${.TARGET:T}} 
-CFLAGS+= ${COPTS.${.ALLSRC:M*.c:T:u}}
-COPTS.main.c+= "-DMAKE_VERSION=\"${MAKE_VERSION}\""
-LDFLAGS= @LDFLAGS@
-LIBOBJS= @LIBOBJS@
-LDADD= @LIBS@
-
-.if !empty(LIBOBJS)
-SRCS+= ${LIBOBJS:T:.o=.c}
-.endif
-
-USE_META = @use_meta@
-.if ${USE_META} != "no"
-SRCS+= meta.c
-CPPFLAGS+= -DUSE_META
-FILEMON_H ?= @filemon_h@
-.if exists(${FILEMON_H}) && ${FILEMON_H:T} == "filemon.h"
-COPTS.meta.c += -DHAVE_FILEMON_H -I${FILEMON_H:H}
-.endif
-.endif
-
-.PATH: ${srcdir}
-.PATH: ${srcdir}/lst.lib
-
-OS!= uname -s
-ARCH!= uname -p 2>/dev/null || uname -m
-
-# list of OS's which are derrived from BSD4.4
-isBSD44= NetBSD FreeBSD OpenBSD DragonFly
-
-.if ${OS} == "NetBSD"
-# Don't set these for anyone else since we don't know what the effect may be.
-# On FreeBSD WARNS=2 sets a bunch of -W flags that make does not handle.
-WFORMAT= 1
-WARNS=4
-.NOPATH: bmake.cat1
-.if make(install) && exists(${DESTDIR}/usr/share/doc)
-SUBDIR=        PSD.doc
-.endif
-.endif
-
-.if defined(.PARSEDIR) 
-# we cannot rely on anything but bmake to parse this correctly.
-.if empty(isBSD44:M${OS})
-MANTARGET=cat
-INSTALL?=${srcdir}/install-sh
-.if (${MACHINE} == "sun386")
-# even I don't have one of these anymore :-)
-CFLAGS+= -DPORTAR
-.elif (${MACHINE} != "sunos")
-SRCS+= sigcompat.c
-CFLAGS+= -DSIGNAL_FLAGS=SA_RESTART
-.endif
-.endif
-
-.if make(obj) || make(clean)
-SUBDIR+= unit-tests
-.endif
-.endif
-
-# many systems use gcc these days
-CC_IS_GCC=@GCC@
-.if ${CC_IS_GCC} == "yes"
-# problem with gcc3
-CFLAGS_var.o+= -Wno-cast-qual
-.endif
-
-CFLAGS_main.o+= "-D@force_machine@MACHINE=\"${MACHINE}\"" "-DMACHINE_ARCH=\"${MACHINE_ARCH}\""
-
-EXTRACT_MAN=no
-
-MAN=${PROG}.1
-.if (${PROG} != "make")
-my.history: ${MAKEFILE}
-       @(echo ".Nm"; \
-       echo "is derived from NetBSD"; \
-       echo ".Xr make 1 ."; \
-       echo "It uses autoconf to facilitate portability to other platforms."; \
-       echo ".Pp") > $@
-
-${MAN}:        make.1 my.history
-       @echo making ${PROG}.1
-       @sed -e 's/^.Nx/NetBSD/' -e '/^.Nm/s/make/${PROG}/' \
-       -e '/^.Sh HISTORY/rmy.history' \
-       -e '/^.Sh HISTORY/,$$s,^.Nm,make,' ${.CURDIR}/make.1 > $@
-
-.endif
-
-.if !empty(isBSD44:M${OS})
-.if "${OS}" != "NetBSD" 
-MAN1=${MAN}
-.endif
-MANTARGET?=man
-.endif
-
-MANTARGET?= cat
-MANDEST?= ${MANDIR}/${MANTARGET}1
-
-.if ${MANTARGET} == "cat"
-_mfromdir=${srcdir}
-.endif
-
-.if exists(${srcdir}/../Makefile.inc)
-.include "${srcdir}/../Makefile.inc"
-.endif
-.-include <bsd.prog.mk>
-# sigh, FreeBSD at least includes bsd.subdir.mk via bsd.obj.mk
-# so the inclusion below, results in complaints about re-defined
-# targets.  For NetBSD though we need to explicitly include it.
-.if defined(.PARSEDIR)
-.if defined(SUBDIR) && !target(${SUBDIR:[1]})
-.-include <bsd.subdir.mk>
-.endif
-.endif
-
-CPPFLAGS+= -DMAKE_NATIVE
-COPTS.var.c += -Wno-cast-qual
-COPTS.job.c += -Wno-format-nonliteral
-COPTS.parse.c += -Wno-format-nonliteral
-COPTS.var.c += -Wno-format-nonliteral
-
-# Force these
-BINDIR= ${prefix}/bin
-MANDIR= ${prefix}/man
-
-arch.o:        config.h
-# make sure that MAKE_VERSION gets updated.
-main.o: ${SRCS} ${MAKEFILE}
-
-MK?=${prefix}/share/mk
-MKSRC?=@mksrc@
-INSTALL?=${srcdir}/install-sh
-
-beforeinstall:
-       test -d ${DESTDIR}${BINDIR} || ${INSTALL} -m 775 -d ${DESTDIR}${BINDIR}
-       test -d ${DESTDIR}${MANDEST} || ${INSTALL} -m 775 -d ${DESTDIR}${MANDEST}
-
-# latest version of *.mk includes an installer.
-# you should not need to  set USE_OS
-install-mk:
-.if exists(${MKSRC}/install-mk)
-       test -d ${DESTDIR}${MK} || ${INSTALL} -m 775 -d ${DESTDIR}${MK}
-       ${MKSRC}/install-mk -v -m 644 ${DESTDIR}${MK} ${USE_OS}
-.else
-       @echo need to unpack mk.tar.gz under ${srcdir} or set MKSRC; false
-.endif
-
-.ifdef TOOLDIR
-# this is a native netbsd build, 
-# use libutil rather than the local emalloc etc.
-CPPFLAGS+= -DUSE_EMALLOC
-LDADD+=-lutil
-DPADD+=${LIBUTIL}
-.endif
-
-# A simple unit-test driver to help catch regressions
-accept test:
-       cd ${.CURDIR}/unit-tests && MAKEFLAGS= ${.MAKE} -r -m / TEST_MAKE=${TEST_MAKE:U${.OBJDIR}/${PROG:T}} ${.TARGET}
index d7ed08a..df604e7 100644 (file)
@@ -1,4 +1,4 @@
-.\"    $NetBSD: make.1,v 1.209 2012/10/08 15:09:48 christos Exp $
+.\"    $NetBSD: make.1,v 1.222 2013/08/11 09:53:49 apb Exp $
 .\"
 .\" Copyright (c) 1990, 1993
 .\"    The Regents of the University of California.  All rights reserved.
@@ -29,7 +29,7 @@
 .\"
 .\"    from: @(#)make.1        8.4 (Berkeley) 3/19/94
 .\"
-.Dd October 8, 2012
+.Dd August 11, 2013
 .Dt MAKE 1
 .Os
 .Sh NAME
@@ -37,7 +37,7 @@
 .Nd maintain program dependencies
 .Sh SYNOPSIS
 .Nm
-.Op Fl BeikNnqrstWX
+.Op Fl BeikNnqrstWwX
 .Op Fl C Ar directory
 .Op Fl D Ar variable
 .Op Fl d Ar flags
@@ -209,6 +209,8 @@ Force the
 option to print raw values of variables.
 .It Ar v
 Print debugging information about variable assignment.
+.It Ar w
+Print entering and leaving directory messages, pre and post processing.
 .It Ar x
 Run shell commands with
 .Fl x
@@ -468,6 +470,50 @@ except that the effect can be limited to a single line of a script.
 A
 .Ql Ic \-
 causes any non-zero exit status of the command line to be ignored.
+.Pp
+When
+.Nm
+is run in jobs mode with
+.Fl j Ar max_jobs ,
+the entire script for the target is fed to a
+single instance of the shell.
+.Pp
+In compatibility (non-jobs) mode, each command is run in a separate process.
+If the command contains any shell meta characters
+.Pq Ql #=|^(){};&<>*?[]:$`\e\en
+it will be passed to the shell, otherwise
+.Nm
+will attempt direct execution.
+.Pp
+Since
+.Nm
+will
+.Xr chdir 2
+to
+.Ql Va .OBJDIR
+before executing any targets, each child process
+starts with that as its current working directory.
+.Pp
+Makefiles should be written so that the mode of
+.Nm
+operation does not change their behavior.
+For example, any command which needs to use
+.Dq cd
+or
+.Dq chdir ,
+without side-effect should be put in parenthesis:
+.Bd -literal -offset indent
+
+avoid-chdir-side-effects:
+       @echo Building $@ in `pwd`
+       @(cd ${.CURDIR} && ${.MAKE} $@)
+       @echo Back in `pwd`
+
+ensure-one-shell-regardless-of-mode:
+       @echo Building $@ in `pwd`; \\
+       (cd ${.CURDIR} && ${.MAKE} $@); \\
+       echo Back in `pwd`
+.Ed
 .Sh VARIABLE ASSIGNMENTS
 Variables in make are much like variables in the shell, and, by tradition,
 consist of all upper-case letters.
@@ -699,6 +745,9 @@ then output for each target is prefixed with a token
 .Ql --- target ---
 the first part of which can be controlled via
 .Va .MAKE.JOB.PREFIX .
+If 
+.Va .MAKE.JOB.PREFIX
+is empty, no token is printed.
 .br
 For example:
 .Li .MAKE.JOB.PREFIX=${.newline}---${.MAKE:T}[${.MAKE.PID}]
@@ -812,6 +861,11 @@ In "meta" mode, this variable contains a list of all the meta files
 used (updated or not).
 This list can be used to process the meta files to extract dependency
 information.
+.It Va .MAKE.META.IGNORE_PATHS
+Provides a list of path prefixes that should be ignored;
+because the contents are expected to change over time.
+The default list includes:
+.Ql Pa /dev /etc /proc /tmp /var/run /var/tmp
 .It Va .MAKE.META.PREFIX
 Defines the message printed for each meta file updated in "meta verbose" mode.
 The default value is:
@@ -830,6 +884,13 @@ by appending their names to
 is re-exported whenever
 .Ql Va .MAKEOVERRIDES
 is modified.
+.It Va .MAKE.PATH_FILEMON
+If
+.Nm
+was built with
+.Xr filemon 4
+support, this is set to the path of the device node.
+This allows makefiles to test for this support.
 .It Va .MAKE.PID
 The process-id of
 .Nm .
@@ -1247,7 +1308,7 @@ should start and end with a period.
 For example.
 .Dl ${LINKS:@.LINK.@${LN} ${TARGET} ${.LINK.}@}
 .Pp
-However a single character varaiable is often more readable:
+However a single character variable is often more readable:
 .Dl ${MAKE_PRINT_VAR_ON_ERROR:@v@$v='${$v}'${.newline}@}
 .It Cm \&:U Ns Ar newval
 If the variable is undefined
@@ -1270,7 +1331,7 @@ The path of the node which has the same name as the variable
 is the value.
 If no such node exists or its path is null, then the
 name of the variable is used.
-In order for this modifier to work, the name (node) must at least have 
+In order for this modifier to work, the name (node) must at least have
 appeared on the rhs of a dependency.
 .Sm off
 .It Cm \&:\&! Ar cmd Cm \&!
@@ -1713,6 +1774,20 @@ targets.
 Ignore differences in commands when deciding if target is out of date.
 This is useful if the command contains a value which always changes.
 If the number of commands change, though, the target will still be out of date.
+The same effect applies to any command line that uses the variable
+.Va .OODATE ,
+which can be used for that purpose even when not otherwise needed or desired:
+.Bd -literal -offset indent
+
+skip-compare-for-some:
+       @echo this will be compared
+       @echo this will not ${.OODATE:M.NOMETA_CMP}
+       @echo this will also be compared
+
+.Ed
+The
+.Cm \&:M
+pattern suppresses any expansion of the unwanted variable.
 .It Ic .NOPATH
 Do not search for the target in the directories specified by
 .Ic .PATH .
@@ -1896,6 +1971,12 @@ If the source is the special
 .Ic .DOTLAST
 target, then the current working
 directory is searched last.
+.It Ic .PATH. Ns Va suffix
+Like
+.Ic .PATH
+but applies only to files with a particular suffix.
+The suffix must have been previously declared with
+.Ic .SUFFIXES .
 .It Ic .PHONY
 Apply the
 .Ic .PHONY
@@ -1964,6 +2045,10 @@ If no sources are specified, the
 .Ic .SILENT
 attribute is applied to every
 command in the file.
+.It Ic .STALE
+This target gets run when a dependency file contains stale entries, having
+.Va .ALLSRC
+set to the name of that dependency file.
 .It Ic .SUFFIXES
 Each source specifies a suffix to
 .Nm .
@@ -2027,28 +2112,6 @@ NetBSD 5.0
 so that they still appear to be variable expansions.
 In particular this stops them being treated as syntax, and removes some
 obscure problems using them in .if statements.
-.Pp
-Unlike other
-.Nm
-programs, this implementation by default executes all commands for a given
-target using a single shell invocation.
-This is done for both efficiency and to simplify error handling in remote
-command invocations.
-Typically this is transparent to the user, unless the target commands change
-the current working directory using
-.Dq cd
-or
-.Dq chdir .
-To be compatible with Makefiles that do this, one can use
-.Fl B
-to disable this behavior.
-.Pp
-In compatibility mode, each command is run in a separate process.
-If the command contains any shell meta characters
-.Pq Ql #=|^(){};&<>*?[]:$`\e\en
-it will be passed to the shell, otherwise
-.Nm
-will attempt direct execution.
 .Sh SEE ALSO
 .Xr mkdep 1
 .Sh HISTORY
@@ -2068,6 +2131,13 @@ for Sprite at Berkeley.
 It was designed to be a parallel distributed make running jobs on different
 machines using a daemon called
 .Dq customs .
+.Pp
+Historically the target/dependency
+.Dq FRC
+has been used to FoRCe rebuilding (since the target/dependency
+does not exist... unless someone creates an
+.Dq FRC
+file).
 .Sh BUGS
 The
 make
index f693b07..ca49bb6 100644 (file)
@@ -4,7 +4,7 @@ N\bNA\bAM\bME\bE
      b\bbm\bma\bak\bke\be -- maintain program dependencies
 
 S\bSY\bYN\bNO\bOP\bPS\bSI\bIS\bS
-     b\bbm\bma\bak\bke\be [-\b-B\bBe\bei\bik\bkN\bNn\bnq\bqr\brs\bst\btW\bWX\bX] [-\b-C\bC _\bd_\bi_\br_\be_\bc_\bt_\bo_\br_\by] [-\b-D\bD _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be] [-\b-d\bd _\bf_\bl_\ba_\bg_\bs]
+     b\bbm\bma\bak\bke\be [-\b-B\bBe\bei\bik\bkN\bNn\bnq\bqr\brs\bst\btW\bWw\bwX\bX] [-\b-C\bC _\bd_\bi_\br_\be_\bc_\bt_\bo_\br_\by] [-\b-D\bD _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be] [-\b-d\bd _\bf_\bl_\ba_\bg_\bs]
            [-\b-f\bf _\bm_\ba_\bk_\be_\bf_\bi_\bl_\be] [-\b-I\bI _\bd_\bi_\br_\be_\bc_\bt_\bo_\br_\by] [-\b-J\bJ _\bp_\br_\bi_\bv_\ba_\bt_\be] [-\b-j\bj _\bm_\ba_\bx_\b__\bj_\bo_\bb_\bs]
            [-\b-m\bm _\bd_\bi_\br_\be_\bc_\bt_\bo_\br_\by] [-\b-T\bT _\bf_\bi_\bl_\be] [-\b-V\bV _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be] [_\bv_\ba_\br_\bi_\ba_\bb_\bl_\be_\b=_\bv_\ba_\bl_\bu_\be]
            [_\bt_\ba_\br_\bg_\be_\bt _\b._\b._\b.]
@@ -122,1334 +122,8 @@ D\bDE\bES\bSC\bCR\bRI\bIP\bPT\bTI\bIO\bON\bN
 
              _\bv       Print debugging information about variable assignment.
 
-             _\bx       Run shell commands with -\b-x\bx so the actual commands are
-                     printed as they are executed.
-
-     -\b-e\be      Specify that environment variables override macro assignments
-             within makefiles.
-
-     -\b-f\bf _\bm_\ba_\bk_\be_\bf_\bi_\bl_\be
-             Specify a makefile to read instead of the default `_\bm_\ba_\bk_\be_\bf_\bi_\bl_\be'.  If
-             _\bm_\ba_\bk_\be_\bf_\bi_\bl_\be is `-\b-', standard input is read.  Multiple makefiles may
-             be specified, and are read in the order specified.
-
-     -\b-I\bI _\bd_\bi_\br_\be_\bc_\bt_\bo_\br_\by
-             Specify a directory in which to search for makefiles and included
-             makefiles.  The system makefile directory (or directories, see
-             the -\b-m\bm option) is automatically included as part of this list.
-
-     -\b-i\bi      Ignore non-zero exit of shell commands in the makefile.  Equiva-
-             lent to specifying `-\b-' before each command line in the makefile.
-
-     -\b-J\bJ _\bp_\br_\bi_\bv_\ba_\bt_\be
-             This option should _\bn_\bo_\bt be specified by the user.
-
-             When the _\bj option is in use in a recursive build, this option is
-             passed by a make to child makes to allow all the make processes
-             in the build to cooperate to avoid overloading the system.
-
-     -\b-j\bj _\bm_\ba_\bx_\b__\bj_\bo_\bb_\bs
-             Specify the maximum number of jobs that b\bbm\bma\bak\bke\be may have running at
-             any one time.  The value is saved in _\b._\bM_\bA_\bK_\bE_\b._\bJ_\bO_\bB_\bS.  Turns compati-
-             bility mode off, unless the _\bB flag is also specified.  When com-
-             patibility mode is off, all commands associated with a target are
-             executed in a single shell invocation as opposed to the tradi-
-             tional one shell invocation per line.  This can break traditional
-             scripts which change directories on each command invocation and
-             then expect to start with a fresh environment on the next line.
-             It is more efficient to correct the scripts rather than turn
-             backwards compatibility on.
-
-     -\b-k\bk      Continue processing after errors are encountered, but only on
-             those targets that do not depend on the target whose creation
-             caused the error.
-
-     -\b-m\bm _\bd_\bi_\br_\be_\bc_\bt_\bo_\br_\by
-             Specify a directory in which to search for sys.mk and makefiles
-             included via the <_\bf_\bi_\bl_\be>-style include statement.  The -\b-m\bm option
-             can be used multiple times to form a search path.  This path will
-             override the default system include path: /usr/share/mk.  Fur-
-             thermore the system include path will be appended to the search
-             path used for "_\bf_\bi_\bl_\be"-style include statements (see the -\b-I\bI
-             option).
-
-             If a file or directory name in the -\b-m\bm argument (or the
-             MAKESYSPATH environment variable) starts with the string ".../"
-             then b\bbm\bma\bak\bke\be will search for the specified file or directory named
-             in the remaining part of the argument string.  The search starts
-             with the current directory of the Makefile and then works upward
-             towards the root of the filesystem.  If the search is successful,
-             then the resulting directory replaces the ".../" specification in
-             the -\b-m\bm argument.  If used, this feature allows b\bbm\bma\bak\bke\be to easily
-             search in the current source tree for customized sys.mk files
-             (e.g., by using ".../mk/sys.mk" as an argument).
-
-     -\b-n\bn      Display the commands that would have been executed, but do not
-             actually execute them unless the target depends on the .MAKE spe-
-             cial source (see below).
-
-     -\b-N\bN      Display the commands which would have been executed, but do not
-             actually execute any of them; useful for debugging top-level
-             makefiles without descending into subdirectories.
-
-     -\b-q\bq      Do not execute any commands, but exit 0 if the specified targets
-             are up-to-date and 1, otherwise.
-
-     -\b-r\br      Do not use the built-in rules specified in the system makefile.
-
-     -\b-s\bs      Do not echo any commands as they are executed.  Equivalent to
-             specifying `@\b@' before each command line in the makefile.
-
-     -\b-T\bT _\bt_\br_\ba_\bc_\be_\bf_\bi_\bl_\be
-             When used with the -\b-j\bj flag, append a trace record to _\bt_\br_\ba_\bc_\be_\bf_\bi_\bl_\be
-             for each job started and completed.
-
-     -\b-t\bt      Rather than re-building a target as specified in the makefile,
-             create it or update its modification time to make it appear up-
-             to-date.
-
-     -\b-V\bV _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be
-             Print b\bbm\bma\bak\bke\be's idea of the value of _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be, in the global con-
-             text.  Do not build any targets.  Multiple instances of this
-             option may be specified; the variables will be printed one per
-             line, with a blank line for each null or undefined variable.  If
-             _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be contains a `$' then the value will be expanded before
-             printing.
-
-     -\b-W\bW      Treat any warnings during makefile parsing as errors.
-
-     -\b-X\bX      Don't export variables passed on the command line to the environ-
-             ment individually.  Variables passed on the command line are
-             still exported via the _\bM_\bA_\bK_\bE_\bF_\bL_\bA_\bG_\bS environment variable.  This
-             option may be useful on systems which have a small limit on the
-             size of command arguments.
-
-     _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be_\b=_\bv_\ba_\bl_\bu_\be
-             Set the value of the variable _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be to _\bv_\ba_\bl_\bu_\be.  Normally, all
-             values passed on the command line are also exported to sub-makes
-             in the environment.  The -\b-X\bX flag disables this behavior.  Vari-
-             able assignments should follow options for POSIX compatibility
-             but no ordering is enforced.
-
-     There are seven different types of lines in a makefile: file dependency
-     specifications, shell commands, variable assignments, include statements,
-     conditional directives, for loops, and comments.
-
-     In general, lines may be continued from one line to the next by ending
-     them with a backslash (`\').  The trailing newline character and initial
-     whitespace on the following line are compressed into a single space.
-
-F\bFI\bIL\bLE\bE D\bDE\bEP\bPE\bEN\bND\bDE\bEN\bNC\bCY\bY S\bSP\bPE\bEC\bCI\bIF\bFI\bIC\bCA\bAT\bTI\bIO\bON\bNS\bS
-     Dependency lines consist of one or more targets, an operator, and zero or
-     more sources.  This creates a relationship where the targets ``depend''
-     on the sources and are usually created from them.  The exact relationship
-     between the target and the source is determined by the operator that sep-
-     arates them.  The three operators are as follows:
-
-     :\b:     A target is considered out-of-date if its modification time is less
-           than those of any of its sources.  Sources for a target accumulate
-           over dependency lines when this operator is used.  The target is
-           removed if b\bbm\bma\bak\bke\be is interrupted.
-
-     !\b!     Targets are always re-created, but not until all sources have been
-           examined and re-created as necessary.  Sources for a target accumu-
-           late over dependency lines when this operator is used.  The target
-           is removed if b\bbm\bma\bak\bke\be is interrupted.
-
-     :\b::\b:    If no sources are specified, the target is always re-created.  Oth-
-           erwise, a target is considered out-of-date if any of its sources
-           has been modified more recently than the target.  Sources for a
-           target do not accumulate over dependency lines when this operator
-           is used.  The target will not be removed if b\bbm\bma\bak\bke\be is interrupted.
-
-     Targets and sources may contain the shell wildcard values `?', `*', `[]',
-     and `{}'.  The values `?', `*', and `[]' may only be used as part of the
-     final component of the target or source, and must be used to describe
-     existing files.  The value `{}' need not necessarily be used to describe
-     existing files.  Expansion is in directory order, not alphabetically as
-     done in the shell.
-
-S\bSH\bHE\bEL\bLL\bL C\bCO\bOM\bMM\bMA\bAN\bND\bDS\bS
-     Each target may have associated with it a series of shell commands, nor-
-     mally used to create the target.  Each of the commands in this script
-     _\bm_\bu_\bs_\bt be preceded by a tab.  While any target may appear on a dependency
-     line, only one of these dependencies may be followed by a creation
-     script, unless the `:\b::\b:' operator is used.
-
-     If the first characters of the command line are any combination of `@\b@',
-     `+\b+', or `-\b-', the command is treated specially.  A `@\b@' causes the command
-     not to be echoed before it is executed.  A `+\b+' causes the command to be
-     executed even when -\b-n\bn is given.  This is similar to the effect of the
-     .MAKE special source, except that the effect can be limited to a single
-     line of a script.  A `-\b-' causes any non-zero exit status of the command
-     line to be ignored.
-
-V\bVA\bAR\bRI\bIA\bAB\bBL\bLE\bE A\bAS\bSS\bSI\bIG\bGN\bNM\bME\bEN\bNT\bTS\bS
-     Variables in make are much like variables in the shell, and, by tradi-
-     tion, consist of all upper-case letters.
-
-   V\bVa\bar\bri\bia\bab\bbl\ble\be a\bas\bss\bsi\big\bgn\bnm\bme\ben\bnt\bt m\bmo\bod\bdi\bif\bfi\bie\ber\brs\bs
-     The five operators that can be used to assign values to variables are as
-     follows:
-
-     =\b=       Assign the value to the variable.  Any previous value is overrid-
-             den.
-
-     +\b+=\b=      Append the value to the current value of the variable.
-
-     ?\b?=\b=      Assign the value to the variable if it is not already defined.
-
-     :\b:=\b=      Assign with expansion, i.e. expand the value before assigning it
-             to the variable.  Normally, expansion is not done until the vari-
-             able is referenced.  _\bN_\bO_\bT_\bE: References to undefined variables are
-             _\bn_\bo_\bt expanded.  This can cause problems when variable modifiers
-             are used.
-
-     !\b!=\b=      Expand the value and pass it to the shell for execution and
-             assign the result to the variable.  Any newlines in the result
-             are replaced with spaces.
-
-     Any white-space before the assigned _\bv_\ba_\bl_\bu_\be is removed; if the value is
-     being appended, a single space is inserted between the previous contents
-     of the variable and the appended value.
-
-     Variables are expanded by surrounding the variable name with either curly
-     braces (`{}') or parentheses (`()') and preceding it with a dollar sign
-     (`$').  If the variable name contains only a single letter, the surround-
-     ing braces or parentheses are not required.  This shorter form is not
-     recommended.
-
-     If the variable name contains a dollar, then the name itself is expanded
-     first.  This allows almost arbitrary variable names, however names con-
-     taining dollar, braces, parenthesis, or whitespace are really best
-     avoided!
-
-     If the result of expanding a variable contains a dollar sign (`$') the
-     string is expanded again.
-
-     Variable substitution occurs at three distinct times, depending on where
-     the variable is being used.
-
-     1.   Variables in dependency lines are expanded as the line is read.
-
-     2.   Variables in shell commands are expanded when the shell command is
-          executed.
-
-     3.   ``.for'' loop index variables are expanded on each loop iteration.
-          Note that other variables are not expanded inside loops so the fol-
-          lowing example code:
-
-
-                .for i in 1 2 3
-                a+=     ${i}
-                j=      ${i}
-                b+=     ${j}
-                .endfor
-
-                all:
-                        @echo ${a}
-                        @echo ${b}
-
-          will print:
-
-                1 2 3
-                3 3 3
-
-          Because while ${a} contains ``1 2 3'' after the loop is executed,
-          ${b} contains ``${j} ${j} ${j}'' which expands to ``3 3 3'' since
-          after the loop completes ${j} contains ``3''.
-
-   V\bVa\bar\bri\bia\bab\bbl\ble\be c\bcl\bla\bas\bss\bse\bes\bs
-     The four different classes of variables (in order of increasing prece-
-     dence) are:
-
-     Environment variables
-             Variables defined as part of b\bbm\bma\bak\bke\be's environment.
-
-     Global variables
-             Variables defined in the makefile or in included makefiles.
-
-     Command line variables
-             Variables defined as part of the command line.
-
-     Local variables
-             Variables that are defined specific to a certain target.  The
-             seven local variables are as follows:
-
-             _\b._\bA_\bL_\bL_\bS_\bR_\bC   The list of all sources for this target; also known as
-                       `_\b>'.
-
-             _\b._\bA_\bR_\bC_\bH_\bI_\bV_\bE  The name of the archive file.
-
-             _\b._\bI_\bM_\bP_\bS_\bR_\bC   In suffix-transformation rules, the name/path of the
-                       source from which the target is to be transformed (the
-                       ``implied'' source); also known as `_\b<'.  It is not
-                       defined in explicit rules.
-
-             _\b._\bM_\bE_\bM_\bB_\bE_\bR   The name of the archive member.
-
-             _\b._\bO_\bO_\bD_\bA_\bT_\bE   The list of sources for this target that were deemed
-                       out-of-date; also known as `_\b?'.
-
-             _\b._\bP_\bR_\bE_\bF_\bI_\bX   The file prefix of the target, containing only the file
-                       portion, no suffix or preceding directory components;
-                       also known as `_\b*'.
-
-             _\b._\bT_\bA_\bR_\bG_\bE_\bT   The name of the target; also known as `_\b@'.
-
-             The shorter forms `_\b@', `_\b?', `_\b<', `_\b>', and `_\b*' are permitted for
-             backward compatibility with historical makefiles and are not rec-
-             ommended.  The six variables `_\b@_\bF', `_\b@_\bD', `_\b<_\bF', `_\b<_\bD', `_\b*_\bF', and
-             `_\b*_\bD' are permitted for compatibility with AT&T System V UNIX
-             makefiles and are not recommended.
-
-             Four of the local variables may be used in sources on dependency
-             lines because they expand to the proper value for each target on
-             the line.  These variables are `_\b._\bT_\bA_\bR_\bG_\bE_\bT', `_\b._\bP_\bR_\bE_\bF_\bI_\bX', `_\b._\bA_\bR_\bC_\bH_\bI_\bV_\bE',
-             and `_\b._\bM_\bE_\bM_\bB_\bE_\bR'.
-
-   A\bAd\bdd\bdi\bit\bti\bio\bon\bna\bal\bl b\bbu\bui\bil\blt\bt-\b-i\bin\bn v\bva\bar\bri\bia\bab\bbl\ble\bes\bs
-     In addition, b\bbm\bma\bak\bke\be sets or knows about the following variables:
-
-     _\b$               A single dollar sign `$', i.e.  `$$' expands to a single
-                     dollar sign.
-
-     _\b._\bA_\bL_\bL_\bT_\bA_\bR_\bG_\bE_\bT_\bS     The list of all targets encountered in the Makefile.  If
-                     evaluated during Makefile parsing, lists only those tar-
-                     gets encountered thus far.
-
-     _\b._\bC_\bU_\bR_\bD_\bI_\bR         A path to the directory where b\bbm\bma\bak\bke\be was executed.  Refer
-                     to the description of `PWD' for more details.
-
-     MAKE            The name that b\bbm\bma\bak\bke\be was executed with (_\ba_\br_\bg_\bv_\b[_\b0_\b]).  For
-                     compatibility b\bbm\bma\bak\bke\be also sets _\b._\bM_\bA_\bK_\bE with the same value.
-                     The preferred variable to use is the environment variable
-                     MAKE because it is more compatible with other versions of
-                     b\bbm\bma\bak\bke\be and cannot be confused with the special target with
-                     the same name.
-
-     _\b._\bM_\bA_\bK_\bE_\b._\bD_\bE_\bP_\bE_\bN_\bD_\bF_\bI_\bL_\bE
-                     Names the makefile (default `_\b._\bd_\be_\bp_\be_\bn_\bd') from which gener-
-                     ated dependencies are read.
-
-     _\b._\bM_\bA_\bK_\bE_\b._\bE_\bX_\bP_\bA_\bN_\bD_\b__\bV_\bA_\bR_\bI_\bA_\bB_\bL_\bE_\bS
-                     A boolean that controls the default behavior of the -\b-V\bV
-                     option.
-
-     _\b._\bM_\bA_\bK_\bE_\b._\bE_\bX_\bP_\bO_\bR_\bT_\bE_\bD  The list of variables exported by b\bbm\bma\bak\bke\be.
-
-     _\b._\bM_\bA_\bK_\bE_\b._\bJ_\bO_\bB_\bS      The argument to the -\b-j\bj option.
-
-     _\b._\bM_\bA_\bK_\bE_\b._\bJ_\bO_\bB_\b._\bP_\bR_\bE_\bF_\bI_\bX
-                     If b\bbm\bma\bak\bke\be is run with _\bj then output for each target is
-                     prefixed with a token `--- target ---' the first part of
-                     which can be controlled via _\b._\bM_\bA_\bK_\bE_\b._\bJ_\bO_\bB_\b._\bP_\bR_\bE_\bF_\bI_\bX.
-                     For example:
-                     .MAKE.JOB.PREFIX=${.newline}---${.MAKE:T}[${.MAKE.PID}]
-                     would produce tokens like `---make[1234] target ---' mak-
-                     ing it easier to track the degree of parallelism being
-                     achieved.
-
-     MAKEFLAGS       The environment variable `MAKEFLAGS' may contain anything
-                     that may be specified on b\bbm\bma\bak\bke\be's command line.  Anything
-                     specified on b\bbm\bma\bak\bke\be's command line is appended to the
-                     `MAKEFLAGS' variable which is then entered into the envi-
-                     ronment for all programs which b\bbm\bma\bak\bke\be executes.
-
-     _\b._\bM_\bA_\bK_\bE_\b._\bL_\bE_\bV_\bE_\bL     The recursion depth of b\bbm\bma\bak\bke\be.  The initial instance of
-                     b\bbm\bma\bak\bke\be will be 0, and an incremented value is put into the
-                     environment to be seen by the next generation.  This
-                     allows tests like: .if ${.MAKE.LEVEL} == 0 to protect
-                     things which should only be evaluated in the initial
-                     instance of b\bbm\bma\bak\bke\be.
-
-     _\b._\bM_\bA_\bK_\bE_\b._\bM_\bA_\bK_\bE_\bF_\bI_\bL_\bE_\b__\bP_\bR_\bE_\bF_\bE_\bR_\bE_\bN_\bC_\bE
-                     The ordered list of makefile names (default `_\bm_\ba_\bk_\be_\bf_\bi_\bl_\be',
-                     `_\bM_\ba_\bk_\be_\bf_\bi_\bl_\be') that b\bbm\bma\bak\bke\be will look for.
-
-     _\b._\bM_\bA_\bK_\bE_\b._\bM_\bA_\bK_\bE_\bF_\bI_\bL_\bE_\bS
-                     The list of makefiles read by b\bbm\bma\bak\bke\be, which is useful for
-                     tracking dependencies.  Each makefile is recorded only
-                     once, regardless of the number of times read.
-
-     _\b._\bM_\bA_\bK_\bE_\b._\bM_\bO_\bD_\bE      Processed after reading all makefiles.  Can affect the
-                     mode that b\bbm\bma\bak\bke\be runs in.  It can contain a number of key-
-                     words:
-
-                     _\bc_\bo_\bm_\bp_\ba_\bt      Like -\b-B\bB, puts b\bbm\bma\bak\bke\be into "compat" mode.
-
-                     _\bm_\be_\bt_\ba        Puts b\bbm\bma\bak\bke\be into "meta" mode, where meta files
-                                 are created for each target to capture the
-                                 command run, the output generated and if
-                                 filemon(4) is available, the system calls
-                                 which are of interest to b\bbm\bma\bak\bke\be.  The captured
-                                 output can be very useful when diagnosing
-                                 errors.
-
-                     _\bc_\bu_\br_\bd_\bi_\br_\bO_\bk_\b= _\bb_\bf Normally b\bbm\bma\bak\bke\be will not create .meta files
-                                 in `_\b._\bC_\bU_\bR_\bD_\bI_\bR'.  This can be overridden by set-
-                                 ting _\bb_\bf to a value which represents True.
-
-                     _\be_\bn_\bv         For debugging, it can be useful to inlcude
-                                 the environment in the .meta file.
-
-                     _\bv_\be_\br_\bb_\bo_\bs_\be     If in "meta" mode, print a clue about the
-                                 target being built.  This is useful if the
-                                 build is otherwise running silently.  The
-                                 message printed the value of:
-                                 _\b._\bM_\bA_\bK_\bE_\b._\bM_\bE_\bT_\bA_\b._\bP_\bR_\bE_\bF_\bI_\bX.
-
-                     _\bi_\bg_\bn_\bo_\br_\be_\b-_\bc_\bm_\bd  Some makefiles have commands which are simply
-                                 not stable.  This keyword causes them to be
-                                 ignored for determining whether a target is
-                                 out of date in "meta" mode.  See also
-                                 .\b.N\bNO\bOM\bME\bET\bTA\bA_\b_C\bCM\bMP\bP.
-
-                     _\bs_\bi_\bl_\be_\bn_\bt_\b= _\bb_\bf  If _\bb_\bf is True, when a .meta file is created,
-                                 mark the target .\b.S\bSI\bIL\bLE\bEN\bNT\bT.
-
-     _\b._\bM_\bA_\bK_\bE_\b._\bM_\bE_\bT_\bA_\b._\bB_\bA_\bI_\bL_\bI_\bW_\bI_\bC_\bK
-                     In "meta" mode, provides a list of prefixes which match
-                     the directories controlled by b\bbm\bma\bak\bke\be.  If a file that was
-                     generated outside of _\b._\bO_\bB_\bJ_\bD_\bI_\bR but within said bailiwick is
-                     missing, the current target is considered out-of-date.
-
-     _\b._\bM_\bA_\bK_\bE_\b._\bM_\bE_\bT_\bA_\b._\bC_\bR_\bE_\bA_\bT_\bE_\bD
-                     In "meta" mode, this variable contains a list of all the
-                     meta files updated.  If not empty, it can be used to
-                     trigger processing of _\b._\bM_\bA_\bK_\bE_\b._\bM_\bE_\bT_\bA_\b._\bF_\bI_\bL_\bE_\bS.
-
-     _\b._\bM_\bA_\bK_\bE_\b._\bM_\bE_\bT_\bA_\b._\bF_\bI_\bL_\bE_\bS
-                     In "meta" mode, this variable contains a list of all the
-                     meta files used (updated or not).  This list can be used
-                     to process the meta files to extract dependency informa-
-                     tion.
-
-     _\b._\bM_\bA_\bK_\bE_\b._\bM_\bE_\bT_\bA_\b._\bP_\bR_\bE_\bF_\bI_\bX
-                     Defines the message printed for each meta file updated in
-                     "meta verbose" mode.  The default value is:
-                           Building ${.TARGET:H:tA}/${.TARGET:T}
-
-     _\b._\bM_\bA_\bK_\bE_\bO_\bV_\bE_\bR_\bR_\bI_\bD_\bE_\bS  This variable is used to record the names of variables
-                     assigned to on the command line, so that they may be
-                     exported as part of `MAKEFLAGS'.  This behaviour can be
-                     disabled by assigning an empty value to `_\b._\bM_\bA_\bK_\bE_\bO_\bV_\bE_\bR_\bR_\bI_\bD_\bE_\bS'
-                     within a makefile.  Extra variables can be exported from
-                     a makefile by appending their names to `_\b._\bM_\bA_\bK_\bE_\bO_\bV_\bE_\bR_\bR_\bI_\bD_\bE_\bS'.
-                     `MAKEFLAGS' is re-exported whenever `_\b._\bM_\bA_\bK_\bE_\bO_\bV_\bE_\bR_\bR_\bI_\bD_\bE_\bS' is
-                     modified.
-
-     _\b._\bM_\bA_\bK_\bE_\b._\bP_\bI_\bD       The process-id of b\bbm\bma\bak\bke\be.
-
-     _\b._\bM_\bA_\bK_\bE_\b._\bP_\bP_\bI_\bD      The parent process-id of b\bbm\bma\bak\bke\be.
-
-     _\bM_\bA_\bK_\bE_\b__\bP_\bR_\bI_\bN_\bT_\b__\bV_\bA_\bR_\b__\bO_\bN_\b__\bE_\bR_\bR_\bO_\bR
-                     When b\bbm\bma\bak\bke\be stops due to an error, it prints its name and
-                     the value of `_\b._\bC_\bU_\bR_\bD_\bI_\bR' as well as the value of any vari-
-                     ables named in `_\bM_\bA_\bK_\bE_\b__\bP_\bR_\bI_\bN_\bT_\b__\bV_\bA_\bR_\b__\bO_\bN_\b__\bE_\bR_\bR_\bO_\bR'.
-
-     _\b._\bn_\be_\bw_\bl_\bi_\bn_\be        This variable is simply assigned a newline character as
-                     its value.  This allows expansions using the :\b:@\b@ modifier
-                     to put a newline between iterations of the loop rather
-                     than a space.  For example, the printing of
-                     `_\bM_\bA_\bK_\bE_\b__\bP_\bR_\bI_\bN_\bT_\b__\bV_\bA_\bR_\b__\bO_\bN_\b__\bE_\bR_\bR_\bO_\bR' could be done as
-                     ${MAKE_PRINT_VAR_ON_ERROR:@v@$v='${$v}'${.newline}@}.
-
-     _\b._\bO_\bB_\bJ_\bD_\bI_\bR         A path to the directory where the targets are built.  Its
-                     value is determined by trying to chdir(2) to the follow-
-                     ing directories in order and using the first match:
-
-                     1.   ${MAKEOBJDIRPREFIX}${.CURDIR}
-
-                          (Only if `MAKEOBJDIRPREFIX' is set in the environ-
-                          ment or on the command line.)
-
-                     2.   ${MAKEOBJDIR}
-
-                          (Only if `MAKEOBJDIR' is set in the environment or
-                          on the command line.)
-
-                     3.   ${.CURDIR}_\b/_\bo_\bb_\bj_\b.${MACHINE}
-
-                     4.   ${.CURDIR}_\b/_\bo_\bb_\bj
-
-                     5.   _\b/_\bu_\bs_\br_\b/_\bo_\bb_\bj_\b/${.CURDIR}
-
-                     6.   ${.CURDIR}
-
-                     Variable expansion is performed on the value before it's
-                     used, so expressions such as
-                           ${.CURDIR:S,^/usr/src,/var/obj,}
-                     may be used.  This is especially useful with
-                     `MAKEOBJDIR'.
-
-                     `_\b._\bO_\bB_\bJ_\bD_\bI_\bR' may be modified in the makefile as a global
-                     variable.  In all cases, b\bbm\bma\bak\bke\be will chdir(2) to `_\b._\bO_\bB_\bJ_\bD_\bI_\bR'
-                     and set `PWD' to that directory before executing any tar-
-                     gets.
-
-     _\b._\bP_\bA_\bR_\bS_\bE_\bD_\bI_\bR       A path to the directory of the current `_\bM_\ba_\bk_\be_\bf_\bi_\bl_\be' being
-                     parsed.
-
-     _\b._\bP_\bA_\bR_\bS_\bE_\bF_\bI_\bL_\bE      The basename of the current `_\bM_\ba_\bk_\be_\bf_\bi_\bl_\be' being parsed.
-                     This variable and `_\b._\bP_\bA_\bR_\bS_\bE_\bD_\bI_\bR' are both set only while the
-                     `_\bM_\ba_\bk_\be_\bf_\bi_\bl_\be_\bs' are being parsed.  If you want to retain
-                     their current values, assign them to a variable using
-                     assignment with expansion: (`:\b:=\b=').
-
-     _\b._\bP_\bA_\bT_\bH           A variable that represents the list of directories that
-                     b\bbm\bma\bak\bke\be will search for files.  The search list should be
-                     updated using the target `_\b._\bP_\bA_\bT_\bH' rather than the vari-
-                     able.
-
-     PWD             Alternate path to the current directory.  b\bbm\bma\bak\bke\be normally
-                     sets `_\b._\bC_\bU_\bR_\bD_\bI_\bR' to the canonical path given by getcwd(3).
-                     However, if the environment variable `PWD' is set and
-                     gives a path to the current directory, then b\bbm\bma\bak\bke\be sets
-                     `_\b._\bC_\bU_\bR_\bD_\bI_\bR' to the value of `PWD' instead.  This behaviour
-                     is disabled if `MAKEOBJDIRPREFIX' is set or `MAKEOBJDIR'
-                     contains a variable transform.  `PWD' is set to the value
-                     of `_\b._\bO_\bB_\bJ_\bD_\bI_\bR' for all programs which b\bbm\bma\bak\bke\be executes.
-
-     .TARGETS        The list of targets explicitly specified on the command
-                     line, if any.
-
-     VPATH           Colon-separated (``:'') lists of directories that b\bbm\bma\bak\bke\be
-                     will search for files.  The variable is supported for
-                     compatibility with old make programs only, use `_\b._\bP_\bA_\bT_\bH'
-                     instead.
-
-   V\bVa\bar\bri\bia\bab\bbl\ble\be m\bmo\bod\bdi\bif\bfi\bie\ber\brs\bs
-     Variable expansion may be modified to select or modify each word of the
-     variable (where a ``word'' is white-space delimited sequence of charac-
-     ters).  The general format of a variable expansion is as follows:
-
-           ${variable[:modifier[:...]]}
-
-     Each modifier begins with a colon, which may be escaped with a backslash
-     (`\').
-
-     A set of modifiers can be specified via a variable, as follows:
-
-           modifier_variable=modifier[:...]
-           ${variable:${modifier_variable}[:...]}
-
-     In this case the first modifier in the modifier_variable does not start
-     with a colon, since that must appear in the referencing variable.  If any
-     of the modifiers in the modifier_variable contain a dollar sign (`$'),
-     these must be doubled to avoid early expansion.
-
-     The supported modifiers are:
-
-     :\b:E\bE   Replaces each word in the variable with its suffix.
-
-     :\b:H\bH   Replaces each word in the variable with everything but the last com-
-          ponent.
-
-     :\b:M\bM_\bp_\ba_\bt_\bt_\be_\br_\bn
-          Select only those words that match _\bp_\ba_\bt_\bt_\be_\br_\bn.  The standard shell
-          wildcard characters (`*', `?', and `[]') may be used.  The wildcard
-          characters may be escaped with a backslash (`\').
-
-     :\b:N\bN_\bp_\ba_\bt_\bt_\be_\br_\bn
-          This is identical to `:\b:M\bM', but selects all words which do not match
-          _\bp_\ba_\bt_\bt_\be_\br_\bn.
-
-     :\b:O\bO   Order every word in variable alphabetically.  To sort words in
-          reverse order use the `:\b:O\bO:\b:[\b[-\b-1\b1.\b..\b.1\b1]\b]' combination of modifiers.
-
-     :\b:O\bOx\bx  Randomize words in variable.  The results will be different each
-          time you are referring to the modified variable; use the assignment
-          with expansion (`:\b:=\b=') to prevent such behaviour.  For example,
-
-                LIST=                   uno due tre quattro
-                RANDOM_LIST=            ${LIST:Ox}
-                STATIC_RANDOM_LIST:=    ${LIST:Ox}
-
-                all:
-                        @echo "${RANDOM_LIST}"
-                        @echo "${RANDOM_LIST}"
-                        @echo "${STATIC_RANDOM_LIST}"
-                        @echo "${STATIC_RANDOM_LIST}"
-          may produce output similar to:
-
-                quattro due tre uno
-                tre due quattro uno
-                due uno quattro tre
-                due uno quattro tre
-
-     :\b:Q\bQ   Quotes every shell meta-character in the variable, so that it can be
-          passed safely through recursive invocations of b\bbm\bma\bak\bke\be.
-
-     :\b:R\bR   Replaces each word in the variable with everything but its suffix.
-
-     :\b:g\bgm\bmt\bti\bim\bme\be
-          The value is a format string for strftime(3), using the current
-          gmtime(3).
-
-     :\b:h\bha\bas\bsh\bh
-          Compute a 32bit hash of the value and encode it as hex digits.
-
-     :\b:l\blo\boc\bca\bal\blt\bti\bim\bme\be
-          The value is a format string for strftime(3), using the current
-          localtime(3).
-
-     :\b:t\btA\bA  Attempt to convert variable to an absolute path using realpath(3),
-          if that fails, the value is unchanged.
-
-     :\b:t\btl\bl  Converts variable to lower-case letters.
-
-     :\b:t\bts\bs_\bc
-          Words in the variable are normally separated by a space on expan-
-          sion.  This modifier sets the separator to the character _\bc.  If _\bc is
-          omitted, then no separator is used.  The common escapes (including
-          octal numeric codes), work as expected.
-
-     :\b:t\btu\bu  Converts variable to upper-case letters.
-
-     :\b:t\btW\bW  Causes the value to be treated as a single word (possibly containing
-          embedded white space).  See also `:\b:[\b[*\b*]\b]'.
-
-     :\b:t\btw\bw  Causes the value to be treated as a sequence of words delimited by
-          white space.  See also `:\b:[\b[@\b@]\b]'.
-
-     :\b:S\bS/_\bo_\bl_\bd_\b__\bs_\bt_\br_\bi_\bn_\bg/_\bn_\be_\bw_\b__\bs_\bt_\br_\bi_\bn_\bg/[1\b1g\bgW\bW]
-          Modify the first occurrence of _\bo_\bl_\bd_\b__\bs_\bt_\br_\bi_\bn_\bg in the variable's value,
-          replacing it with _\bn_\be_\bw_\b__\bs_\bt_\br_\bi_\bn_\bg.  If a `g' is appended to the last
-          slash of the pattern, all occurrences in each word are replaced.  If
-          a `1' is appended to the last slash of the pattern, only the first
-          word is affected.  If a `W' is appended to the last slash of the
-          pattern, then the value is treated as a single word (possibly con-
-          taining embedded white space).  If _\bo_\bl_\bd_\b__\bs_\bt_\br_\bi_\bn_\bg begins with a caret
-          (`^'), _\bo_\bl_\bd_\b__\bs_\bt_\br_\bi_\bn_\bg is anchored at the beginning of each word.  If
-          _\bo_\bl_\bd_\b__\bs_\bt_\br_\bi_\bn_\bg ends with a dollar sign (`$'), it is anchored at the end
-          of each word.  Inside _\bn_\be_\bw_\b__\bs_\bt_\br_\bi_\bn_\bg, an ampersand (`&') is replaced by
-          _\bo_\bl_\bd_\b__\bs_\bt_\br_\bi_\bn_\bg (without any `^' or `$').  Any character may be used as a
-          delimiter for the parts of the modifier string.  The anchoring,
-          ampersand and delimiter characters may be escaped with a backslash
-          (`\').
-
-          Variable expansion occurs in the normal fashion inside both
-          _\bo_\bl_\bd_\b__\bs_\bt_\br_\bi_\bn_\bg and _\bn_\be_\bw_\b__\bs_\bt_\br_\bi_\bn_\bg with the single exception that a backslash
-          is used to prevent the expansion of a dollar sign (`$'), not a pre-
-          ceding dollar sign as is usual.
-
-     :\b:C\bC/_\bp_\ba_\bt_\bt_\be_\br_\bn/_\br_\be_\bp_\bl_\ba_\bc_\be_\bm_\be_\bn_\bt/[1\b1g\bgW\bW]
-          The :\b:C\bC modifier is just like the :\b:S\bS modifier except that the old and
-          new strings, instead of being simple strings, are a regular expres-
-          sion (see regex(3)) string _\bp_\ba_\bt_\bt_\be_\br_\bn and an ed(1)-style string
-          _\br_\be_\bp_\bl_\ba_\bc_\be_\bm_\be_\bn_\bt.  Normally, the first occurrence of the pattern _\bp_\ba_\bt_\bt_\be_\br_\bn
-          in each word of the value is substituted with _\br_\be_\bp_\bl_\ba_\bc_\be_\bm_\be_\bn_\bt.  The `1'
-          modifier causes the substitution to apply to at most one word; the
-          `g' modifier causes the substitution to apply to as many instances
-          of the search pattern _\bp_\ba_\bt_\bt_\be_\br_\bn as occur in the word or words it is
-          found in; the `W' modifier causes the value to be treated as a sin-
-          gle word (possibly containing embedded white space).  Note that `1'
-          and `g' are orthogonal; the former specifies whether multiple words
-          are potentially affected, the latter whether multiple substitutions
-          can potentially occur within each affected word.
-
-     :\b:T\bT   Replaces each word in the variable with its last component.
-
-     :\b:u\bu   Remove adjacent duplicate words (like uniq(1)).
-
-     :\b:?\b?_\bt_\br_\bu_\be_\b__\bs_\bt_\br_\bi_\bn_\bg:\b:_\bf_\ba_\bl_\bs_\be_\b__\bs_\bt_\br_\bi_\bn_\bg
-          If the variable name (not its value), when parsed as a .if condi-
-          tional expression, evaluates to true, return as its value the
-          _\bt_\br_\bu_\be_\b__\bs_\bt_\br_\bi_\bn_\bg, otherwise return the _\bf_\ba_\bl_\bs_\be_\b__\bs_\bt_\br_\bi_\bn_\bg.  Since the variable
-          name is used as the expression, :? must be the first modifier after
-          the variable name itself - which will, of course, usually contain
-          variable expansions.  A common error is trying to use expressions
-          like
-                ${NUMBERS:M42:?match:no}
-          which actually tests defined(NUMBERS), to determine is any words
-          match "42" you need to use something like:
-                ${"${NUMBERS:M42}" != "":?match:no}.
-
-     _\b:_\bo_\bl_\bd_\b__\bs_\bt_\br_\bi_\bn_\bg_\b=_\bn_\be_\bw_\b__\bs_\bt_\br_\bi_\bn_\bg
-          This is the AT&T System V UNIX style variable substitution.  It must
-          be the last modifier specified.  If _\bo_\bl_\bd_\b__\bs_\bt_\br_\bi_\bn_\bg or _\bn_\be_\bw_\b__\bs_\bt_\br_\bi_\bn_\bg do not
-          contain the pattern matching character _\b% then it is assumed that
-          they are anchored at the end of each word, so only suffixes or
-          entire words may be replaced.  Otherwise _\b% is the substring of
-          _\bo_\bl_\bd_\b__\bs_\bt_\br_\bi_\bn_\bg to be replaced in _\bn_\be_\bw_\b__\bs_\bt_\br_\bi_\bn_\bg.
-
-          Variable expansion occurs in the normal fashion inside both
-          _\bo_\bl_\bd_\b__\bs_\bt_\br_\bi_\bn_\bg and _\bn_\be_\bw_\b__\bs_\bt_\br_\bi_\bn_\bg with the single exception that a backslash
-          is used to prevent the expansion of a dollar sign (`$'), not a pre-
-          ceding dollar sign as is usual.
-
-     :\b:@\b@_\bt_\be_\bm_\bp@\b@_\bs_\bt_\br_\bi_\bn_\bg@\b@
-          This is the loop expansion mechanism from the OSF Development Envi-
-          ronment (ODE) make.  Unlike .\b.f\bfo\bor\br loops expansion occurs at the time
-          of reference.  Assign _\bt_\be_\bm_\bp to each word in the variable and evaluate
-          _\bs_\bt_\br_\bi_\bn_\bg.  The ODE convention is that _\bt_\be_\bm_\bp should start and end with a
-          period.  For example.
-                ${LINKS:@.LINK.@${LN} ${TARGET} ${.LINK.}@}
-
-          However a single character varaiable is often more readable:
-                ${MAKE_PRINT_VAR_ON_ERROR:@v@$v='${$v}'${.newline}@}
-
-     :\b:U\bU_\bn_\be_\bw_\bv_\ba_\bl
-          If the variable is undefined _\bn_\be_\bw_\bv_\ba_\bl is the value.  If the variable
-          is defined, the existing value is returned.  This is another ODE
-          make feature.  It is handy for setting per-target CFLAGS for
-          instance:
-                ${_${.TARGET:T}_CFLAGS:U${DEF_CFLAGS}}
-          If a value is only required if the variable is undefined, use:
-                ${VAR:D:Unewval}
-
-     :\b:D\bD_\bn_\be_\bw_\bv_\ba_\bl
-          If the variable is defined _\bn_\be_\bw_\bv_\ba_\bl is the value.
-
-     :\b:L\bL   The name of the variable is the value.
-
-     :\b:P\bP   The path of the node which has the same name as the variable is the
-          value.  If no such node exists or its path is null, then the name of
-          the variable is used.  In order for this modifier to work, the name
-          (node) must at least have appeared on the rhs of a dependency.
-
-     :\b:!\b!_\bc_\bm_\bd!\b!
-          The output of running _\bc_\bm_\bd is the value.
-
-     :\b:s\bsh\bh  If the variable is non-empty it is run as a command and the output
-          becomes the new value.
-
-     :\b::\b:=\b=_\bs_\bt_\br
-          The variable is assigned the value _\bs_\bt_\br after substitution.  This
-          modifier and its variations are useful in obscure situations such as
-          wanting to set a variable when shell commands are being parsed.
-          These assignment modifiers always expand to nothing, so if appearing
-          in a rule line by themselves should be preceded with something to
-          keep b\bbm\bma\bak\bke\be happy.
-
-          The `:\b::\b:' helps avoid false matches with the AT&T System V UNIX style
-          :\b:=\b= modifier and since substitution always occurs the :\b::\b:=\b= form is
-          vaguely appropriate.
-
-     :\b::\b:?\b?=\b=_\bs_\bt_\br
-          As for :\b::\b:=\b= but only if the variable does not already have a value.
-
-     :\b::\b:+\b+=\b=_\bs_\bt_\br
-          Append _\bs_\bt_\br to the variable.
-
-     :\b::\b:!\b!=\b=_\bc_\bm_\bd
-          Assign the output of _\bc_\bm_\bd to the variable.
-
-     :\b:[\b[_\br_\ba_\bn_\bg_\be]\b]
-          Selects one or more words from the value, or performs other opera-
-          tions related to the way in which the value is divided into words.
-
-          Ordinarily, a value is treated as a sequence of words delimited by
-          white space.  Some modifiers suppress this behaviour, causing a
-          value to be treated as a single word (possibly containing embedded
-          white space).  An empty value, or a value that consists entirely of
-          white-space, is treated as a single word.  For the purposes of the
-          `:\b:[\b[]\b]' modifier, the words are indexed both forwards using positive
-          integers (where index 1 represents the first word), and backwards
-          using negative integers (where index -1 represents the last word).
-
-          The _\br_\ba_\bn_\bg_\be is subjected to variable expansion, and the expanded
-          result is then interpreted as follows:
-
-          _\bi_\bn_\bd_\be_\bx  Selects a single word from the value.
-
-          _\bs_\bt_\ba_\br_\bt.\b..\b._\be_\bn_\bd
-                 Selects all words from _\bs_\bt_\ba_\br_\bt to _\be_\bn_\bd, inclusive.  For example,
-                 `:\b:[\b[2\b2.\b..\b.-\b-1\b1]\b]' selects all words from the second word to the last
-                 word.  If _\bs_\bt_\ba_\br_\bt is greater than _\be_\bn_\bd, then the words are out-
-                 put in reverse order.  For example, `:\b:[\b[-\b-1\b1.\b..\b.1\b1]\b]' selects all
-                 the words from last to first.
-
-          *\b*      Causes subsequent modifiers to treat the value as a single
-                 word (possibly containing embedded white space).  Analogous
-                 to the effect of "$*" in Bourne shell.
-
-          0      Means the same as `:\b:[\b[*\b*]\b]'.
-
-          @\b@      Causes subsequent modifiers to treat the value as a sequence
-                 of words delimited by white space.  Analogous to the effect
-                 of "$@" in Bourne shell.
-
-          #\b#      Returns the number of words in the value.
-
-I\bIN\bNC\bCL\bLU\bUD\bDE\bE S\bST\bTA\bAT\bTE\bEM\bME\bEN\bNT\bTS\bS,\b, C\bCO\bON\bND\bDI\bIT\bTI\bIO\bON\bNA\bAL\bLS\bS A\bAN\bND\bD F\bFO\bOR\bR L\bLO\bOO\bOP\bPS\bS
-     Makefile inclusion, conditional structures and for loops  reminiscent of
-     the C programming language are provided in b\bbm\bma\bak\bke\be.  All such structures
-     are identified by a line beginning with a single dot (`.') character.
-     Files are included with either .\b.i\bin\bnc\bcl\blu\bud\bde\be <_\bf_\bi_\bl_\be> or .\b.i\bin\bnc\bcl\blu\bud\bde\be "_\bf_\bi_\bl_\be".  Vari-
-     ables between the angle brackets or double quotes are expanded to form
-     the file name.  If angle brackets are used, the included makefile is
-     expected to be in the system makefile directory.  If double quotes are
-     used, the including makefile's directory and any directories specified
-     using the -\b-I\bI option are searched before the system makefile directory.
-     For compatibility with other versions of b\bbm\bma\bak\bke\be `include file ...' is also
-     accepted.  If the include statement is written as .\b.-\b-i\bin\bnc\bcl\blu\bud\bde\be or as
-     .\b.s\bsi\bin\bnc\bcl\blu\bud\bde\be then errors locating and/or opening include files are ignored.
-
-     Conditional expressions are also preceded by a single dot as the first
-     character of a line.  The possible conditionals are as follows:
-
-     .\b.e\ber\brr\bro\bor\br _\bm_\be_\bs_\bs_\ba_\bg_\be
-             The message is printed along with the name of the makefile and
-             line number, then b\bbm\bma\bak\bke\be will exit.
-
-     .\b.e\bex\bxp\bpo\bor\brt\bt _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be _\b._\b._\b.
-             Export the specified global variable.  If no variable list is
-             provided, all globals are exported except for internal variables
-             (those that start with `.').  This is not affected by the -\b-X\bX
-             flag, so should be used with caution.  For compatibility with
-             other b\bbm\bma\bak\bke\be programs `export variable=value' is also accepted.
-
-             Appending a variable name to _\b._\bM_\bA_\bK_\bE_\b._\bE_\bX_\bP_\bO_\bR_\bT_\bE_\bD is equivalent to
-             exporting a variable.
-
-     .\b.e\bex\bxp\bpo\bor\brt\bt-\b-e\ben\bnv\bv _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be _\b._\b._\b.
-             The same as `.export', except that the variable is not appended
-             to _\b._\bM_\bA_\bK_\bE_\b._\bE_\bX_\bP_\bO_\bR_\bT_\bE_\bD.  This allows exporting a value to the environ-
-             ment which is different from that used by b\bbm\bma\bak\bke\be internally.
-
-     .\b.i\bin\bnf\bfo\bo _\bm_\be_\bs_\bs_\ba_\bg_\be
-             The message is printed along with the name of the makefile and
-             line number.
-
-     .\b.u\bun\bnd\bde\bef\bf _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be
-             Un-define the specified global variable.  Only global variables
-             may be un-defined.
-
-     .\b.u\bun\bne\bex\bxp\bpo\bor\brt\bt _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be _\b._\b._\b.
-             The opposite of `.export'.  The specified global _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be will be
-             removed from _\b._\bM_\bA_\bK_\bE_\b._\bE_\bX_\bP_\bO_\bR_\bT_\bE_\bD.  If no variable list is provided,
-             all globals are unexported, and _\b._\bM_\bA_\bK_\bE_\b._\bE_\bX_\bP_\bO_\bR_\bT_\bE_\bD deleted.
-
-     .\b.u\bun\bne\bex\bxp\bpo\bor\brt\bt-\b-e\ben\bnv\bv
-             Unexport all globals previously exported and clear the environ-
-             ment inherited from the parent.  This operation will cause a mem-
-             ory leak of the original environment, so should be used spar-
-             ingly.  Testing for _\b._\bM_\bA_\bK_\bE_\b._\bL_\bE_\bV_\bE_\bL being 0, would make sense.  Also
-             note that any variables which originated in the parent environ-
-             ment should be explicitly preserved if desired.  For example:
-
-                   .if ${.MAKE.LEVEL} == 0
-                   PATH := ${PATH}
-                   .unexport-env
-                   .export PATH
-                   .endif
-
-             Would result in an environment containing only `PATH', which is
-             the minimal useful environment.  Actually `.MAKE.LEVEL' will also
-             be pushed into the new environment.
-
-     .\b.w\bwa\bar\brn\bni\bin\bng\bg _\bm_\be_\bs_\bs_\ba_\bg_\be
-             The message prefixed by `_\bw_\ba_\br_\bn_\bi_\bn_\bg_\b:' is printed along with the name
-             of the makefile and line number.
-
-     .\b.i\bif\bf [!]_\be_\bx_\bp_\br_\be_\bs_\bs_\bi_\bo_\bn [_\bo_\bp_\be_\br_\ba_\bt_\bo_\br _\be_\bx_\bp_\br_\be_\bs_\bs_\bi_\bo_\bn _\b._\b._\b.]
-             Test the value of an expression.
-
-     .\b.i\bif\bfd\bde\bef\bf [!]_\bv_\ba_\br_\bi_\ba_\bb_\bl_\be [_\bo_\bp_\be_\br_\ba_\bt_\bo_\br _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be _\b._\b._\b.]
-             Test the value of a variable.
-
-     .\b.i\bif\bfn\bnd\bde\bef\bf [!]_\bv_\ba_\br_\bi_\ba_\bb_\bl_\be [_\bo_\bp_\be_\br_\ba_\bt_\bo_\br _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be _\b._\b._\b.]
-             Test the value of a variable.
-
-     .\b.i\bif\bfm\bma\bak\bke\be [!]_\bt_\ba_\br_\bg_\be_\bt [_\bo_\bp_\be_\br_\ba_\bt_\bo_\br _\bt_\ba_\br_\bg_\be_\bt _\b._\b._\b.]
-             Test the target being built.
-
-     .\b.i\bif\bfn\bnm\bma\bak\bke\be [!] _\bt_\ba_\br_\bg_\be_\bt [_\bo_\bp_\be_\br_\ba_\bt_\bo_\br _\bt_\ba_\br_\bg_\be_\bt _\b._\b._\b.]
-             Test the target being built.
-
-     .\b.e\bel\bls\bse\be   Reverse the sense of the last conditional.
-
-     .\b.e\bel\bli\bif\bf [!] _\be_\bx_\bp_\br_\be_\bs_\bs_\bi_\bo_\bn [_\bo_\bp_\be_\br_\ba_\bt_\bo_\br _\be_\bx_\bp_\br_\be_\bs_\bs_\bi_\bo_\bn _\b._\b._\b.]
-             A combination of `.\b.e\bel\bls\bse\be' followed by `.\b.i\bif\bf'.
-
-     .\b.e\bel\bli\bif\bfd\bde\bef\bf [!]_\bv_\ba_\br_\bi_\ba_\bb_\bl_\be [_\bo_\bp_\be_\br_\ba_\bt_\bo_\br _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be _\b._\b._\b.]
-             A combination of `.\b.e\bel\bls\bse\be' followed by `.\b.i\bif\bfd\bde\bef\bf'.
-
-     .\b.e\bel\bli\bif\bfn\bnd\bde\bef\bf [!]_\bv_\ba_\br_\bi_\ba_\bb_\bl_\be [_\bo_\bp_\be_\br_\ba_\bt_\bo_\br _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be _\b._\b._\b.]
-             A combination of `.\b.e\bel\bls\bse\be' followed by `.\b.i\bif\bfn\bnd\bde\bef\bf'.
-
-     .\b.e\bel\bli\bif\bfm\bma\bak\bke\be [!]_\bt_\ba_\br_\bg_\be_\bt [_\bo_\bp_\be_\br_\ba_\bt_\bo_\br _\bt_\ba_\br_\bg_\be_\bt _\b._\b._\b.]
-             A combination of `.\b.e\bel\bls\bse\be' followed by `.\b.i\bif\bfm\bma\bak\bke\be'.
-
-     .\b.e\bel\bli\bif\bfn\bnm\bma\bak\bke\be [!]_\bt_\ba_\br_\bg_\be_\bt [_\bo_\bp_\be_\br_\ba_\bt_\bo_\br _\bt_\ba_\br_\bg_\be_\bt _\b._\b._\b.]
-             A combination of `.\b.e\bel\bls\bse\be' followed by `.\b.i\bif\bfn\bnm\bma\bak\bke\be'.
-
-     .\b.e\ben\bnd\bdi\bif\bf  End the body of the conditional.
-
-     The _\bo_\bp_\be_\br_\ba_\bt_\bo_\br may be any one of the following:
-
-     |\b||\b|     Logical OR.
-
-     &\b&&\b&     Logical AND; of higher precedence than ``||''.
-
-     As in C, b\bbm\bma\bak\bke\be will only evaluate a conditional as far as is necessary to
-     determine its value.  Parentheses may be used to change the order of
-     evaluation.  The boolean operator `!\b!' may be used to logically negate an
-     entire conditional.  It is of higher precedence than `&\b&&\b&'.
-
-     The value of _\be_\bx_\bp_\br_\be_\bs_\bs_\bi_\bo_\bn may be any of the following:
-
-     d\bde\bef\bfi\bin\bne\bed\bd  Takes a variable name as an argument and evaluates to true if
-              the variable has been defined.
-
-     m\bma\bak\bke\be     Takes a target name as an argument and evaluates to true if the
-              target was specified as part of b\bbm\bma\bak\bke\be's command line or was
-              declared the default target (either implicitly or explicitly,
-              see _\b._\bM_\bA_\bI_\bN) before the line containing the conditional.
-
-     e\bem\bmp\bpt\bty\by    Takes a variable, with possible modifiers, and evaluates to true
-              if the expansion of the variable would result in an empty
-              string.
-
-     e\bex\bxi\bis\bst\bts\bs   Takes a file name as an argument and evaluates to true if the
-              file exists.  The file is searched for on the system search path
-              (see _\b._\bP_\bA_\bT_\bH).
-
-     t\bta\bar\brg\bge\bet\bt   Takes a target name as an argument and evaluates to true if the
-              target has been defined.
-
-     c\bco\bom\bmm\bma\ban\bnd\bds\bs
-              Takes a target name as an argument and evaluates to true if the
-              target has been defined and has commands associated with it.
-
-     _\bE_\bx_\bp_\br_\be_\bs_\bs_\bi_\bo_\bn may also be an arithmetic or string comparison.  Variable
-     expansion is performed on both sides of the comparison, after which the
-     integral values are compared.  A value is interpreted as hexadecimal if
-     it is preceded by 0x, otherwise it is decimal; octal numbers are not sup-
-     ported.  The standard C relational operators are all supported.  If after
-     variable expansion, either the left or right hand side of a `=\b==\b=' or `!\b!=\b='
-     operator is not an integral value, then string comparison is performed
-     between the expanded variables.  If no relational operator is given, it
-     is assumed that the expanded variable is being compared against 0 or an
-     empty string in the case of a string comparison.
-
-     When b\bbm\bma\bak\bke\be is evaluating one of these conditional expressions, and it
-     encounters a (white-space separated) word it doesn't recognize, either
-     the ``make'' or ``defined'' expression is applied to it, depending on the
-     form of the conditional.  If the form is `.\b.i\bif\bfd\bde\bef\bf', `.\b.i\bif\bfn\bnd\bde\bef\bf', or `.\b.i\bif\bf'
-     the ``defined'' expression is applied.  Similarly, if the form is
-     `.\b.i\bif\bfm\bma\bak\bke\be' or `.\b.i\bif\bfn\bnm\bma\bak\bke\be, t\bth\bhe\be' ``make'' expression is applied.
-
-     If the conditional evaluates to true the parsing of the makefile contin-
-     ues as before.  If it evaluates to false, the following lines are
-     skipped.  In both cases this continues until a `.\b.e\bel\bls\bse\be' or `.\b.e\ben\bnd\bdi\bif\bf' is
-     found.
-
-     For loops are typically used to apply a set of rules to a list of files.
-     The syntax of a for loop is:
-
-     .\b.f\bfo\bor\br _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be [_\bv_\ba_\br_\bi_\ba_\bb_\bl_\be _\b._\b._\b.] i\bin\bn _\be_\bx_\bp_\br_\be_\bs_\bs_\bi_\bo_\bn
-     <make-rules>
-     .\b.e\ben\bnd\bdf\bfo\bor\br
-
-     After the for e\bex\bxp\bpr\bre\bes\bss\bsi\bio\bon\bn is evaluated, it is split into words.  On each
-     iteration of the loop, one word is taken and assigned to each v\bva\bar\bri\bia\bab\bbl\ble\be,
-     in order, and these v\bva\bar\bri\bia\bab\bbl\ble\bes\bs are substituted into the m\bma\bak\bke\be-\b-r\bru\bul\ble\bes\bs inside
-     the body of the for loop.  The number of words must come out even; that
-     is, if there are three iteration variables, the number of words provided
-     must be a multiple of three.
-
-C\bCO\bOM\bMM\bME\bEN\bNT\bTS\bS
-     Comments begin with a hash (`#') character, anywhere but in a shell com-
-     mand line, and continue to the end of an unescaped new line.
-
-S\bSP\bPE\bEC\bCI\bIA\bAL\bL S\bSO\bOU\bUR\bRC\bCE\bES\bS (\b(A\bAT\bTT\bTR\bRI\bIB\bBU\bUT\bTE\bES\bS)\b)
-     .\b.E\bEX\bXE\bEC\bC     Target is never out of date, but always execute commands any-
-               way.
-
-     .\b.I\bIG\bGN\bNO\bOR\bRE\bE   Ignore any errors from the commands associated with this tar-
-               get, exactly as if they all were preceded by a dash (`-').
-
-     .\b.M\bMA\bAD\bDE\bE     Mark all sources of this target as being up-to-date.
-
-     .\b.M\bMA\bAK\bKE\bE     Execute the commands associated with this target even if the -\b-n\bn
-               or -\b-t\bt options were specified.  Normally used to mark recursive
-               b\bbm\bma\bak\bke\be's.
-
-     .\b.M\bME\bET\bTA\bA     Create a meta file for the target, even if it is flagged as
-               .\b.P\bPH\bHO\bON\bNY\bY, .\b.M\bMA\bAK\bKE\bE, or .\b.S\bSP\bPE\bEC\bCI\bIA\bAL\bL.  Usage in conjunction with .\b.M\bMA\bAK\bKE\bE is
-               the most likely case.  In "meta" mode, the target is out-of-
-               date if the meta file is missing.
-
-     .\b.N\bNO\bOM\bME\bET\bTA\bA   Do not create a meta file for the target.  Meta files are also
-               not created for .\b.P\bPH\bHO\bON\bNY\bY, .\b.M\bMA\bAK\bKE\bE, or .\b.S\bSP\bPE\bEC\bCI\bIA\bAL\bL targets.
-
-     .\b.N\bNO\bOM\bME\bET\bTA\bA_\b_C\bCM\bMP\bP
-               Ignore differences in commands when deciding if target is out
-               of date.  This is useful if the command contains a value which
-               always changes.  If the number of commands change, though, the
-               target will still be out of date.
-
-     .\b.N\bNO\bOP\bPA\bAT\bTH\bH   Do not search for the target in the directories specified by
-               .\b.P\bPA\bAT\bTH\bH.
-
-     .\b.N\bNO\bOT\bTM\bMA\bAI\bIN\bN  Normally b\bbm\bma\bak\bke\be selects the first target it encounters as the
-               default target to be built if no target was specified.  This
-               source prevents this target from being selected.
-
-     .\b.O\bOP\bPT\bTI\bIO\bON\bNA\bAL\bL
-               If a target is marked with this attribute and b\bbm\bma\bak\bke\be can't fig-
-               ure out how to create it, it will ignore this fact and assume
-               the file isn't needed or already exists.
-
-     .\b.P\bPH\bHO\bON\bNY\bY    The target does not correspond to an actual file; it is always
-               considered to be out of date, and will not be created with the
-               -\b-t\bt option.  Suffix-transformation rules are not applied to
-               .\b.P\bPH\bHO\bON\bNY\bY targets.
-
-     .\b.P\bPR\bRE\bEC\bCI\bIO\bOU\bUS\bS
-               When b\bbm\bma\bak\bke\be is interrupted, it normally removes any partially
-               made targets.  This source prevents the target from being
-               removed.
-
-     .\b.R\bRE\bEC\bCU\bUR\bRS\bSI\bIV\bVE\bE
-               Synonym for .\b.M\bMA\bAK\bKE\bE.
-
-     .\b.S\bSI\bIL\bLE\bEN\bNT\bT   Do not echo any of the commands associated with this target,
-               exactly as if they all were preceded by an at sign (`@').
-
-     .\b.U\bUS\bSE\bE      Turn the target into b\bbm\bma\bak\bke\be's version of a macro.  When the tar-
-               get is used as a source for another target, the other target
-               acquires the commands, sources, and attributes (except for
-               .\b.U\bUS\bSE\bE) of the source.  If the target already has commands, the
-               .\b.U\bUS\bSE\bE target's commands are appended to them.
-
-     .\b.U\bUS\bSE\bEB\bBE\bEF\bFO\bOR\bRE\bE
-               Exactly like .\b.U\bUS\bSE\bE, but prepend the .\b.U\bUS\bSE\bEB\bBE\bEF\bFO\bOR\bRE\bE target commands
-               to the target.
-
-     .\b.W\bWA\bAI\bIT\bT     If .\b.W\bWA\bAI\bIT\bT appears in a dependency line, the sources that precede
-               it are made before the sources that succeed it in the line.
-               Since the dependents of files are not made until the file
-               itself could be made, this also stops the dependents being
-               built unless they are needed for another branch of the depen-
-               dency tree.  So given:
-
-               x: a .WAIT b
-                       echo x
-               a:
-                       echo a
-               b: b1
-                       echo b
-               b1:
-                       echo b1
-
-               the output is always `a', `b1', `b', `x'.
-               The ordering imposed by .\b.W\bWA\bAI\bIT\bT is only relevant for parallel
-               makes.
-
-S\bSP\bPE\bEC\bCI\bIA\bAL\bL T\bTA\bAR\bRG\bGE\bET\bTS\bS
-     Special targets may not be included with other targets, i.e. they must be
-     the only target specified.
-
-     .\b.B\bBE\bEG\bGI\bIN\bN   Any command lines attached to this target are executed before
-              anything else is done.
-
-     .\b.D\bDE\bEF\bFA\bAU\bUL\bLT\bT
-              This is sort of a .\b.U\bUS\bSE\bE rule for any target (that was used only
-              as a source) that b\bbm\bma\bak\bke\be can't figure out any other way to cre-
-              ate.  Only the shell script is used.  The .\b.I\bIM\bMP\bPS\bSR\bRC\bC variable of a
-              target that inherits .\b.D\bDE\bEF\bFA\bAU\bUL\bLT\bT's commands is set to the target's
-              own name.
-
-     .\b.E\bEN\bND\bD     Any command lines attached to this target are executed after
-              everything else is done.
-
-     .\b.E\bER\bRR\bRO\bOR\bR   Any command lines attached to this target are executed when
-              another target fails.  The .\b.E\bER\bRR\bRO\bOR\bR_\b_T\bTA\bAR\bRG\bGE\bET\bT variable is set to the
-              target that failed.  See also M\bMA\bAK\bKE\bE_\b_P\bPR\bRI\bIN\bNT\bT_\b_V\bVA\bAR\bR_\b_O\bON\bN_\b_E\bER\bRR\bRO\bOR\bR.
-
-     .\b.I\bIG\bGN\bNO\bOR\bRE\bE  Mark each of the sources with the .\b.I\bIG\bGN\bNO\bOR\bRE\bE attribute.  If no
-              sources are specified, this is the equivalent of specifying the
-              -\b-i\bi option.
-
-     .\b.I\bIN\bNT\bTE\bER\bRR\bRU\bUP\bPT\bT
-              If b\bbm\bma\bak\bke\be is interrupted, the commands for this target will be
-              executed.
-
-     .\b.M\bMA\bAI\bIN\bN    If no target is specified when b\bbm\bma\bak\bke\be is invoked, this target
-              will be built.
-
-     .\b.M\bMA\bAK\bKE\bEF\bFL\bLA\bAG\bGS\bS
-              This target provides a way to specify flags for b\bbm\bma\bak\bke\be when the
-              makefile is used.  The flags are as if typed to the shell,
-              though the -\b-f\bf option will have no effect.
-
-     .\b.N\bNO\bOP\bPA\bAT\bTH\bH  Apply the .\b.N\bNO\bOP\bPA\bAT\bTH\bH attribute to any specified sources.
-
-     .\b.N\bNO\bOT\bTP\bPA\bAR\bRA\bAL\bLL\bLE\bEL\bL
-              Disable parallel mode.
-
-     .\b.N\bNO\bO_\b_P\bPA\bAR\bRA\bAL\bLL\bLE\bEL\bL
-              Synonym for .\b.N\bNO\bOT\bTP\bPA\bAR\bRA\bAL\bLL\bLE\bEL\bL, for compatibility with other pmake
-              variants.
-
-     .\b.O\bOR\bRD\bDE\bER\bR   The named targets are made in sequence.  This ordering does not
-              add targets to the list of targets to be made.  Since the depen-
-              dents of a target do not get built until the target itself could
-              be built, unless `a' is built by another part of the dependency
-              graph, the following is a dependency loop:
-
-              .ORDER: b a
-              b: a
-
-              The ordering imposed by .\b.O\bOR\bRD\bDE\bER\bR is only relevant for parallel
-              makes.
-
-     .\b.P\bPA\bAT\bTH\bH    The sources are directories which are to be searched for files
-              not found in the current directory.  If no sources are speci-
-              fied, any previously specified directories are deleted.  If the
-              source is the special .\b.D\bDO\bOT\bTL\bLA\bAS\bST\bT target, then the current working
-              directory is searched last.
-
-     .\b.P\bPH\bHO\bON\bNY\bY   Apply the .\b.P\bPH\bHO\bON\bNY\bY attribute to any specified sources.
-
-     .\b.P\bPR\bRE\bEC\bCI\bIO\bOU\bUS\bS
-              Apply the .\b.P\bPR\bRE\bEC\bCI\bIO\bOU\bUS\bS attribute to any specified sources.  If no
-              sources are specified, the .\b.P\bPR\bRE\bEC\bCI\bIO\bOU\bUS\bS attribute is applied to
-              every target in the file.
-
-     .\b.S\bSH\bHE\bEL\bLL\bL   Sets the shell that b\bbm\bma\bak\bke\be will use to execute commands.  The
-              sources are a set of _\bf_\bi_\be_\bl_\bd_\b=_\bv_\ba_\bl_\bu_\be pairs.
-
-              _\bn_\ba_\bm_\be        This is the minimal specification, used to select
-                          one of the builtin shell specs; _\bs_\bh, _\bk_\bs_\bh, and _\bc_\bs_\bh.
-
-              _\bp_\ba_\bt_\bh        Specifies the path to the shell.
-
-              _\bh_\ba_\bs_\bE_\br_\br_\bC_\bt_\bl   Indicates whether the shell supports exit on error.
-
-              _\bc_\bh_\be_\bc_\bk       The command to turn on error checking.
-
-              _\bi_\bg_\bn_\bo_\br_\be      The command to disable error checking.
-
-              _\be_\bc_\bh_\bo        The command to turn on echoing of commands executed.
-
-              _\bq_\bu_\bi_\be_\bt       The command to turn off echoing of commands exe-
-                          cuted.
-
-              _\bf_\bi_\bl_\bt_\be_\br      The output to filter after issuing the _\bq_\bu_\bi_\be_\bt com-
-                          mand.  It is typically identical to _\bq_\bu_\bi_\be_\bt.
-
-              _\be_\br_\br_\bF_\bl_\ba_\bg     The flag to pass the shell to enable error checking.
-
-              _\be_\bc_\bh_\bo_\bF_\bl_\ba_\bg    The flag to pass the shell to enable command echo-
-                          ing.
-
-              _\bn_\be_\bw_\bl_\bi_\bn_\be     The string literal to pass the shell that results in
-                          a single newline character when used outside of any
-                          quoting characters.
-              Example:
-
-              .SHELL: name=ksh path=/bin/ksh hasErrCtl=true \
-                      check="set -e" ignore="set +e" \
-                      echo="set -v" quiet="set +v" filter="set +v" \
-                      echoFlag=v errFlag=e newline="'\n'"
-
-     .\b.S\bSI\bIL\bLE\bEN\bNT\bT  Apply the .\b.S\bSI\bIL\bLE\bEN\bNT\bT attribute to any specified sources.  If no
-              sources are specified, the .\b.S\bSI\bIL\bLE\bEN\bNT\bT attribute is applied to every
-              command in the file.
-
-     .\b.S\bSU\bUF\bFF\bFI\bIX\bXE\bES\bS
-              Each source specifies a suffix to b\bbm\bma\bak\bke\be.  If no sources are
-              specified, any previously specified suffixes are deleted.  It
-              allows the creation of suffix-transformation rules.
-
-              Example:
-
-              .SUFFIXES: .o
-              .c.o:
-                      cc -o ${.TARGET} -c ${.IMPSRC}
-
-E\bEN\bNV\bVI\bIR\bRO\bON\bNM\bME\bEN\bNT\bT
-     b\bbm\bma\bak\bke\be uses the following environment variables, if they exist: MACHINE,
-     MACHINE_ARCH, MAKE, MAKEFLAGS, MAKEOBJDIR, MAKEOBJDIRPREFIX, MAKESYSPATH,
-     PWD, and TMPDIR.
-
-     MAKEOBJDIRPREFIX and MAKEOBJDIR may only be set in the environment or on
-     the command line to b\bbm\bma\bak\bke\be and not as makefile variables; see the descrip-
-     tion of `_\b._\bO_\bB_\bJ_\bD_\bI_\bR' for more details.
-
-F\bFI\bIL\bLE\bES\bS
-     .depend        list of dependencies
-     Makefile       list of dependencies
-     makefile       list of dependencies
-     sys.mk         system makefile
-     /usr/share/mk  system makefile directory
-
-C\bCO\bOM\bMP\bPA\bAT\bTI\bIB\bBI\bIL\bLI\bIT\bTY\bY
-     The basic make syntax is compatible between different versions of make,
-     however the special variables, variable modifiers and conditionals are
-     not.
-
-     The way that parallel makes are scheduled changed in NetBSD 4.0 so that
-     .ORDER and .WAIT apply recursively to the dependent nodes.  The algo-
-     rithms used may change again in the future.
-
-     The way that .for loop variables are substituted changed after NetBSD 5.0
-     so that they still appear to be variable expansions.  In particular this
-     stops them being treated as syntax, and removes some obscure problems
-     using them in .if statements.
-
-     Unlike other b\bbm\bma\bak\bke\be programs, this implementation by default executes all
-     commands for a given target using a single shell invocation.  This is
-     done for both efficiency and to simplify error handling in remote command
-     invocations.  Typically this is transparent to the user, unless the tar-
-     get commands change the current working directory using ``cd'' or
-     ``chdir''.  To be compatible with Makefiles that do this, one can use -\b-B\bB
-     to disable this behavior.
-
-     In compatibility mode, each command is run in a separate process.  If the
-     command contains any shell meta characters (`#=|^(){};&<>*?[]:$`\\n') it
-     will be passed to the shell, otherwise b\bbm\bma\bak\bke\be will attempt direct execu-
-     tion.
-
-S\bSE\bEE\bE A\bAL\bLS\bSO\bO
-     mkdep(1)
-
-H\bHI\bIS\bST\bTO\bOR\bRY\bY
-     b\bbm\bma\bak\bke\be is derived from NetBSD make(1).  It uses autoconf to facilitate
-     portability to other platforms.
-
-     A make command appeared in Version 7 AT&T UNIX.  This make implementation
-     is based on Adam De Boor's pmake program which was written for Sprite at
-     Berkeley.  It was designed to be a parallel distributed make running jobs
-     on different machines using a daemon called ``customs''.
-
-B\bBU\bUG\bGS\bS
-     The make syntax is difficult to parse without actually acting of the
-     data.  For instance finding the end of a variable use should involve
-     scanning each the modifiers using the correct terminator for each field.
-     In many places make just counts {} and () in order to find the end of a
-     variable expansion.
-
-MAKE(1)                 NetBSD General Commands Manual                 MAKE(1)
-
-     There is no way of escaping a space character in a filename.
-
-N\bNA\bAM\bME\bE
-     b\bbm\bma\bak\bke\be -- maintain program dependencies
-
-S\bSY\bYN\bNO\bOP\bPS\bSI\bIS\bS
-     b\bbm\bma\bak\bke\be [-\b-B\bBe\bei\bik\bkN\bNn\bnq\bqr\brs\bst\btW\bWX\bX] [-\b-C\bC _\bd_\bi_\br_\be_\bc_\bt_\bo_\br_\by] [-\b-D\bD _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be] [-\b-d\bd _\bf_\bl_\ba_\bg_\bs]
-           [-\b-f\bf _\bm_\ba_\bk_\be_\bf_\bi_\bl_\be] [-\b-I\bI _\bd_\bi_\br_\be_\bc_\bt_\bo_\br_\by] [-\b-J\bJ _\bp_\br_\bi_\bv_\ba_\bt_\be] [-\b-j\bj _\bm_\ba_\bx_\b__\bj_\bo_\bb_\bs]
-           [-\b-m\bm _\bd_\bi_\br_\be_\bc_\bt_\bo_\br_\by] [-\b-T\bT _\bf_\bi_\bl_\be] [-\b-V\bV _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be] [_\bv_\ba_\br_\bi_\ba_\bb_\bl_\be_\b=_\bv_\ba_\bl_\bu_\be]
-           [_\bt_\ba_\br_\bg_\be_\bt _\b._\b._\b.]
-
-D\bDE\bES\bSC\bCR\bRI\bIP\bPT\bTI\bIO\bON\bN
-     b\bbm\bma\bak\bke\be is a program designed to simplify the maintenance of other pro-
-     grams.  Its input is a list of specifications as to the files upon which
-     programs and other files depend.  If no -\b-f\bf _\bm_\ba_\bk_\be_\bf_\bi_\bl_\be makefile option is
-     given, b\bbm\bma\bak\bke\be will try to open `_\bm_\ba_\bk_\be_\bf_\bi_\bl_\be' then `_\bM_\ba_\bk_\be_\bf_\bi_\bl_\be' in order to find
-     the specifications.  If the file `_\b._\bd_\be_\bp_\be_\bn_\bd' exists, it is read (see
-     mkdep(1)).
-
-     This manual page is intended as a reference document only.  For a more
-     thorough description of b\bbm\bma\bak\bke\be and makefiles, please refer to _\bP_\bM_\ba_\bk_\be _\b- _\bA
-     _\bT_\bu_\bt_\bo_\br_\bi_\ba_\bl.
-
-     b\bbm\bma\bak\bke\be will prepend the contents of the _\bM_\bA_\bK_\bE_\bF_\bL_\bA_\bG_\bS environment variable to
-     the command line arguments before parsing them.
-
-     The options are as follows:
-
-     -\b-B\bB      Try to be backwards compatible by executing a single shell per
-             command and by executing the commands to make the sources of a
-             dependency line in sequence.
-
-     -\b-C\bC _\bd_\bi_\br_\be_\bc_\bt_\bo_\br_\by
-             Change to _\bd_\bi_\br_\be_\bc_\bt_\bo_\br_\by before reading the makefiles or doing any-
-             thing else.  If multiple -\b-C\bC options are specified, each is inter-
-             preted relative to the previous one: -\b-C\bC _\b/ -\b-C\bC _\be_\bt_\bc is equivalent to
-             -\b-C\bC _\b/_\be_\bt_\bc.
-
-     -\b-D\bD _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be
-             Define _\bv_\ba_\br_\bi_\ba_\bb_\bl_\be to be 1, in the global context.
-
-     -\b-d\bd _\b[_\b-_\b]_\bf_\bl_\ba_\bg_\bs
-             Turn on debugging, and specify which portions of b\bbm\bma\bak\bke\be are to
-             print debugging information.  Unless the flags are preceded by
-             `-' they are added to the _\bM_\bA_\bK_\bE_\bF_\bL_\bA_\bG_\bS environment variable and will
-             be processed by any child make processes.  By default, debugging
-             information is printed to standard error, but this can be changed
-             using the _\bF debugging flag.  The debugging output is always
-             unbuffered; in addition, if debugging is enabled but debugging
-             output is not directed to standard output, then the standard out-
-             put is line buffered.  _\bF_\bl_\ba_\bg_\bs is one or more of the following:
-
-             _\bA       Print all possible debugging information; equivalent to
-                     specifying all of the debugging flags.
-
-             _\ba       Print debugging information about archive searching and
-                     caching.
-
-             _\bC       Print debugging information about current working direc-
-                     tory.
-
-             _\bc       Print debugging information about conditional evaluation.
-
-             _\bd       Print debugging information about directory searching and
-                     caching.
-
-             _\be       Print debugging information about failed commands and
-                     targets.
-
-             _\bF[+\b+]_\bf_\bi_\bl_\be_\bn_\ba_\bm_\be
-                     Specify where debugging output is written.  This must be
-                     the last flag, because it consumes the remainder of the
-                     argument.  If the character immediately after the `F'
-                     flag is `+', then the file will be opened in append mode;
-                     otherwise the file will be overwritten.  If the file name
-                     is `stdout' or `stderr' then debugging output will be
-                     written to the standard output or standard error output
-                     file descriptors respectively (and the `+' option has no
-                     effect).  Otherwise, the output will be written to the
-                     named file.  If the file name ends `.%d' then the `%d' is
-                     replaced by the pid.
-
-             _\bf       Print debugging information about loop evaluation.
-
-             _\bg_\b1      Print the input graph before making anything.
-
-             _\bg_\b2      Print the input graph after making everything, or before
-                     exiting on error.
-
-             _\bg_\b3      Print the input graph before exiting on error.
-
-             _\bj       Print debugging information about running multiple
-                     shells.
-
-             _\bl       Print commands in Makefiles regardless of whether or not
-                     they are prefixed by `@' or other "quiet" flags.  Also
-                     known as "loud" behavior.
-
-             _\bM       Print debugging information about "meta" mode decisions
-                     about targets.
-
-             _\bm       Print debugging information about making targets, includ-
-                     ing modification dates.
-
-             _\bn       Don't delete the temporary command scripts created when
-                     running commands.  These temporary scripts are created in
-                     the directory referred to by the TMPDIR environment vari-
-                     able, or in _\b/_\bt_\bm_\bp if TMPDIR is unset or set to the empty
-                     string.  The temporary scripts are created by mkstemp(3),
-                     and have names of the form _\bm_\ba_\bk_\be_\bX_\bX_\bX_\bX_\bX_\bX.  _\bN_\bO_\bT_\bE: This can
-                     create many files in TMPDIR or _\b/_\bt_\bm_\bp, so use with care.
-
-             _\bp       Print debugging information about makefile parsing.
-
-             _\bs       Print debugging information about suffix-transformation
-                     rules.
-
-             _\bt       Print debugging information about target list mainte-
-                     nance.
-
-             _\bV       Force the -\b-V\bV option to print raw values of variables.
-
-             _\bv       Print debugging information about variable assignment.
+             _\bw       Print entering and leaving directory messages, pre and
+                     post processing.
 
              _\bx       Run shell commands with -\b-x\bx so the actual commands are
                      printed as they are executed.
@@ -1613,6 +287,32 @@ S\bSH\bHE\bEL\bLL\bL C\bCO\bOM\bMM\bMA\bAN\bND\bDS\bS
      line of a script.  A `-\b-' causes any non-zero exit status of the command
      line to be ignored.
 
+     When b\bbm\bma\bak\bke\be is run in jobs mode with -\b-j\bj _\bm_\ba_\bx_\b__\bj_\bo_\bb_\bs, the entire script for
+     the target is fed to a single instance of the shell.
+
+     In compatibility (non-jobs) mode, each command is run in a separate
+     process.  If the command contains any shell meta characters
+     (`#=|^(){};&<>*?[]:$`\\n') it will be passed to the shell, otherwise
+     b\bbm\bma\bak\bke\be will attempt direct execution.
+
+     Since b\bbm\bma\bak\bke\be will chdir(2) to `_\b._\bO_\bB_\bJ_\bD_\bI_\bR' before executing any targets, each
+     child process starts with that as its current working directory.
+
+     Makefiles should be written so that the mode of b\bbm\bma\bak\bke\be operation does not
+     change their behavior.  For example, any command which needs to use
+     ``cd'' or ``chdir'', without side-effect should be put in parenthesis:
+
+
+           avoid-chdir-side-effects:
+                   @echo Building $@ in `pwd`
+                   @(cd ${.CURDIR} && ${.MAKE} $@)
+                   @echo Back in `pwd`
+
+           ensure-one-shell-regardless-of-mode:
+                   @echo Building $@ in `pwd`; \
+                   (cd ${.CURDIR} && ${.MAKE} $@); \
+                   echo Back in `pwd`
+
 V\bVA\bAR\bRI\bIA\bAB\bBL\bLE\bE A\bAS\bSS\bSI\bIG\bGN\bNM\bME\bEN\bNT\bTS\bS
      Variables in make are much like variables in the shell, and, by tradi-
      tion, consist of all upper-case letters.
@@ -1772,7 +472,8 @@ V\bVA\bAR\bRI\bIA\bAB\bBL\bLE\bE A\bAS\bSS\bSI\bIG\bGN\bNM\bME\bEN\bNT\bTS\bS
      _\b._\bM_\bA_\bK_\bE_\b._\bJ_\bO_\bB_\b._\bP_\bR_\bE_\bF_\bI_\bX
                      If b\bbm\bma\bak\bke\be is run with _\bj then output for each target is
                      prefixed with a token `--- target ---' the first part of
-                     which can be controlled via _\b._\bM_\bA_\bK_\bE_\b._\bJ_\bO_\bB_\b._\bP_\bR_\bE_\bF_\bI_\bX.
+                     which can be controlled via _\b._\bM_\bA_\bK_\bE_\b._\bJ_\bO_\bB_\b._\bP_\bR_\bE_\bF_\bI_\bX.  If
+                     _\b._\bM_\bA_\bK_\bE_\b._\bJ_\bO_\bB_\b._\bP_\bR_\bE_\bF_\bI_\bX is empty, no token is printed.
                      For example:
                      .MAKE.JOB.PREFIX=${.newline}---${.MAKE:T}[${.MAKE.PID}]
                      would produce tokens like `---make[1234] target ---' mak-
@@ -1854,6 +555,12 @@ V\bVA\bAR\bRI\bIA\bAB\bBL\bLE\bE A\bAS\bSS\bSI\bIG\bGN\bNM\bME\bEN\bNT\bTS\bS
                      to process the meta files to extract dependency informa-
                      tion.
 
+     _\b._\bM_\bA_\bK_\bE_\b._\bM_\bE_\bT_\bA_\b._\bI_\bG_\bN_\bO_\bR_\bE_\b__\bP_\bA_\bT_\bH_\bS
+                     Provides a list of path prefixes that should be ignored;
+                     because the contents are expected to change over time.
+                     The default list includes: `_\b/_\bd_\be_\bv _\b/_\be_\bt_\bc _\b/_\bp_\br_\bo_\bc _\b/_\bt_\bm_\bp _\b/_\bv_\ba_\br_\b/_\br_\bu_\bn
+                     _\b/_\bv_\ba_\br_\b/_\bt_\bm_\bp'
+
      _\b._\bM_\bA_\bK_\bE_\b._\bM_\bE_\bT_\bA_\b._\bP_\bR_\bE_\bF_\bI_\bX
                      Defines the message printed for each meta file updated in
                      "meta verbose" mode.  The default value is:
@@ -1868,6 +575,11 @@ V\bVA\bAR\bRI\bIA\bAB\bBL\bLE\bE A\bAS\bSS\bSI\bIG\bGN\bNM\bME\bEN\bNT\bTS\bS
                      `MAKEFLAGS' is re-exported whenever `_\b._\bM_\bA_\bK_\bE_\bO_\bV_\bE_\bR_\bR_\bI_\bD_\bE_\bS' is
                      modified.
 
+     _\b._\bM_\bA_\bK_\bE_\b._\bP_\bA_\bT_\bH_\b__\bF_\bI_\bL_\bE_\bM_\bO_\bN
+                     If b\bbm\bma\bak\bke\be was built with filemon(4) support, this is set
+                     to the path of the device node.  This allows makefiles to
+                     test for this support.
+
      _\b._\bM_\bA_\bK_\bE_\b._\bP_\bI_\bD       The process-id of b\bbm\bma\bak\bke\be.
 
      _\b._\bM_\bA_\bK_\bE_\b._\bP_\bP_\bI_\bD      The parent process-id of b\bbm\bma\bak\bke\be.
@@ -2116,7 +828,7 @@ V\bVA\bAR\bRI\bIA\bAB\bBL\bLE\bE A\bAS\bSS\bSI\bIG\bGN\bNM\bME\bEN\bNT\bTS\bS
           period.  For example.
                 ${LINKS:@.LINK.@${LN} ${TARGET} ${.LINK.}@}
 
-          However a single character varaiable is often more readable:
+          However a single character variable is often more readable:
                 ${MAKE_PRINT_VAR_ON_ERROR:@v@$v='${$v}'${.newline}@}
 
      :\b:U\bU_\bn_\be_\bw_\bv_\ba_\bl
@@ -2409,7 +1121,19 @@ S\bSP\bPE\bEC\bCI\bIA\bAL\bL S\bSO\bOU\bUR\bRC\bCE\bES\bS (\b(A\bAT\bTT\bTR\bRI\bIB\bBU\bUT\bTE\bES\bS)\b)
                Ignore differences in commands when deciding if target is out
                of date.  This is useful if the command contains a value which
                always changes.  If the number of commands change, though, the
-               target will still be out of date.
+               target will still be out of date.  The same effect applies to
+               any command line that uses the variable _\b._\bO_\bO_\bD_\bA_\bT_\bE, which can be
+               used for that purpose even when not otherwise needed or
+               desired:
+
+
+                     skip-compare-for-some:
+                             @echo this will be compared
+                             @echo this will not ${.OODATE:M.NOMETA_CMP}
+                             @echo this will also be compared
+
+               The :\b:M\bM pattern suppresses any expansion of the unwanted vari-
+               able.
 
      .\b.N\bNO\bOP\bPA\bAT\bTH\bH   Do not search for the target in the directories specified by
                .\b.P\bPA\bAT\bTH\bH.
@@ -2533,6 +1257,10 @@ S\bSP\bPE\bEC\bCI\bIA\bAL\bL T\bTA\bAR\bRG\bGE\bET\bTS\bS
               source is the special .\b.D\bDO\bOT\bTL\bLA\bAS\bST\bT target, then the current working
               directory is searched last.
 
+     .\b.P\bPA\bAT\bTH\bH.\b._\bs_\bu_\bf_\bf_\bi_\bx
+              Like .\b.P\bPA\bAT\bTH\bH but applies only to files with a particular suffix.
+              The suffix must have been previously declared with .\b.S\bSU\bUF\bFF\bFI\bIX\bXE\bES\bS.
+
      .\b.P\bPH\bHO\bON\bNY\bY   Apply the .\b.P\bPH\bHO\bON\bNY\bY attribute to any specified sources.
 
      .\b.P\bPR\bRE\bEC\bCI\bIO\bOU\bUS\bS
@@ -2581,6 +1309,9 @@ S\bSP\bPE\bEC\bCI\bIA\bAL\bL T\bTA\bAR\bRG\bGE\bET\bTS\bS
               sources are specified, the .\b.S\bSI\bIL\bLE\bEN\bNT\bT attribute is applied to every
               command in the file.
 
+     .\b.S\bST\bTA\bAL\bLE\bE   This target gets run when a dependency file contains stale
+              entries, having _\b._\bA_\bL_\bL_\bS_\bR_\bC set to the name of that dependency file.
+
      .\b.S\bSU\bUF\bFF\bFI\bIX\bXE\bES\bS
               Each source specifies a suffix to b\bbm\bma\bak\bke\be.  If no sources are
               specified, any previously specified suffixes are deleted.  It
@@ -2622,19 +1353,6 @@ C\bCO\bOM\bMP\bPA\bAT\bTI\bIB\bBI\bIL\bLI\bIT\bTY\bY
      stops them being treated as syntax, and removes some obscure problems
      using them in .if statements.
 
-     Unlike other b\bbm\bma\bak\bke\be programs, this implementation by default executes all
-     commands for a given target using a single shell invocation.  This is
-     done for both efficiency and to simplify error handling in remote command
-     invocations.  Typically this is transparent to the user, unless the tar-
-     get commands change the current working directory using ``cd'' or
-     ``chdir''.  To be compatible with Makefiles that do this, one can use -\b-B\bB
-     to disable this behavior.
-
-     In compatibility mode, each command is run in a separate process.  If the
-     command contains any shell meta characters (`#=|^(){};&<>*?[]:$`\\n') it
-     will be passed to the shell, otherwise b\bbm\bma\bak\bke\be will attempt direct execu-
-     tion.
-
 S\bSE\bEE\bE A\bAL\bLS\bSO\bO
      mkdep(1)
 
@@ -2647,6 +1365,10 @@ H\bHI\bIS\bST\bTO\bOR\bRY\bY
      Berkeley.  It was designed to be a parallel distributed make running jobs
      on different machines using a daemon called ``customs''.
 
+     Historically the target/dependency ``FRC'' has been used to FoRCe
+     rebuilding (since the target/dependency does not exist... unless someone
+     creates an ``FRC'' file).
+
 B\bBU\bUG\bGS\bS
      The make syntax is difficult to parse without actually acting of the
      data.  For instance finding the end of a variable use should involve
@@ -2656,4 +1378,4 @@ B\bBU\bUG\bGS\bS
 
      There is no way of escaping a space character in a filename.
 
-NetBSD 5.1                      October 8, 2012                     NetBSD 5.1
+NetBSD 5.1                      August 11, 2013                     NetBSD 5.1
index 660b766..2193926 100755 (executable)
@@ -3,23 +3,52 @@
 #      boot-strap
 #
 # SYNOPSIS:
-#      boot-strap [--"configure_arg" ... ][-s "srcdir"][-m "mksrc"]\\
-#              ["prefix" ["bmakesrc" ["mksrc"]]]
+#      boot-strap ["options"]
+#      boot-strap --prefix=/opt --install
+#      boot-strap --prefix=$HOME --install-host-target -DWITH_PROG_VERSION
+#      boot-strap ["options"] op=build
+#      boot-strap ["options"] op=install
 #
 # DESCRIPTION:
 #      This script is used to configure/build bmake it builds for
-#      each OS in a subdir to keep the src clean. 
-#      On successful completion it echos commands to put the new
-#      bmake binary into the /configs tree (if it exists)
-#      (http://www.crufty.net/FreeWare/configs.html), $prefix/bin
-#      and a suitable ~/*bin directory.
+#      each host-target in a different subdir to keep the src clean.
+#      There is no requirement for an existing make(1).
 #
+#      On successful completion if no '--install' flag is given,
+#      it echos a command to do installation.
+#
+#      The variable "op" defaults to 'all', and is affected by
+#      '--install' flag as above.
+#      Other values include:
+#
+#      configure
+#              Just run 'configure'
+#
+#      build
+#              If 'configure' has not been done, do it, then
+#              run the build script, and finally 'test'.
+#
+#      install
+#              If 'build' has not been done, do it, 'test' then
+#              install. 
+#
+#      clean
+#              attempt to clean up
+#
+#      test
+#              run the unit-tests.  Done automatically after 'build'
+#              and before 'install'.
+#
+#      The above are leveraged by a trivial makefile for the benefit
+#      of those that have './configure; make; make install' baked
+#      into them.
+#      
 #      Options:
 #
 #      -c "rc"
 #              Pick up settings from "rc".  
 #              We look for '.bmake-boot-strap.rc' before processing
-#              options.
+#              options (unless SKIP_RC is set in environment).
 #
 #      --share "share_dir"
 #              Where to put man pages and mk files.
 #
 #      --mksrc "mksrc"
 #              Indicate where the mk files can be found.
-#              Default is ./mk or ../mk, set to 'none' to force
-#              building without "mksrc" but in that case a sys.mk
-#              needs to exist in the default syspath ($share_dir/mk)
+#              Default is $Mydir/mk
+#
+#      --install
+#              If build and test work, run bmake install.
+#              BINDIR=$prefix/bin
+#              SHAREDIR=$prefix/share
+#
+#      --install-host-target
+#              As for '--install' but BINDIR=$prefix/$HOST_TARGET/bin
+#              This is useful when $prefix/ is shared by multiple
+#              machines.
+#
+#      Flags relevant when installing:
+#
+#      -DWITHOUT_INSTALL_MK
+#              Skip installing mk files.
+#              By default they will be installed to $prefix/share/mk
+#
+#      -DWITH_PROG_VERSION
+#              Install 'bmake' as 'bmake-$MAKE_VERSION'
+#              A symlink will be made as 'bmake' unless
+#              -DWITHOUT_PROG_LINK is set.
 #
 #      Possibly useful configure_args:
 #
 #      Simon J. Gerraty <sjg@crufty.net>
 
 # RCSid:
-#      $Id: boot-strap,v 1.39 2012/03/26 17:08:22 sjg Exp $
+#      $Id: boot-strap,v 1.43 2013/03/02 18:55:23 sjg Exp $
 #
 #      @(#) Copyright (c) 2001 Simon J. Gerraty
 #
@@ -85,11 +133,10 @@ case "$Mydir" in
 *) Mydir=`cd "$Mydir" && 'pwd'`;;
 esac
 
-
 Usage() {
        [ "$1" ] && echo "ERROR: $@" >&2
        echo "Usage:" >&2
-       echo "$0 [--<configure_arg> ...][-s <srcdir>][-m <mksrc>][<prefix> [[<srcdir>] [<mksrc>]]]" >&2
+       echo "$0 [--<configure_arg> ...][<prefix>][--install]" >&2
        exit 1
 }
 
@@ -110,28 +157,58 @@ source_rc() {
        done
 }
 
+cmd_args="$@"
+
+# clear some things from the environment that we care about
+unset MAKEOBJDIR MAKEOBJDIRPREFIX
+
+# --install[-host-target] will set this
+INSTALL_PREFIX=
+# other things we pass to install step
+INSTALL_ARGS=
 CONFIGURE_ARGS=
 MAKESYSPATH=
 # pick a useful default prefix (for me at least ;-)
 for prefix in /opt/$HOST_TARGET "$HOME/$HOST_TARGET" /usr/pkg /usr/local ""
 do
-       [ -d "${prefix:-.}" ] && break
+       [ -d "${prefix:-.}" ] || continue
+       case "$prefix" in
+       */$HOST_TARGET)
+               p=`dirname $prefix`
+               if [ -d $p/share ]; then
+                       INSTALL_BIN=$HOST_TARGET/bin
+                       prefix=$p
+               fi
+               ;;
+       esac
+        echo "NOTE: default prefix=$prefix ${INSTALL_BIN:+INSTALL_BIN=$INSTALL_BIN}"
+       break
 done
-srcdir=
-mksrc=
+srcdir=$Mydir
+mksrc=$Mydir/mk
 objdir=
 quiet=:
 
-source_rc .bmake-boot-strap.rc . "$Mydir/.." "$HOME"
+${SKIP_RC:+:} source_rc .bmake-boot-strap.rc . "$Mydir/.." "$HOME"
 
 get_optarg() {
        expr "x$1" : "x[^=]*=\\(.*\\)"
 }
 
+here=`'pwd'`
+if [ $here = $Mydir ]; then
+   # avoid polution
+   OBJROOT=../
+fi
+
+op=all
+BMAKE=
+
 while :
 do
        case "$1" in
        --) shift; break;;
+        --help) sed -n -e "1d;/RCSid/,\$d" -e '/^#\.[a-z]/d' -e '/^#/s,^# *,,p' $0; exit 0;;
        --prefix) prefix="$2"; shift;;
        --prefix=*) prefix=`get_optarg "$1"`;;
        --src=*) srcdir=`get_optarg "$1"`;;
@@ -144,6 +221,13 @@ do
        --with-default-sys-path)
            CONFIGURE_ARGS="$1 $2"
            MAKESYSPATH="$2"; shift;;
+       --install) INSTALL_PREFIX=${INSTALL_PREFIX:-$prefix};;
+       --install-host-target)
+                INSTALL_PREFIX=${INSTALL_PREFIX:-$prefix}
+                INSTALL_BIN=$HOST_TARGET/bin;;
+       --install-destdir=*) INSTALL_DESTDIR=`get_optarg "$1"`;;
+       --install-prefix=*) INSTALL_PREFIX=`get_optarg "$1"`;;
+       -DWITH*) INSTALL_ARGS="$INSTALL_ARGS $1";;
        -s|--src) srcdir="$2"; shift;;
        -m|--mksrc) mksrc="$2"; shift;;
        -o|--objdir) objdir="$2"; shift;;
@@ -261,7 +345,7 @@ none|-) # we don't want it
 esac
 
 # Ok, get to work...
-objdir="${objdir:-$OS}"
+objdir="${objdir:-$OBJROOT$HOST_TARGET}"
 [ -d "$objdir" ] || mkdir -p "$objdir"
 [ -d "$objdir" ] || mkdir "$objdir"
 cd "$objdir" || exit 1
@@ -301,88 +385,80 @@ if [ "$mksrc" ]; then
         export CFLAGS_MF CFLAGS_MD
 fi
 
-$srcdir/configure $CONFIGURE_ARGS || exit 1
-chmod 755 make-bootstrap.sh || exit 1
-./make-bootstrap.sh || exit 1
-if [ -z "$MAKESYSPATH" ]; then
-       add_path "${share_dir:-...}/mk" MAKESYSPATH
-       case "$HOST_TARGET" in
-       netbsd*) add_path /usr/share/mk MAKESYSPATH;;
-       esac
-fi
-if [ -s "${mksrc:-/dev/null}/install-mk" ]; then
-        sh "${mksrc}/install-mk" "$objdir/mk"
-        case "$MAKESYSPATH" in
-        .../mk*) ;;
-        *) MAKESYSPATH=".../mk:${MAKESYSPATH}";;
-        esac
-fi
+# this makes it easy to run the bmake we just built
+# the :tA dance is needed because 'pwd' and even /bin/pwd
+# may not give the same result as realpath().
+Bmake() {
+    (
+           cd $Mydir &&
+           MAKESYSPATH=$mksrc SRCTOP=$Mydir OBJTOP=$objdir \
+           MAKEOBJDIR='${.CURDIR:S,${SRCTOP:tA},${OBJTOP:tA},}' \
+           ${BMAKE:-$objdir/bmake} -f $Mydir/Makefile "$@"
+    )
+}
+
 # make sure test below uses the same diff that configure did
 TOOL_DIFF=`type diff | sed 's,[()],,g;s,^[^/][^/]*,,;q'`
-export MAKESYSPATH TOOL_DIFF
-if [ "$mksrc" ]; then
-        $objdir/bmake test || exit 1
-else
-        # assume nothing
-        $objdir/bmake -r -m / test || exit 1
-fi
-# If -q given, we don't want all the install instructions
-$quiet exit 0
-
-make_version=`./bmake -r -m / -f ./Makefile -V MAKE_VERSION | ( read one two; echo $one )`
-bmake_version=bmake-$make_version
-
-if [ -s /usr/share/tmac/andoc.tmac ]; then
-       # this should be ok
-       man_subdir=man1
-       man_src=$srcdir/bmake.1
-else
-       # guess not
-       man_subdir=cat1
-       man_src=$srcdir/bmake.cat1
-fi
+export TOOL_DIFF
 
-install_prefix() {
-    (
-       bin_dir=
-       share_dir=
-       man_dir=
-       mk_dir=
-       while :
-       do
-               case "$1" in
-               *=*) eval "$1"; shift;;
-               *) break;;
-               esac
-       done
-       bin_dir=${bin_dir:-$1/bin}
-       share_dir=${share_dir:-`ShareDir "$1"`}
-       man_dir=${man_dir:-$share_dir/man}
-       mk_dir=${mk_dir:-$share_dir/mk}
-       echo
-       echo Commands to install into $1/
-       echo
-       echo mkdir -p $bin_dir
-       echo cp $objdir/bmake $bin_dir/$bmake_version
-       echo rm -f $bin_dir/bmake
-       echo ln -s $bmake_version $bin_dir/bmake
-       echo mkdir -p $man_dir/$man_subdir
-       echo cp $man_src $man_dir/$man_subdir/bmake.1
-       if [ "$mksrc" ]; then
-               ev=`env | grep '_MK='`
-               echo $ev sh $mksrc/install-mk $mk_dir
+op_configure() {
+       $srcdir/configure $CONFIGURE_ARGS || exit 1
+}
+
+op_build() {
+       [ -s make-bootstrap.sh ] || op_configure
+       chmod 755 make-bootstrap.sh || exit 1
+       ./make-bootstrap.sh || exit 1
+       case "$op" in
+       build) op_test;;
+       esac
+}
+
+op_test() {
+       [ -x bmake ] || op_build
+       Bmake test || exit 1
+}
+
+op_clean() {
+       if [ -x bmake ]; then
+               ln bmake bmake$$
+               BMAKE=$objdir/bmake$$ Bmake clean
+               rm -f bmake$$
+       elif [ $objdir != $srcdir ]; then
+               rm -rf *
        fi
-    )
 }
 
-case "$prefix/" in
-"$HOME"/*) ;;
-*)     CONFIGS=${CONFIGS:-/configs}
-       [ -d $CONFIGS ] &&
-       install_prefix mksrc= "$CONFIGS/$OS/$OSMAJOR.X/$MACHINE_ARCH$prefix"
-       # I like to keep a copy here...
-       install_prefix share_dir="$HOME/share" "$HOME/$HOST_TARGET"
-       ;;
-esac
+op_install() {
+       op_test
+       case "$INSTALL_PREFIX,$INSTALL_BIN,$prefix" in
+       ,$HOST_TARGET/bin,*/$HOST_TARGET)
+               INSTALL_PREFIX=`dirname $prefix`
+               ;;
+       esac
+       INSTALL_PREFIX=${INSTALL_PREFIX:-$prefix}
+       Bmake install prefix=$INSTALL_PREFIX BINDIR=$INSTALL_PREFIX/${INSTALL_BIN:-bin} ${INSTALL_DESTDIR:+DESTDIR=$INSTALL_DESTDIR} $INSTALL_ARGS || exit 1
+}
+
+op_all() {
+       rm -f make-bootstrap.sh bmake *.o
+       if [ -n "$INSTALL_PREFIX" ]; then
+               op_install
+       else
+               op_test
+               MAKE_VERSION=`sed -n '/^MAKE_VERSION/ { s,.*=  *,,;p; }' $srcdir/Makefile`
+               echo You can install by running:
+               echo
+               echo $0 $cmd_args op=install
+               echo
+               echo "Use --install-prefix=/something to install somewhere other than $prefix"
+               echo "Use --install-destdir=/somewhere to set DESTDIR during install"
+               echo "Use --install-host-target to use INSTALL_BIN=$HOST_TARGET/bin"
+               echo "Use -DWITH_PROG_VERSION to install as bmake-$MAKE_VERSION"
+               echo "Use -DWITHOUT_PROG_LINK to supress bmake -> bmake-$MAKE_VERSION symlink"
+               echo "Use -DWITHOUT_INSTALL_MK to skip installing files to $prefix/share/mk"
+       fi
+}
 
-install_prefix "$prefix"
+op_$op
+exit 0
index 6cd442a..85bd2c1 100644 (file)
@@ -1,4 +1,4 @@
-# $Id: bsd.after-import.mk,v 1.9 2012/09/20 00:30:15 sjg Exp $
+# $Id: bsd.after-import.mk,v 1.11 2012/12/29 19:32:25 sjg Exp $
 
 # This makefile is for use when integrating bmake into a BSD build
 # system.  Use this makefile after importing bmake.
@@ -48,36 +48,36 @@ DEFAULT_SYS_PATH= .../share/mk:/usr/share/mk
 BOOTSTRAP_ARGS = \
        --with-default-sys-path='${DEFAULT_SYS_PATH}' \
        --prefix /usr \
-       --share /usr/share \
-       --mksrc none
+       --share /usr/share
+
 
 # run boot-strap with minimal influence
 bootstrap:     ${BMAKE_SRC}/boot-strap ${MAKEFILE}
-       HOME=/ ${BMAKE_SRC}/boot-strap ${BOOTSTRAP_ARGS} ${BOOTSTRAP_XTRAS}
+       HOME=/ ${BMAKE_SRC}/boot-strap -o ${HOST_OS} ${BOOTSTRAP_ARGS} ${BOOTSTRAP_XTRAS}
        touch ${.TARGET}
 
 # Makefiles need a little more tweaking than say config.h
 MAKEFILE_SED =         sed -e '/^MACHINE/d' \
        -e '/^PROG/ { s,=,?=,;s,bmake,$${.CURDIR:T},; }' \
        -e 's,^.-include,.sinclude,' \
+       -e '/^\..*include  *</ { s,<,<bsd.,;/autoconf/d; }' \
        -e 's,${SRCTOP},$${SRCTOP},g'
 
 # These are the simple files we want to capture
-configured_files= config.h unit-tests/Makefile
+configured_files= config.h Makefile.config unit-tests/Makefile
 
 after-import: bootstrap ${MAKEFILE}
-.for f in ${configured_files:N*Makefile}
+.for f in ${configured_files:M*.[ch]}
        @echo Capturing $f
        @mkdir -p ${${.CURDIR}/$f:L:H}
-       @cmp -s ${.CURDIR}/$f ${HOST_OS}/$f || \
-           cp ${HOST_OS}/$f ${.CURDIR}/$f
+       @(echo '/* $$${HOST_OS}$$ */'; cat ${HOST_OS}/$f) > ${.CURDIR}/$f
 .endfor
-.for f in ${configured_files:M*Makefile}
+.for f in ${configured_files:M*Makefile*}
        @echo Capturing $f
        @mkdir -p ${${.CURDIR}/$f:L:H}
        @(echo '# This is a generated file, do NOT edit!'; \
        echo '# See ${_this:S,${SRCTOP}/,,}'; \
-       echo '#'; echo '# $$${OS}$$'; echo; \
+       echo '#'; echo '# $$${HOST_OS}$$'; echo; \
        echo 'SRCTOP?= $${.CURDIR:${${.CURDIR}/$f:L:H:S,${SRCTOP}/,,:C,[^/]+,H,g:S,/,:,g}}'; echo; \
        ${MAKEFILE_SED} ${HOST_OS}/$f ) > ${.CURDIR}/$f
 .endfor
@@ -87,18 +87,22 @@ _makefile:  bootstrap ${MAKEFILE}
        @echo Generating ${.CURDIR}/Makefile
        @(echo '# This is a generated file, do NOT edit!'; \
        echo '# See ${_this:S,${SRCTOP}/,,}'; \
-       echo '#'; echo '# $$${OS}$$'; \
+       echo '#'; echo '# $$${HOST_OS}$$'; \
        echo; echo '.sinclude "Makefile.inc"'; \
        echo; echo 'SRCTOP?= $${.CURDIR:${.CURDIR:S,${SRCTOP}/,,:C,[^/]+,H,g:S,/,:,g}}'; \
        echo; echo '# look here first for config.h'; \
        echo 'CFLAGS+= -I$${.CURDIR}'; echo; \
-       ${MAKEFILE_SED} ${HOST_OS}/Makefile; \
+       echo '# for after-import'; \
+       echo 'CLEANDIRS+= ${HOST_OS}'; \
+       echo 'CLEANFILES+= bootstrap'; echo; \
+       ${MAKEFILE_SED} \
+       ${1 2:L:@n@-e '/start-delete$n/,/end-delete$n/d'@} \
+       ${BMAKE_SRC}/Makefile; \
        echo; echo '# override some simple things'; \
        echo 'BINDIR= /usr/bin'; \
        echo 'MANDIR= ${MANDIR:U/usr/share/man}'; \
        echo; echo '# make sure we get this'; \
        echo 'CFLAGS+= $${COPTS.$${.IMPSRC:T}}'; \
-       echo 'CLEANFILES+= bootstrap'; \
        echo; echo 'after-import: ${_this:S,${SRCTOP},\${SRCTOP},}'; \
        echo '  cd $${.CURDIR} && $${.MAKE} -f ${_this:S,${SRCTOP},\${SRCTOP},}'; \
        echo ) > ${.TARGET}
index 4cc699e..b0bbc93 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: compat.c,v 1.90 2012/10/07 19:17:31 sjg Exp $  */
+/*     $NetBSD: compat.c,v 1.93 2013/09/02 19:26:42 sjg Exp $  */
 
 /*
  * Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
  */
 
 #ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: compat.c,v 1.90 2012/10/07 19:17:31 sjg Exp $";
+static char rcsid[] = "$NetBSD: compat.c,v 1.93 2013/09/02 19:26:42 sjg Exp $";
 #else
 #include <sys/cdefs.h>
 #ifndef lint
 #if 0
 static char sccsid[] = "@(#)compat.c   8.2 (Berkeley) 3/19/94";
 #else
-__RCSID("$NetBSD: compat.c,v 1.90 2012/10/07 19:17:31 sjg Exp $");
+__RCSID("$NetBSD: compat.c,v 1.93 2013/09/02 19:26:42 sjg Exp $");
 #endif
 #endif /* not lint */
 #endif
@@ -332,18 +332,23 @@ again:
         * We need to pass the command off to the shell, typically
         * because the command contains a "meta" character.
         */
-       static const char *shargv[4];
+       static const char *shargv[5];
+       int shargc;
 
-       shargv[0] = shellPath;
+       shargc = 0;
+       shargv[shargc++] = shellPath;
        /*
         * The following work for any of the builtin shell specs.
         */
+       if (errCheck && shellErrFlag) {
+           shargv[shargc++] = shellErrFlag;
+       }
        if (DEBUG(SHELL))
-               shargv[1] = "-xc";
+               shargv[shargc++] = "-xc";
        else
-               shargv[1] = "-c";
-       shargv[2] = cmd;
-       shargv[3] = NULL;
+               shargv[shargc++] = "-c";
+       shargv[shargc++] = cmd;
+       shargv[shargc++] = NULL;
        av = shargv;
        argc = 0;
        bp = NULL;
@@ -377,7 +382,6 @@ again:
        Fatal("Could not fork");
     }
     if (cpid == 0) {
-       Check_Cwd(av);
        Var_ExportVars();
 #ifdef USE_META
        if (useMeta) {
index 6d0b965..a1c6705 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: cond.c,v 1.64 2012/06/12 19:21:50 joerg Exp $  */
+/*     $NetBSD: cond.c,v 1.67 2012/11/03 13:59:27 christos Exp $       */
 
 /*
  * Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
  */
 
 #ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: cond.c,v 1.64 2012/06/12 19:21:50 joerg Exp $";
+static char rcsid[] = "$NetBSD: cond.c,v 1.67 2012/11/03 13:59:27 christos Exp $";
 #else
 #include <sys/cdefs.h>
 #ifndef lint
 #if 0
 static char sccsid[] = "@(#)cond.c     8.2 (Berkeley) 1/2/94";
 #else
-__RCSID("$NetBSD: cond.c,v 1.64 2012/06/12 19:21:50 joerg Exp $");
+__RCSID("$NetBSD: cond.c,v 1.67 2012/11/03 13:59:27 christos Exp $");
 #endif
 #endif /* not lint */
 #endif
@@ -1227,7 +1227,8 @@ do_Cond_EvalExpression(Boolean *value)
 int
 Cond_Eval(char *line)
 {
-    #define        MAXIF      128      /* maximum depth of .if'ing */
+#define            MAXIF      128      /* maximum depth of .if'ing */
+#define            MAXIF_BUMP  32      /* how much to grow by */
     enum if_states {
        IF_ACTIVE,              /* .if or .elif part active */
        ELSE_ACTIVE,            /* .else part active */
@@ -1235,7 +1236,8 @@ Cond_Eval(char *line)
        SKIP_TO_ELSE,           /* has been true, but not seen '.else' */
        SKIP_TO_ENDIF           /* nothing else to execute */
     };
-    static enum if_states cond_state[MAXIF + 1] = { IF_ACTIVE };
+    static enum if_states *cond_state = NULL;
+    static unsigned int max_if_depth = MAXIF;
 
     const struct If *ifp;
     Boolean        isElif;
@@ -1244,7 +1246,10 @@ Cond_Eval(char *line)
     enum if_states  state;
 
     level = PARSE_FATAL;
-
+    if (!cond_state) {
+       cond_state = bmake_malloc(max_if_depth * sizeof(*cond_state));
+       cond_state[0] = IF_ACTIVE;
+    }
     /* skip leading character (the '.') and any whitespace */
     for (line++; *line == ' ' || *line == '\t'; line++)
        continue;
@@ -1261,8 +1266,6 @@ Cond_Eval(char *line)
            }
            /* Return state for previous conditional */
            cond_depth--;
-           if (cond_depth > MAXIF)
-               return COND_SKIP;
            return cond_state[cond_depth] <= ELSE_ACTIVE ? COND_PARSE : COND_SKIP;
        }
 
@@ -1275,8 +1278,6 @@ Cond_Eval(char *line)
                return COND_PARSE;
            }
 
-           if (cond_depth > MAXIF)
-               return COND_SKIP;
            state = cond_state[cond_depth];
            switch (state) {
            case SEARCH_FOR_ELIF:
@@ -1325,9 +1326,6 @@ Cond_Eval(char *line)
            Parse_Error(level, "if-less elif");
            return COND_PARSE;
        }
-       if (cond_depth > MAXIF)
-           /* Error reported when we saw the .if ... */
-           return COND_SKIP;
        state = cond_state[cond_depth];
        if (state == SKIP_TO_ENDIF || state == ELSE_ACTIVE) {
            Parse_Error(PARSE_WARNING, "extra elif");
@@ -1341,10 +1339,15 @@ Cond_Eval(char *line)
        }
     } else {
        /* Normal .if */
-       if (cond_depth >= MAXIF) {
-           cond_depth++;
-           Parse_Error(PARSE_FATAL, "Too many nested if's. %d max.", MAXIF);
-           return COND_SKIP;
+       if (cond_depth + 1 >= max_if_depth) {
+           /*
+            * This is rare, but not impossible.
+            * In meta mode, dirdeps.mk (only runs at level 0)
+            * can need more than the default.
+            */
+           max_if_depth += MAXIF_BUMP;
+           cond_state = bmake_realloc(cond_state, max_if_depth *
+               sizeof(*cond_state));
        }
        state = cond_state[cond_depth];
        cond_depth++;
index ee479f1..7accf1a 100755 (executable)
@@ -1,6 +1,6 @@
 #! /bin/sh
 # Guess values for system-dependent variables and create Makefiles.
-# Generated by GNU Autoconf 2.64 for bmake 20120620.
+# Generated by GNU Autoconf 2.64 for bmake 20130706.
 #
 # Report bugs to <sjg@NetBSD.org>.
 #
@@ -549,8 +549,8 @@ MAKEFLAGS=
 # Identity of this package.
 PACKAGE_NAME='bmake'
 PACKAGE_TARNAME='bmake'
-PACKAGE_VERSION='20120620'
-PACKAGE_STRING='bmake 20120620'
+PACKAGE_VERSION='20130706'
+PACKAGE_STRING='bmake 20130706'
 PACKAGE_BUGREPORT='sjg@NetBSD.org'
 PACKAGE_URL=''
 
@@ -1220,7 +1220,7 @@ if test "$ac_init_help" = "long"; then
   # Omit some internal or obsolete options to make the list less imposing.
   # This message is too long to be a string in the A/UX 3.1 sh.
   cat <<_ACEOF
-\`configure' configures bmake 20120620 to adapt to many kinds of systems.
+\`configure' configures bmake 20130706 to adapt to many kinds of systems.
 
 Usage: $0 [OPTION]... [VAR=VALUE]...
 
@@ -1281,7 +1281,7 @@ fi
 
 if test -n "$ac_init_help"; then
   case $ac_init_help in
-     short | recursive ) echo "Configuration of bmake 20120620:";;
+     short | recursive ) echo "Configuration of bmake 20130706:";;
    esac
   cat <<\_ACEOF
 
@@ -1386,7 +1386,7 @@ fi
 test -n "$ac_init_help" && exit $ac_status
 if $ac_init_version; then
   cat <<\_ACEOF
-bmake configure 20120620
+bmake configure 20130706
 generated by GNU Autoconf 2.64
 
 Copyright (C) 2009 Free Software Foundation, Inc.
@@ -1907,7 +1907,7 @@ cat >config.log <<_ACEOF
 This file contains any messages produced by compilers while
 running configure, to aid debugging if configure makes a mistake.
 
-It was created by bmake $as_me 20120620, which was
+It was created by bmake $as_me 20130706, which was
 generated by GNU Autoconf 2.64.  Invocation command line was
 
   $ $0 $@
@@ -2257,6 +2257,11 @@ ac_compiler_gnu=$ac_cv_c_compiler_gnu
 ac_config_headers="$ac_config_headers config.h"
 
 
+case "$srcdir" in
+/*) ;;
+*) srcdir=`cd $srcdir && pwd`;;
+esac
+
 
 # Check whether --with-defshell was given.
 if test "${with_defshell+set}" = set; then :
@@ -4240,13 +4245,6 @@ test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}'
 test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644'
 
 
-echo $ECHO_N "checking if sh will pass .MAKE. variables... $ECHO_C" >&6
-ok=`env .MAKE.LEVEL=1 /bin/sh -c env | grep LEVEL=`
-case "$ok" in
-"") echo no >&6; CPPFLAGS="${CPPFLAGS} -DNEED_MAKE_LEVEL_SAFE";;
-*) echo yes >&6;;
-esac
-
 
 { $as_echo "$as_me:${as_lineno-$LINENO}: checking for ANSI C header files" >&5
 $as_echo_n "checking for ANSI C header files... " >&6; }
@@ -5861,7 +5859,7 @@ fi
 
 
 
-ac_config_files="$ac_config_files Makefile make-bootstrap.sh unit-tests/Makefile"
+ac_config_files="$ac_config_files makefile Makefile.config make-bootstrap.sh unit-tests/Makefile"
 
 cat >confcache <<\_ACEOF
 # This file is a shell script that caches the results of configure
@@ -6369,7 +6367,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1
 # report actual input values of CONFIG_FILES etc. instead of their
 # values after options handling.
 ac_log="
-This file was extended by bmake $as_me 20120620, which was
+This file was extended by bmake $as_me 20130706, which was
 generated by GNU Autoconf 2.64.  Invocation command line was
 
   CONFIG_FILES    = $CONFIG_FILES
@@ -6429,7 +6427,7 @@ Report bugs to <sjg@NetBSD.org>."
 _ACEOF
 cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
 ac_cs_version="\\
-bmake config.status 20120620
+bmake config.status 20130706
 configured by $0, generated by GNU Autoconf 2.64,
   with options \\"`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`\\"
 
@@ -6544,7 +6542,8 @@ for ac_config_target in $ac_config_targets
 do
   case $ac_config_target in
     "config.h") CONFIG_HEADERS="$CONFIG_HEADERS config.h" ;;
-    "Makefile") CONFIG_FILES="$CONFIG_FILES Makefile" ;;
+    "makefile") CONFIG_FILES="$CONFIG_FILES makefile" ;;
+    "Makefile.config") CONFIG_FILES="$CONFIG_FILES Makefile.config" ;;
     "make-bootstrap.sh") CONFIG_FILES="$CONFIG_FILES make-bootstrap.sh" ;;
     "unit-tests/Makefile") CONFIG_FILES="$CONFIG_FILES unit-tests/Makefile" ;;
 
index 156034b..ac2cc2e 100644 (file)
@@ -1,12 +1,18 @@
 dnl
 dnl RCSid:
-dnl    $Id: configure.in,v 1.45 2012/06/20 22:43:41 sjg Exp $
+dnl    $Id: configure.in,v 1.49 2013/07/06 18:25:19 sjg Exp $
 dnl
 dnl Process this file with autoconf to produce a configure script
 dnl
-AC_INIT([bmake], [20120620], [sjg@NetBSD.org])
+AC_INIT([bmake], [20130706], [sjg@NetBSD.org])
 AC_CONFIG_HEADER(config.h)
 
+dnl make srcdir absolute
+case "$srcdir" in
+/*) ;;
+*) srcdir=`cd $srcdir && pwd`;;
+esac
+
 dnl
 AC_ARG_WITH(defshell,
 [  --with-defshell=SHELL  use SHELL by default - must be sh compatible, use sh or ksh to pick the internal definitions],
@@ -72,15 +78,6 @@ AC_PROG_INSTALL
 dnl Executable suffix - normally empty; .exe on os2.
 AC_SUBST(ac_exe_suffix)dnl
 
-dnl
-dnl Check if /bin/sh will pass .MAKE.LEVEL
-echo $ECHO_N "checking if sh will pass .MAKE. variables... $ECHO_C" >&6
-ok=`env .MAKE.LEVEL=1 /bin/sh -c env | grep LEVEL=`
-case "$ok" in
-"") echo no >&6; CPPFLAGS="${CPPFLAGS} -DNEED_MAKE_LEVEL_SAFE";;
-*) echo yes >&6;;
-esac
-
 dnl
 dnl AC_C_CROSS
 dnl
@@ -357,7 +354,7 @@ AC_SUBST(GCC)
 AC_SUBST(diff_u)
 AC_SUBST(use_meta)
 AC_SUBST(filemon_h)
-AC_OUTPUT(Makefile make-bootstrap.sh unit-tests/Makefile)
+AC_OUTPUT(makefile Makefile.config make-bootstrap.sh unit-tests/Makefile)
 
 cat <<EOF
 
index 1c56ea3..7b12769 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: dir.c,v 1.65 2012/06/12 19:21:50 joerg Exp $   */
+/*     $NetBSD: dir.c,v 1.67 2013/03/05 22:01:43 christos Exp $        */
 
 /*
  * Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
  */
 
 #ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: dir.c,v 1.65 2012/06/12 19:21:50 joerg Exp $";
+static char rcsid[] = "$NetBSD: dir.c,v 1.67 2013/03/05 22:01:43 christos Exp $";
 #else
 #include <sys/cdefs.h>
 #ifndef lint
 #if 0
 static char sccsid[] = "@(#)dir.c      8.2 (Berkeley) 1/2/94";
 #else
-__RCSID("$NetBSD: dir.c,v 1.65 2012/06/12 19:21:50 joerg Exp $");
+__RCSID("$NetBSD: dir.c,v 1.67 2013/03/05 22:01:43 christos Exp $");
 #endif
 #endif /* not lint */
 #endif
@@ -145,6 +145,7 @@ __RCSID("$NetBSD: dir.c,v 1.65 2012/06/12 19:21:50 joerg Exp $");
 #include "make.h"
 #include "hash.h"
 #include "dir.h"
+#include "job.h"
 
 /*
  *     A search path consists of a Lst of Path structures. A Path structure
@@ -1463,9 +1464,11 @@ Dir_MTime(GNode *gn, Boolean recheck)
                         * so that we give that to the compiler.
                         */
                        gn->path = bmake_strdup(fullName);
-                       fprintf(stdout,
-                               "%s: ignoring stale %s for %s, found %s\n",
-                               progname, makeDependfile, gn->name, fullName);
+                       if (!Job_RunTarget(".STALE", gn->fname))
+                           fprintf(stdout,
+                               "%s: %s, %d: ignoring stale %s for %s, "
+                               "found %s\n", progname, gn->fname, gn->lineno,
+                               makeDependfile, gn->name, fullName);
                    }
                }
            }
index 99e05d5..b5dbf4c 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: job.c,v 1.163 2012/07/03 21:03:40 sjg Exp $    */
+/*     $NetBSD: job.c,v 1.176 2013/08/04 16:48:15 sjg Exp $    */
 
 /*
  * Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
  */
 
 #ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: job.c,v 1.163 2012/07/03 21:03:40 sjg Exp $";
+static char rcsid[] = "$NetBSD: job.c,v 1.176 2013/08/04 16:48:15 sjg Exp $";
 #else
 #include <sys/cdefs.h>
 #ifndef lint
 #if 0
 static char sccsid[] = "@(#)job.c      8.2 (Berkeley) 3/19/94";
 #else
-__RCSID("$NetBSD: job.c,v 1.163 2012/07/03 21:03:40 sjg Exp $");
+__RCSID("$NetBSD: job.c,v 1.176 2013/08/04 16:48:15 sjg Exp $");
 #endif
 #endif /* not lint */
 #endif
@@ -142,6 +142,7 @@ __RCSID("$NetBSD: job.c,v 1.163 2012/07/03 21:03:40 sjg Exp $");
 #include <sys/time.h>
 #include "wait.h"
 
+#include <assert.h>
 #include <errno.h>
 #include <fcntl.h>
 #if !defined(USE_SELECT) && defined(HAVE_POLL_H)
@@ -312,6 +313,7 @@ static Shell *commandShell = &shells[DEFSHELL_INDEX]; /* this is the shell to
 const char *shellPath = NULL,                    /* full pathname of
                                                   * executable image */
            *shellName = NULL;                    /* last component of shell */
+char *shellErrFlag = NULL;
 static const char *shellArgv = NULL;             /* Custom shell args */
 
 
@@ -343,7 +345,7 @@ static Job childExitJob;    /* child exit pseudo-job */
 
 #define TARG_FMT  "%s %s ---\n" /* Default format */
 #define MESSAGE(fp, gn) \
-       if (maxJobs != 1) \
+       if (maxJobs != 1 && targPrefix && *targPrefix) \
            (void)fprintf(fp, TARG_FMT, targPrefix, gn->name)
 
 static sigset_t caught_signals;        /* Set of signals we handle */
@@ -413,6 +415,15 @@ JobCreatePipe(Job *job, int minfd)
     if (pipe(job->jobPipe) == -1)
        Punt("Cannot create pipe: %s", strerror(errno));
 
+    for (i = 0; i < 2; i++) {
+       /* Avoid using low numbered fds */
+       fd = fcntl(job->jobPipe[i], F_DUPFD, minfd);
+       if (fd != -1) {
+          close(job->jobPipe[i]);
+          job->jobPipe[i] = fd;
+       }
+    }
+    
     /* Set close-on-exec flag for both */
     (void)fcntl(job->jobPipe[0], F_SETFD, 1);
     (void)fcntl(job->jobPipe[1], F_SETFD, 1);
@@ -425,15 +436,6 @@ JobCreatePipe(Job *job, int minfd)
      */
     fcntl(job->jobPipe[0], F_SETFL, 
        fcntl(job->jobPipe[0], F_GETFL, 0) | O_NONBLOCK);
-
-    for (i = 0; i < 2; i++) {
-       /* Avoid using low numbered fds */
-       fd = fcntl(job->jobPipe[i], F_DUPFD, minfd);
-       if (fd != -1) {
-          close(job->jobPipe[i]);
-          job->jobPipe[i] = fd;
-       }
-    }
 }
 
 /*-
@@ -490,7 +492,8 @@ JobCondPassSig(int signo)
 static void
 JobChildSig(int signo MAKE_ATTR_UNUSED)
 {
-    write(childExitJob.outPipe, CHILD_EXIT, 1);
+    while (write(childExitJob.outPipe, CHILD_EXIT, 1) == -1 && errno == EAGAIN)
+       continue;
 }
 
 
@@ -517,7 +520,9 @@ JobContinueSig(int signo MAKE_ATTR_UNUSED)
      * Defer sending to SIGCONT to our stopped children until we return
      * from the signal handler.
      */
-    write(childExitJob.outPipe, DO_JOB_RESUME, 1);
+    while (write(childExitJob.outPipe, DO_JOB_RESUME, 1) == -1 &&
+       errno == EAGAIN)
+       continue;
 }
 
 /*-
@@ -688,7 +693,6 @@ JobPrintCommand(void *cmdp, void *jobp)
     char         *escCmd = NULL;    /* Command with quotes/backticks escaped */
     char         *cmd = (char *)cmdp;
     Job           *job = (Job *)jobp;
-    char         *cp, *tmp;
     int           i, j;
 
     noSpecials = NoExecute(job->node);
@@ -860,11 +864,6 @@ JobPrintCommand(void *cmdp, void *jobp)
            job->flags |= JOB_TRACED;
     }
     
-    if ((cp = Check_Cwd_Cmd(cmd)) != NULL) {
-           DBPRINTF("test -d %s && ", cp);
-           DBPRINTF("cd %s\n", cp);
-    }
-
     DBPRINTF(cmdTemplate, cmd);
     free(cmdStart);
     if (escCmd)
@@ -884,10 +883,6 @@ JobPrintCommand(void *cmdp, void *jobp)
     if (shutUp && commandShell->hasEchoCtl) {
        DBPRINTF("%s\n", commandShell->echoOn);
     }
-    if (cp != NULL) {
-           DBPRINTF("test -d %s && ", cp);
-           DBPRINTF("cd %s\n", Var_Value(".OBJDIR", VAR_GLOBAL, &tmp));
-    }
     return 0;
 }
 
@@ -1185,7 +1180,8 @@ Job_Touch(GNode *gn, Boolean silent)
                 */
                if (read(streamID, &c, 1) == 1) {
                    (void)lseek(streamID, (off_t)0, SEEK_SET);
-                   (void)write(streamID, &c, 1);
+                   while (write(streamID, &c, 1) == -1 && errno == EAGAIN)
+                       continue;
                }
 
                (void)close(streamID);
@@ -1251,8 +1247,10 @@ Job_CheckCommands(GNode *gn, void (*abortProc)(const char *, ...))
            static const char msg[] = ": don't know how to make";
 
            if (gn->flags & FROM_DEPEND) {
-               fprintf(stdout, "%s: ignoring stale %s for %s\n",
-                       progname, makeDependfile, gn->name);
+               if (!Job_RunTarget(".STALE", gn->fname))
+                   fprintf(stdout, "%s: %s, %d: ignoring stale %s for %s\n",
+                       progname, gn->fname, gn->lineno, makeDependfile,
+                       gn->name);
                return TRUE;
            }
 
@@ -2069,31 +2067,45 @@ Job_CatchOutput(void)
     (void)fflush(stdout);
 
     /* The first fd in the list is the job token pipe */
-    nready = poll(fds + 1 - wantToken, nfds - 1 + wantToken, POLL_MSEC);
+    do {
+       nready = poll(fds + 1 - wantToken, nfds - 1 + wantToken, POLL_MSEC);
+    } while (nready < 0 && errno == EINTR);
+
+    if (nready < 0)
+       Punt("poll: %s", strerror(errno));
 
-    if (nready < 0 || readyfd(&childExitJob)) {
+    if (nready > 0 && readyfd(&childExitJob)) {
        char token = 0;
-       nready -= 1;
-       (void)read(childExitJob.inPipe, &token, 1);
-       if (token == DO_JOB_RESUME[0])
-           /* Complete relay requested from our SIGCONT handler */
-           JobRestartJobs();
-       Job_CatchChildren();
+       ssize_t count;
+       count = read(childExitJob.inPipe, &token, 1);
+       switch (count) {
+       case 0:
+           Punt("unexpected eof on token pipe");
+       case -1:
+           Punt("token pipe read: %s", strerror(errno));
+       case 1:
+           if (token == DO_JOB_RESUME[0])
+               /* Complete relay requested from our SIGCONT handler */
+               JobRestartJobs();
+           break;
+       default:
+           abort();
+       }
+       --nready;
     }
 
-    if (nready <= 0)
-       return;
-
-    if (wantToken && readyfd(&tokenWaitJob))
-       nready--;
+    Job_CatchChildren();
+    if (nready == 0)
+           return;
 
     for (i = 2; i < nfds; i++) {
        if (!fds[i].revents)
            continue;
        job = jobfds[i];
-       if (job->job_state != JOB_ST_RUNNING)
-           continue;
-       JobDoOutput(job, FALSE);
+       if (job->job_state == JOB_ST_RUNNING)
+           JobDoOutput(job, FALSE);
+       if (--nready == 0)
+               return;
     }
 }
 
@@ -2141,6 +2153,24 @@ Shell_Init(void)
     if (commandShell->echo == NULL) {
        commandShell->echo = "";
     }
+    if (commandShell->hasErrCtl && *commandShell->exit) {
+       if (shellErrFlag &&
+           strcmp(commandShell->exit, &shellErrFlag[1]) != 0) {
+           free(shellErrFlag);
+           shellErrFlag = NULL;
+       }
+       if (!shellErrFlag) {
+           int n = strlen(commandShell->exit) + 2;
+
+           shellErrFlag = bmake_malloc(n);
+           if (shellErrFlag) {
+               snprintf(shellErrFlag, n, "-%s", commandShell->exit);
+           }
+       }
+    } else if (shellErrFlag) {
+       free(shellErrFlag);
+       shellErrFlag = NULL;
+    }
 }
 
 /*-
@@ -2184,8 +2214,7 @@ Job_SetPrefix(void)
 void
 Job_Init(void)
 {
-    GNode         *begin;     /* node for commands to do at the very start */
-
+    Job_SetPrefix();
     /* Allocate space for all the job info */
     job_table = bmake_malloc(maxJobs * sizeof *job_table);
     memset(job_table, 0, maxJobs * sizeof *job_table);
@@ -2261,15 +2290,7 @@ Job_Init(void)
     ADDSIG(SIGCONT, JobContinueSig)
 #undef ADDSIG
 
-    begin = Targ_FindNode(".BEGIN", TARG_NOCREATE);
-
-    if (begin != NULL) {
-       JobRun(begin);
-       if (begin->made == ERROR) {
-           PrintOnError(begin, "\n\nStop.");
-           exit(1);
-       }
-    }
+    (void)Job_RunTarget(".BEGIN", NULL);
     postCommands = Targ_FindNode(".END", TARG_CREATE);
 }
 
@@ -2495,6 +2516,8 @@ Job_ParseShell(char *line)
            commandShell = bmake_malloc(sizeof(Shell));
            *commandShell = newShell;
        }
+       /* this will take care of shellErrFlag */
+       Shell_Init();
     }
 
     if (commandShell->echoOn && commandShell->echoOff) {
@@ -2805,7 +2828,8 @@ JobTokenAdd(void)
     if (DEBUG(JOB))
        fprintf(debug_file, "(%d) aborting %d, deposit token %c\n",
            getpid(), aborting, JOB_TOKENS[aborting]);
-    write(tokenWaitJob.outPipe, &tok, 1);
+    while (write(tokenWaitJob.outPipe, &tok, 1) == -1 && errno == EAGAIN)
+       continue;
 }
 
 /*-
@@ -2826,6 +2850,8 @@ Job_ServerStart(int max_tokens, int jp_0, int jp_1)
        /* Pipe passed in from parent */
        tokenWaitJob.inPipe = jp_0;
        tokenWaitJob.outPipe = jp_1;
+       (void)fcntl(jp_0, F_SETFD, 1);
+       (void)fcntl(jp_1, F_SETFD, 1);
        return;
     }
 
@@ -2918,13 +2944,15 @@ Job_TokenWithdraw(void)
        while (read(tokenWaitJob.inPipe, &tok1, 1) == 1)
            continue;
        /* And put the stopper back */
-       write(tokenWaitJob.outPipe, &tok, 1);
+       while (write(tokenWaitJob.outPipe, &tok, 1) == -1 && errno == EAGAIN)
+           continue;
        Fatal("A failure has been detected in another branch of the parallel make");
     }
 
     if (count == 1 && jobTokensRunning == 0)
        /* We didn't want the token really */
-       write(tokenWaitJob.outPipe, &tok, 1);
+       while (write(tokenWaitJob.outPipe, &tok, 1) == -1 && errno == EAGAIN)
+           continue;
 
     jobTokensRunning++;
     if (DEBUG(JOB))
@@ -2932,6 +2960,38 @@ Job_TokenWithdraw(void)
     return TRUE;
 }
 
+/*-
+ *-----------------------------------------------------------------------
+ * Job_RunTarget --
+ *     Run the named target if found. If a filename is specified, then
+ *     set that to the sources.
+ *
+ * Results:
+ *     None
+ *
+ * Side Effects:
+ *     exits if the target fails.
+ *
+ *-----------------------------------------------------------------------
+ */
+Boolean
+Job_RunTarget(const char *target, const char *fname) {
+    GNode *gn = Targ_FindNode(target, TARG_NOCREATE);
+
+    if (gn == NULL)
+       return FALSE;
+
+    if (fname)
+       Var_Set(ALLSRC, fname, gn, 0);
+
+    JobRun(gn);
+    if (gn->made == ERROR) {
+       PrintOnError(gn, "\n\nStop.");
+       exit(1);
+    }
+    return TRUE;
+}
+
 #ifdef USE_SELECT
 int
 emul_poll(struct pollfd *fd, int nfd, int timeout)
index 560b70b..91e2c87 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: job.h,v 1.40 2010/09/13 15:36:57 sjg Exp $     */
+/*     $NetBSD: job.h,v 1.42 2013/07/05 22:14:56 sjg Exp $     */
 
 /*
  * Copyright (c) 1988, 1989, 1990 The Regents of the University of California.
@@ -243,6 +243,7 @@ typedef struct Shell {
 
 extern const char *shellPath;
 extern const char *shellName;
+extern char *shellErrFlag;
 
 extern int     jobTokensRunning; /* tokens currently "out" */
 extern int     maxJobs;        /* Max jobs we can run */
@@ -268,5 +269,6 @@ void Job_TokenReturn(void);
 Boolean Job_TokenWithdraw(void);
 void Job_ServerStart(int, int, int);
 void Job_SetPrefix(void);
+Boolean Job_RunTarget(const char *, const char *);
 
 #endif /* _JOB_H_ */
index 0b177bb..7c1e64d 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: main.c,v 1.203 2012/08/31 07:00:36 sjg Exp $   */
+/*     $NetBSD: main.c,v 1.225 2013/09/14 15:09:34 matt Exp $  */
 
 /*
  * Copyright (c) 1988, 1989, 1990, 1993
@@ -69,7 +69,7 @@
  */
 
 #ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: main.c,v 1.203 2012/08/31 07:00:36 sjg Exp $";
+static char rcsid[] = "$NetBSD: main.c,v 1.225 2013/09/14 15:09:34 matt Exp $";
 #else
 #include <sys/cdefs.h>
 #ifndef lint
@@ -81,7 +81,7 @@ __COPYRIGHT("@(#) Copyright (c) 1988, 1989, 1990, 1993\
 #if 0
 static char sccsid[] = "@(#)main.c     8.3 (Berkeley) 3/19/94";
 #else
-__RCSID("$NetBSD: main.c,v 1.203 2012/08/31 07:00:36 sjg Exp $");
+__RCSID("$NetBSD: main.c,v 1.225 2013/09/14 15:09:34 matt Exp $");
 #endif
 #endif /* not lint */
 #endif
@@ -117,19 +117,21 @@ __RCSID("$NetBSD: main.c,v 1.203 2012/08/31 07:00:36 sjg Exp $");
 #include <sys/time.h>
 #include <sys/param.h>
 #include <sys/resource.h>
-#include <signal.h>
 #include <sys/stat.h>
 #ifdef MAKE_NATIVE
-#include <sys/utsname.h>
+#include <sys/sysctl.h>
 #endif
+#include <sys/utsname.h>
 #include "wait.h"
 
 #include <errno.h>
 #include <fcntl.h>
+#include <signal.h>
 #include <stdarg.h>
 #include <stdio.h>
 #include <stdlib.h>
 #include <time.h>
+#include <ctype.h>
 
 #include "make.h"
 #include "hash.h"
@@ -146,6 +148,10 @@ __RCSID("$NetBSD: main.c,v 1.203 2012/08/31 07:00:36 sjg Exp $");
 #define        DEFMAXLOCAL DEFMAXJOBS
 #endif /* DEFMAXLOCAL */
 
+#ifndef __arraycount
+# define __arraycount(__x)     (sizeof(__x) / sizeof(__x[0]))
+#endif
+
 Lst                    create;         /* Targets to be made */
 time_t                 now;            /* Time at start of make */
 GNode                  *DEFAULT;       /* .DEFAULT node */
@@ -165,6 +171,7 @@ Boolean                     noRecursiveExecute;     /* -N flag */
 Boolean                        keepgoing;      /* -k flag */
 Boolean                        queryFlag;      /* -q flag */
 Boolean                        touchFlag;      /* -t flag */
+Boolean                        enterFlag;      /* -w flag */
 Boolean                        ignoreErrors;   /* -i flag */
 Boolean                        beSilent;       /* -s flag */
 Boolean                        oldVars;        /* variable substitution style */
@@ -176,9 +183,6 @@ Boolean                     varNoExportEnv; /* -X flag */
 Boolean                        doing_depend;   /* Set while reading .depend */
 static Boolean         jobsRunning;    /* TRUE if the jobs might be running */
 static const char *    tracefile;
-#ifndef NO_CHECK_MAKE_CHDIR
-static char *          Check_Cwd_av(int, char **, int);
-#endif
 static void            MainParseArgs(int, char **);
 static int             ReadMakefile(const void *, const void *);
 static void            usage(void) MAKE_ATTR_DEAD;
@@ -189,6 +193,7 @@ char curdir[MAXPATHLEN + 1];                /* Startup directory */
 char *progname;                                /* the program name */
 char *makeDependfile;
 pid_t myPid;
+int makelevel;
 
 Boolean forceJobs = FALSE;
 
@@ -203,6 +208,38 @@ Boolean forceJobs = FALSE;
 
 extern Lst parseIncPath;
 
+/*
+ * For compatibility with the POSIX version of MAKEFLAGS that includes
+ * all the options with out -, convert flags to -f -l -a -g -s.
+ */
+static char *
+explode(const char *flags)
+{
+    size_t len;
+    char *nf, *st;
+    const char *f;
+
+    if (flags == NULL)
+       return NULL;
+
+    for (f = flags; *f; f++)
+       if (!isalpha((unsigned char)*f))
+           break;
+
+    if (*f)
+       return bmake_strdup(flags);
+
+    len = strlen(flags);
+    st = nf = bmake_malloc(len * 3 + 1);
+    while (*flags) {
+       *nf++ = '-';
+       *nf++ = *flags++;
+       *nf++ = ' ';
+    }
+    *nf = '\0';
+    return st;
+}
+           
 static void
 parse_debug_options(const char *argvalue)
 {
@@ -355,7 +392,7 @@ MainParseArgs(int argc, char **argv)
        Boolean inOption, dashDash = FALSE;
        char found_path[MAXPATHLEN + 1];        /* for searching for sys.mk */
 
-#define OPTFLAGS "BC:D:I:J:NST:V:WXd:ef:ij:km:nqrst"
+#define OPTFLAGS "BC:D:I:J:NST:V:WXd:ef:ij:km:nqrstw"
 /* Can't actually use getopt(3) because rescanning is not portable */
 
        getopt_def = OPTFLAGS;
@@ -563,6 +600,10 @@ rearg:
                        touchFlag = TRUE;
                        Var_Append(MAKEFLAGS, "-t", VAR_GLOBAL);
                        break;
+               case 'w':
+                       enterFlag = TRUE;
+                       Var_Append(MAKEFLAGS, "-w", VAR_GLOBAL);
+                       break;
                case '-':
                        dashDash = TRUE;
                        break;
@@ -771,7 +812,7 @@ MakeMode(const char *mode)
        }
 #if USE_META
        if (strstr(mode, "meta"))
-           meta_init(mode);
+           meta_mode_init(mode);
 #endif
     }
     if (mp)
@@ -801,7 +842,7 @@ main(int argc, char **argv)
        Lst targs;      /* target nodes to create -- passed to Make_Init */
        Boolean outOfDate = FALSE;      /* FALSE if all targets up to date */
        struct stat sb, sa;
-       char *p1, *path, *pwd;
+       char *p1, *path;
        char mdpath[MAXPATHLEN];
 #ifdef FORCE_MACHINE
        const char *machine = FORCE_MACHINE;
@@ -816,9 +857,7 @@ main(int argc, char **argv)
        static char defsyspath[] = _PATH_DEFSYSPATH;
        char found_path[MAXPATHLEN + 1];        /* for searching for sys.mk */
        struct timeval rightnow;                /* to initialize random seed */
-#ifdef MAKE_NATIVE
        struct utsname utsname;
-#endif
 
        /* default to writing debug to stderr */
        debug_file = stderr;
@@ -837,7 +876,7 @@ main(int argc, char **argv)
                progname++;
        else
                progname = argv[0];
-#ifdef RLIMIT_NOFILE
+#if defined(MAKE_NATIVE) || (defined(HAVE_SETRLIMIT) && defined(RLIMIT_NOFILE))
        /*
         * get rid of resource limit on file descriptors
         */
@@ -851,6 +890,12 @@ main(int argc, char **argv)
        }
 #endif
 
+       if (uname(&utsname) == -1) {
+           (void)fprintf(stderr, "%s: uname failed (%s).\n", progname,
+               strerror(errno));
+           exit(2);
+       }
+
        /*
         * Get the name of this type of MACHINE from utsname
         * so we can share an executable for similar machines.
@@ -861,11 +906,6 @@ main(int argc, char **argv)
         */
        if (!machine) {
 #ifdef MAKE_NATIVE
-           if (uname(&utsname) == -1) {
-               (void)fprintf(stderr, "%s: uname failed (%s).\n", progname,
-                   strerror(errno));
-               exit(2);
-           }
            machine = utsname.machine;
 #else
 #ifdef MAKE_MACHINE
@@ -877,6 +917,20 @@ main(int argc, char **argv)
        }
 
        if (!machine_arch) {
+#if defined(MAKE_NATIVE) && defined(CTL_HW) && defined(HW_MACHINE_ARCH)
+           static char machine_arch_buf[sizeof(utsname.machine)];
+           const int mib[2] = { CTL_HW, HW_MACHINE_ARCH };
+           size_t len = sizeof(machine_arch_buf);
+                
+           if (sysctl(mib, __arraycount(mib), machine_arch_buf,
+                   &len, NULL, 0) < 0) {
+               (void)fprintf(stderr, "%s: sysctl failed (%s).\n", progname,
+                   strerror(errno));
+               exit(2);
+           }
+
+           machine_arch = machine_arch_buf;
+#else
 #ifndef MACHINE_ARCH
 #ifdef MAKE_MACHINE_ARCH
             machine_arch = MAKE_MACHINE_ARCH;
@@ -885,6 +939,7 @@ main(int argc, char **argv)
 #endif
 #else
            machine_arch = MACHINE_ARCH;
+#endif
 #endif
        }
 
@@ -895,6 +950,7 @@ main(int argc, char **argv)
         */
        Var_Init();             /* Initialize the lists of variables for
                                 * parsing arguments */
+       Var_Set(".MAKE.OS", utsname.sysname, VAR_GLOBAL, 0);
        Var_Set("MACHINE", machine, VAR_GLOBAL, 0);
        Var_Set("MACHINE_ARCH", machine_arch, VAR_GLOBAL, 0);
 #ifdef MAKE_VERSION
@@ -968,35 +1024,43 @@ main(int argc, char **argv)
        Var_Set(MAKEOVERRIDES, "", VAR_GLOBAL, 0);
        Var_Set("MFLAGS", "", VAR_GLOBAL, 0);
        Var_Set(".ALLTARGETS", "", VAR_GLOBAL, 0);
+       /* some makefiles need to know this */
+       Var_Set(MAKE_LEVEL ".ENV", MAKE_LEVEL_ENV, VAR_CMD, 0);
 
        /*
         * Set some other useful macros
         */
        {
-           char tmp[64];
-           const char *ep;
+           char tmp[64], *ep;
 
-           if (!(ep = getenv(MAKE_LEVEL))) {
-#ifdef MAKE_LEVEL_SAFE
-               if (!(ep = getenv(MAKE_LEVEL_SAFE)))
-#endif
-                   ep = "0";
-           }
-           Var_Set(MAKE_LEVEL, ep, VAR_GLOBAL, 0);
+           makelevel = ((ep = getenv(MAKE_LEVEL_ENV)) && *ep) ? atoi(ep) : 0;
+           if (makelevel < 0)
+               makelevel = 0;
+           snprintf(tmp, sizeof(tmp), "%d", makelevel);
+           Var_Set(MAKE_LEVEL, tmp, VAR_GLOBAL, 0);
            snprintf(tmp, sizeof(tmp), "%u", myPid);
            Var_Set(".MAKE.PID", tmp, VAR_GLOBAL, 0);
            snprintf(tmp, sizeof(tmp), "%u", getppid());
            Var_Set(".MAKE.PPID", tmp, VAR_GLOBAL, 0);
        }
-       Job_SetPrefix();
+       if (makelevel > 0) {
+               char pn[1024];
+               snprintf(pn, sizeof(pn), "%s[%d]", progname, makelevel);
+               progname = bmake_strdup(pn);
+       }
 
+#ifdef USE_META
+       meta_init();
+#endif
        /*
         * First snag any flags out of the MAKE environment variable.
         * (Note this is *not* MAKEFLAGS since /bin/make uses that and it's
         * in a different format).
         */
 #ifdef POSIX
-       Main_ParseArgLine(getenv("MAKEFLAGS"));
+       p1 = explode(getenv("MAKEFLAGS"));
+       Main_ParseArgLine(p1);
+       free(p1);
 #else
        Main_ParseArgLine(getenv("MAKE"));
 #endif
@@ -1013,6 +1077,9 @@ main(int argc, char **argv)
 
        MainParseArgs(argc, argv);
 
+       if (enterFlag)
+               printf("%s: Entering directory `%s'\n", progname, curdir);
+
        /*
         * Verify that cwd is sane.
         */
@@ -1034,15 +1101,19 @@ main(int argc, char **argv)
         * MAKEOBJDIRPREFIX is set or MAKEOBJDIR contains a transform.
         */
 #ifndef NO_PWD_OVERRIDE
-       if (!ignorePWD &&
-           (pwd = getenv("PWD")) != NULL &&
-           getenv("MAKEOBJDIRPREFIX") == NULL) {
-               const char *makeobjdir = getenv("MAKEOBJDIR");
-
-               if (makeobjdir == NULL || !strchr(makeobjdir, '$')) {
-                       if (stat(pwd, &sb) == 0 && sa.st_ino == sb.st_ino &&
-                           sa.st_dev == sb.st_dev)
-                               (void)strncpy(curdir, pwd, MAXPATHLEN);
+       if (!ignorePWD) {
+               char *pwd;
+
+               if ((pwd = getenv("PWD")) != NULL &&
+                   getenv("MAKEOBJDIRPREFIX") == NULL) {
+                       const char *makeobjdir = getenv("MAKEOBJDIR");
+
+                       if (makeobjdir == NULL || !strchr(makeobjdir, '$')) {
+                               if (stat(pwd, &sb) == 0 &&
+                                   sa.st_ino == sb.st_ino &&
+                                   sa.st_dev == sb.st_dev)
+                                       (void)strncpy(curdir, pwd, MAXPATHLEN);
+                       }
                }
        }
 #endif
@@ -1204,10 +1275,6 @@ main(int argc, char **argv)
 
        Main_ExportMAKEFLAGS(TRUE);     /* initial export */
 
-#ifndef NO_CHECK_MAKE_CHDIR
-       Check_Cwd_av(0, NULL, 0);       /* initialize it */
-#endif
-
        /*
         * For compatibility, look at the directories in the VPATH variable
         * and add them to the search path, if the variable is defined. The
@@ -1334,6 +1401,9 @@ main(int argc, char **argv)
 
        Trace_Log(MAKEEND, 0);
 
+       if (enterFlag)
+               printf("%s: Leaving directory `%s'\n", progname, curdir);
+
        Suff_End();
         Targ_End();
        Arch_End();
@@ -1366,7 +1436,7 @@ ReadMakefile(const void *p, const void *q MAKE_ATTR_UNUSED)
 
        if (!strcmp(fname, "-")) {
                Parse_File(NULL /*stdin*/, -1);
-               Var_Set("MAKEFILE", "", VAR_GLOBAL, 0);
+               Var_Set("MAKEFILE", "", VAR_INTERNAL, 0);
        } else {
                /* if we've chdir'd, rebuild the path name */
                if (strcmp(curdir, objdir) && *fname != '/') {
@@ -1415,7 +1485,7 @@ ReadMakefile(const void *p, const void *q MAKE_ATTR_UNUSED)
                 */
 found:
                if (!doing_depend)
-                       Var_Set("MAKEFILE", fname, VAR_GLOBAL, 0);
+                       Var_Set("MAKEFILE", fname, VAR_INTERNAL, 0);
                Parse_File(fname, fd);
        }
        free(path);
@@ -1423,208 +1493,6 @@ found:
 }
 
 
-/*
- * If MAKEOBJDIRPREFIX is in use, make ends up not in .CURDIR
- * in situations that would not arrise with ./obj (links or not).
- * This tends to break things like:
- *
- * build:
- *     ${MAKE} includes
- *
- * This function spots when ${.MAKE:T} or ${.MAKE} is a command (as
- * opposed to an argument) in a command line and if so returns
- * ${.CURDIR} so caller can chdir() so that the assumptions made by
- * the Makefile hold true.
- *
- * If ${.MAKE} does not contain any '/', then ${.MAKE:T} is skipped.
- *
- * The chdir() only happens in the child process, and does nothing if
- * MAKEOBJDIRPREFIX and MAKEOBJDIR are not in the environment so it
- * should not break anything.  Also if NOCHECKMAKECHDIR is set we
- * do nothing - to ensure historic semantics can be retained.
- */
-#ifdef NO_CHECK_MAKE_CHDIR
-char *
-Check_Cwd_Cmd(cmd)
-     char *cmd;
-{
-     return 0;
-}
-
-void
-Check_Cwd(argv)
-    char **argv;
-{
-    return;
-}
-
-#else
-
-static int  Check_Cwd_Off = 0;
-
-static char *
-Check_Cwd_av(int ac, char **av, int copy)
-{
-    static char *make[4];
-    static char *cur_dir = NULL;
-    char **mp;
-    char *cp;
-    int is_cmd, next_cmd;
-    int i;
-    int n;
-
-    if (Check_Cwd_Off) {
-       if (DEBUG(CWD))
-           fprintf(debug_file, "check_cwd: check is off.\n");
-       return NULL;
-    }
-    
-    if (make[0] == NULL) {
-       if (Var_Exists("NOCHECKMAKECHDIR", VAR_GLOBAL)) {
-           Check_Cwd_Off = 1;
-           if (DEBUG(CWD))
-               fprintf(debug_file, "check_cwd: turning check off.\n");
-           return NULL;
-       }
-           
-        make[1] = Var_Value(".MAKE", VAR_GLOBAL, &cp);
-        if ((make[0] = strrchr(make[1], '/')) == NULL) {
-            make[0] = make[1];
-            make[1] = NULL;
-        } else
-            ++make[0];
-        make[2] = NULL;
-        cur_dir = Var_Value(".CURDIR", VAR_GLOBAL, &cp);
-    }
-    if (ac == 0 || av == NULL) {
-       if (DEBUG(CWD))
-           fprintf(debug_file, "check_cwd: empty command.\n");
-        return NULL;                   /* initialization only */
-    }
-
-    if (getenv("MAKEOBJDIR") == NULL &&
-        getenv("MAKEOBJDIRPREFIX") == NULL) {
-       if (DEBUG(CWD))
-           fprintf(debug_file, "check_cwd: no obj dirs.\n");
-        return NULL;
-    }
-
-    
-    next_cmd = 1;
-    for (i = 0; i < ac; ++i) {
-       is_cmd = next_cmd;
-
-       n = strlen(av[i]);
-       cp = &(av[i])[n - 1];
-       if (strspn(av[i], "|&;") == (size_t)n) {
-           next_cmd = 1;
-           continue;
-       } else if (*cp == ';' || *cp == '&' || *cp == '|' || *cp == ')') {
-           next_cmd = 1;
-           if (copy) {
-               do {
-                   *cp-- = '\0';
-               } while (*cp == ';' || *cp == '&' || *cp == '|' ||
-                        *cp == ')' || *cp == '}') ;
-           } else {
-               /*
-                * XXX this should not happen.
-                */
-               fprintf(stderr, "%s: WARNING: raw arg ends in shell meta '%s'\n",
-                   progname, av[i]);
-           }
-       } else
-           next_cmd = 0;
-
-       cp = av[i];
-       if (*cp == ';' || *cp == '&' || *cp == '|')
-           is_cmd = 1;
-       
-       if (DEBUG(CWD))
-           fprintf(debug_file, "av[%d] == %s '%s'",
-               i, (is_cmd) ? "cmd" : "arg", av[i]);
-       if (is_cmd != 0) {
-           if (*cp == '(' || *cp == '{' ||
-               *cp == ';' || *cp == '&' || *cp == '|') {
-               do {
-                   ++cp;
-               } while (*cp == '(' || *cp == '{' ||
-                        *cp == ';' || *cp == '&' || *cp == '|');
-               if (*cp == '\0') {
-                   next_cmd = 1;
-                   continue;
-               }
-           }
-           if (strcmp(cp, "cd") == 0 || strcmp(cp, "chdir") == 0) {
-               if (DEBUG(CWD))
-                   fprintf(debug_file, " == cd, done.\n");
-               return NULL;
-           }
-           for (mp = make; *mp != NULL; ++mp) {
-               n = strlen(*mp);
-               if (strcmp(cp, *mp) == 0) {
-                   if (DEBUG(CWD))
-                       fprintf(debug_file, " %s == '%s', chdir(%s)\n",
-                           cp, *mp, cur_dir);
-                   return cur_dir;
-               }
-           }
-       }
-       if (DEBUG(CWD))
-           fprintf(debug_file, "\n");
-    }
-    return NULL;
-}
-
-char *
-Check_Cwd_Cmd(const char *cmd)
-{
-    char *cp, *bp;
-    char **av;
-    int ac;
-
-    if (Check_Cwd_Off)
-       return NULL;
-    
-    if (cmd) {
-       av = brk_string(cmd, &ac, TRUE, &bp);
-       if (DEBUG(CWD))
-           fprintf(debug_file, "splitting: '%s' -> %d words\n",
-               cmd, ac);
-    } else {
-       ac = 0;
-       av = NULL;
-       bp = NULL;
-    }
-    cp = Check_Cwd_av(ac, av, 1);
-    if (bp)
-       free(bp);
-    if (av)
-       free(av);
-    return cp;
-}
-
-void
-Check_Cwd(const char **argv)
-{
-    char *cp;
-    int ac;
-    
-    if (Check_Cwd_Off)
-       return;
-    
-    for (ac = 0; argv[ac] != NULL; ++ac)
-       /* NOTHING */;
-    if (ac == 3 && *argv[1] == '-') {
-       cp =  Check_Cwd_Cmd(argv[2]);
-    } else {
-       cp = Check_Cwd_av(ac, UNCONST(argv), 0);
-    }
-    if (cp) {
-       chdir(cp);
-    }
-}
-#endif /* NO_CHECK_MAKE_CHDIR */
 
 /*-
  * Cmd_Exec --
@@ -1906,7 +1774,7 @@ Finish(int errors)
 }
 
 /*
- * enunlink --
+ * eunlink --
  *     Remove a file carefully, avoiding directories.
  */
 int
@@ -1952,7 +1820,8 @@ execError(const char *af, const char *av)
        IOADD(")\n");
 
 #ifdef USE_IOVEC
-       (void)writev(2, iov, 8);
+       while (writev(2, iov, 8) == -1 && errno == EAGAIN)
+           continue;
 #endif
 }
 
@@ -1963,8 +1832,12 @@ execError(const char *af, const char *av)
 static void
 usage(void)
 {
+       char *p;
+       if ((p = strchr(progname, '[')) != NULL)
+           *p = '\0';
+
        (void)fprintf(stderr,
-"usage: %s [-BeikNnqrstWX] \n\
+"usage: %s [-BeikNnqrstWwX] \n\
             [-C directory] [-D variable] [-d flags] [-f makefile]\n\
             [-I directory] [-J private] [-j max_jobs] [-m directory] [-T file]\n\
             [-V variable] [variable=value] [target ...]\n", progname);
index d9ff9ff..70d7e2b 100755 (executable)
@@ -13,7 +13,7 @@ esac
 CC="@CC@"
 CFLAGS="@CFLAGS@ -I. -I${srcdir} @DEFS@ @CPPFLAGS@ -DMAKE_NATIVE ${XDEFS}"
 
-MAKE_VERSION=`sed -n '/^MAKE_VERSION=/s,.*=[^0-9]*,,p' Makefile`
+MAKE_VERSION=`sed -n '/^MAKE_VERSION=/s,.*=[^0-9]*,,p' $srcdir/Makefile`
 
 MDEFS="-DMAKE_VERSION=\"$MAKE_VERSION\" \
 -D@force_machine@MACHINE=\"@machine@\" -DMACHINE_ARCH=\"@machine_arch@\" \
index 25fe488..142e989 100644 (file)
@@ -1,4 +1,4 @@
-.\"    $NetBSD: make.1,v 1.209 2012/10/08 15:09:48 christos Exp $
+.\"    $NetBSD: make.1,v 1.222 2013/08/11 09:53:49 apb Exp $
 .\"
 .\" Copyright (c) 1990, 1993
 .\"    The Regents of the University of California.  All rights reserved.
@@ -29,7 +29,7 @@
 .\"
 .\"    from: @(#)make.1        8.4 (Berkeley) 3/19/94
 .\"
-.Dd October 8, 2012
+.Dd August 11, 2013
 .Dt MAKE 1
 .Os
 .Sh NAME
@@ -37,7 +37,7 @@
 .Nd maintain program dependencies
 .Sh SYNOPSIS
 .Nm
-.Op Fl BeikNnqrstWX
+.Op Fl BeikNnqrstWwX
 .Op Fl C Ar directory
 .Op Fl D Ar variable
 .Op Fl d Ar flags
@@ -209,6 +209,8 @@ Force the
 option to print raw values of variables.
 .It Ar v
 Print debugging information about variable assignment.
+.It Ar w
+Print entering and leaving directory messages, pre and post processing.
 .It Ar x
 Run shell commands with
 .Fl x
@@ -468,6 +470,50 @@ except that the effect can be limited to a single line of a script.
 A
 .Ql Ic \-
 causes any non-zero exit status of the command line to be ignored.
+.Pp
+When
+.Nm
+is run in jobs mode with
+.Fl j Ar max_jobs ,
+the entire script for the target is fed to a
+single instance of the shell.
+.Pp
+In compatibility (non-jobs) mode, each command is run in a separate process.
+If the command contains any shell meta characters
+.Pq Ql #=|^(){};&<>*?[]:$`\e\en
+it will be passed to the shell, otherwise
+.Nm
+will attempt direct execution.
+.Pp
+Since
+.Nm
+will
+.Xr chdir 2
+to
+.Ql Va .OBJDIR
+before executing any targets, each child process
+starts with that as its current working directory.
+.Pp
+Makefiles should be written so that the mode of
+.Nm
+operation does not change their behavior.
+For example, any command which needs to use
+.Dq cd
+or
+.Dq chdir ,
+without side-effect should be put in parenthesis:
+.Bd -literal -offset indent
+
+avoid-chdir-side-effects:
+       @echo Building $@ in `pwd`
+       @(cd ${.CURDIR} && ${.MAKE} $@)
+       @echo Back in `pwd`
+
+ensure-one-shell-regardless-of-mode:
+       @echo Building $@ in `pwd`; \\
+       (cd ${.CURDIR} && ${.MAKE} $@); \\
+       echo Back in `pwd`
+.Ed
 .Sh VARIABLE ASSIGNMENTS
 Variables in make are much like variables in the shell, and, by tradition,
 consist of all upper-case letters.
@@ -699,6 +745,9 @@ then output for each target is prefixed with a token
 .Ql --- target ---
 the first part of which can be controlled via
 .Va .MAKE.JOB.PREFIX .
+If 
+.Va .MAKE.JOB.PREFIX
+is empty, no token is printed.
 .br
 For example:
 .Li .MAKE.JOB.PREFIX=${.newline}---${.MAKE:T}[${.MAKE.PID}]
@@ -812,6 +861,11 @@ In "meta" mode, this variable contains a list of all the meta files
 used (updated or not).
 This list can be used to process the meta files to extract dependency
 information.
+.It Va .MAKE.META.IGNORE_PATHS
+Provides a list of path prefixes that should be ignored;
+because the contents are expected to change over time.
+The default list includes:
+.Ql Pa /dev /etc /proc /tmp /var/run /var/tmp
 .It Va .MAKE.META.PREFIX
 Defines the message printed for each meta file updated in "meta verbose" mode.
 The default value is:
@@ -830,6 +884,13 @@ by appending their names to
 is re-exported whenever
 .Ql Va .MAKEOVERRIDES
 is modified.
+.It Va .MAKE.PATH_FILEMON
+If
+.Nm
+was built with
+.Xr filemon 4
+support, this is set to the path of the device node.
+This allows makefiles to test for this support.
 .It Va .MAKE.PID
 The process-id of
 .Nm .
@@ -1247,7 +1308,7 @@ should start and end with a period.
 For example.
 .Dl ${LINKS:@.LINK.@${LN} ${TARGET} ${.LINK.}@}
 .Pp
-However a single character varaiable is often more readable:
+However a single character variable is often more readable:
 .Dl ${MAKE_PRINT_VAR_ON_ERROR:@v@$v='${$v}'${.newline}@}
 .It Cm \&:U Ns Ar newval
 If the variable is undefined
@@ -1270,7 +1331,7 @@ The path of the node which has the same name as the variable
 is the value.
 If no such node exists or its path is null, then the
 name of the variable is used.
-In order for this modifier to work, the name (node) must at least have 
+In order for this modifier to work, the name (node) must at least have
 appeared on the rhs of a dependency.
 .Sm off
 .It Cm \&:\&! Ar cmd Cm \&!
@@ -1713,6 +1774,20 @@ targets.
 Ignore differences in commands when deciding if target is out of date.
 This is useful if the command contains a value which always changes.
 If the number of commands change, though, the target will still be out of date.
+The same effect applies to any command line that uses the variable
+.Va .OODATE ,
+which can be used for that purpose even when not otherwise needed or desired:
+.Bd -literal -offset indent
+
+skip-compare-for-some:
+       @echo this will be compared
+       @echo this will not ${.OODATE:M.NOMETA_CMP}
+       @echo this will also be compared
+
+.Ed
+The
+.Cm \&:M
+pattern suppresses any expansion of the unwanted variable.
 .It Ic .NOPATH
 Do not search for the target in the directories specified by
 .Ic .PATH .
@@ -1896,6 +1971,12 @@ If the source is the special
 .Ic .DOTLAST
 target, then the current working
 directory is searched last.
+.It Ic .PATH. Ns Va suffix
+Like
+.Ic .PATH
+but applies only to files with a particular suffix.
+The suffix must have been previously declared with
+.Ic .SUFFIXES .
 .It Ic .PHONY
 Apply the
 .Ic .PHONY
@@ -1964,6 +2045,10 @@ If no sources are specified, the
 .Ic .SILENT
 attribute is applied to every
 command in the file.
+.It Ic .STALE
+This target gets run when a dependency file contains stale entries, having
+.Va .ALLSRC
+set to the name of that dependency file.
 .It Ic .SUFFIXES
 Each source specifies a suffix to
 .Nm .
@@ -2018,64 +2103,44 @@ The basic make syntax is compatible between different versions of make,
 however the special variables, variable modifiers and conditionals are not.
 .Pp
 The way that parallel makes are scheduled changed in
-NetBSD 4.0
+.Nx 4.0
 so that .ORDER and .WAIT apply recursively to the dependent nodes.
 The algorithms used may change again in the future.
 .Pp
 The way that .for loop variables are substituted changed after
-NetBSD 5.0
+.Nx 5.0
 so that they still appear to be variable expansions.
 In particular this stops them being treated as syntax, and removes some
 obscure problems using them in .if statements.
-.Pp
-Unlike other
-.Nm
-programs, this implementation by default executes all commands for a given
-target using a single shell invocation.
-This is done for both efficiency and to simplify error handling in remote
-command invocations.
-Typically this is transparent to the user, unless the target commands change
-the current working directory using
-.Dq cd
-or
-.Dq chdir .
-To be compatible with Makefiles that do this, one can use
-.Fl B
-to disable this behavior.
-.Pp
-In compatibility mode, each command is run in a separate process.
-If the command contains any shell meta characters
-.Pq Ql #=|^(){};&<>*?[]:$`\e\en
-it will be passed to the shell, otherwise
-.Nm
-will attempt direct execution.
 .Sh SEE ALSO
 .Xr mkdep 1
 .Sh HISTORY
-make
-is derived from NetBSD
-.Xr make 1 .
-It uses autoconf to facilitate portability to other platforms.
-.Pp
 A
-make
+.Nm
 command appeared in
 .At v7 .
 This
-make
+.Nm
 implementation is based on Adam De Boor's pmake program which was written
 for Sprite at Berkeley.
 It was designed to be a parallel distributed make running jobs on different
 machines using a daemon called
 .Dq customs .
+.Pp
+Historically the target/dependency
+.Dq FRC
+has been used to FoRCe rebuilding (since the target/dependency
+does not exist... unless someone creates an
+.Dq FRC
+file).
 .Sh BUGS
 The
-make
+.Nm
 syntax is difficult to parse without actually acting of the data.
 For instance finding the end of a variable use should involve scanning each
 the modifiers using the correct terminator for each field.
 In many places
-make
+.Nm
 just counts {} and () in order to find the end of a variable expansion.
 .Pp
 There is no way of escaping a space character in a filename.
index 4fa4ff9..7905f8c 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: make.c,v 1.87 2012/06/12 19:21:51 joerg Exp $  */
+/*     $NetBSD: make.c,v 1.88 2012/11/09 18:53:05 sjg Exp $    */
 
 /*
  * Copyright (c) 1988, 1989, 1990, 1993
  */
 
 #ifndef MAKE_NATIVE
-static char rcsid[] = "$NetBSD: make.c,v 1.87 2012/06/12 19:21:51 joerg Exp $";
+static char rcsid[] = "$NetBSD: make.c,v 1.88 2012/11/09 18:53:05 sjg Exp $";
 #else
 #include <sys/cdefs.h>
 #ifndef lint
 #if 0
 static char sccsid[] = "@(#)make.c     8.1 (Berkeley) 6/6/93";
 #else
-__RCSID("$NetBSD: make.c,v 1.87 2012/06/12 19:21:51 joerg Exp $");
+__RCSID("$NetBSD: make.c,v 1.88 2012/11/09 18:53:05 sjg Exp $");
 #endif
 #endif /* not lint */
 #endif
@@ -1032,7 +1032,7 @@ MakeBuildChild(void *v_cn, void *toBeMade_next)
     if (cn->order_pred && Lst_ForEach(cn->order_pred, MakeCheckOrder, 0)) {
        /* Can't build this (or anything else in this child list) yet */
        cn->made = DEFERRED;
-       return 1;
+       return 0;                       /* but keep looking */
     }
 
     if (DEBUG(MAKE))
@@ -1055,7 +1055,7 @@ MakeBuildChild(void *v_cn, void *toBeMade_next)
     return cn->type & OP_WAIT && cn->unmade > 0;
 }
 
-/* When a .ORDER RHS node completes we do this on each LHS */
+/* When a .ORDER LHS node completes we do this on each RHS */
 static int
 MakeBuildParent(void *v_pn, void *toBeMade_next)
 {
index 384d109..b13716f 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: make.h,v 1.89 2012/06/12 19:21:51 joerg Exp $  */
+/*     $NetBSD: make.h,v 1.92 2013/09/04 15:38:26 sjg Exp $    */
 
 /*
  * Copyright (c) 1988, 1989, 1990, 1993
        ((__GNUC__ == (x) && __GNUC_MINOR__ >= (y)) ||                  \
         (__GNUC__ > (x)))
 #else /* defined(__GNUC__) */
-#define        MAKE_GNUC_PREREQx, y)   0
+#define        MAKE_GNUC_PREREQ(x, y)  0
 #endif /* defined(__GNUC__) */
 
 #if MAKE_GNUC_PREREQ(2, 7)
@@ -404,6 +404,10 @@ extern Boolean     varNoExportEnv; /* TRUE if we should not export variables
 
 extern GNode    *DEFAULT;      /* .DEFAULT rule */
 
+extern GNode   *VAR_INTERNAL;  /* Variables defined internally by make
+                                * which should not override those set by
+                                * makefiles.
+                                */
 extern GNode    *VAR_GLOBAL;           /* Variables defined in a global context, e.g
                                 * in the Makefile itself */
 extern GNode    *VAR_CMD;      /* Variables defined on the command line */
@@ -442,9 +446,8 @@ extern pid_t        myPid;
 #define MAKEFILE_PREFERENCE ".MAKE.MAKEFILE_PREFERENCE"
 #define MAKE_DEPENDFILE        ".MAKE.DEPENDFILE" /* .depend */
 #define MAKE_MODE      ".MAKE.MODE"
-
-#ifdef NEED_MAKE_LEVEL_SAFE
-# define MAKE_LEVEL_SAFE "_MAKE_LEVEL" /* some shells will not pass .MAKE. */
+#ifndef MAKE_LEVEL_ENV
+# define MAKE_LEVEL_ENV        "MAKELEVEL"
 #endif
 
 /*
diff --git a/contrib/bmake/makefile.in b/contrib/bmake/makefile.in
new file mode 100644 (file)
index 0000000..03b980a
--- /dev/null
@@ -0,0 +1,14 @@
+# $Id: makefile.in,v 1.1 2012/12/28 21:28:19 sjg Exp $
+
+# a simple makefile for those who don't like anything beyond:
+# ./configure; make; make install
+
+prefix= @prefix@
+srcdir= @srcdir@
+
+all: build
+
+build clean install test:
+       ${srcdir}/boot-strap --prefix=${prefix} -o . op=$@
+
+               
index 77af4e8..3ec0bdc 100644 (file)
@@ -1,4 +1,4 @@
-/*      $NetBSD: meta.c,v 1.25 2012/06/27 17:22:58 sjg Exp $ */
+/*      $NetBSD: meta.c,v 1.33 2013/10/01 05:37:17 sjg Exp $ */
 
 /*
  * Implement 'meta' mode.
 #endif
 
 static BuildMon Mybm;                  /* for compat */
-static Lst metaBailiwick;                      /* our scope of control */
+static Lst metaBailiwick;              /* our scope of control */
+static Lst metaIgnorePaths;            /* paths we deliberately ignore */
+
+#ifndef MAKE_META_IGNORE_PATHS
+#define MAKE_META_IGNORE_PATHS ".MAKE.META.IGNORE_PATHS"
+#endif
 
 Boolean useMeta = FALSE;
 static Boolean useFilemon = FALSE;
@@ -539,8 +544,24 @@ boolValue(char *s)
     return TRUE;
 }
 
+/*
+ * Initialization we need before reading makefiles.
+ */
+void
+meta_init(void)
+{
+#ifdef USE_FILEMON
+       /* this allows makefiles to test if we have filemon support */
+       Var_Set(".MAKE.PATH_FILEMON", _PATH_FILEMON, VAR_GLOBAL, 0);
+#endif
+}
+
+
+/*
+ * Initialization we need after reading makefiles.
+ */
 void
-meta_init(const char *make_mode)
+meta_mode_init(const char *make_mode)
 {
     static int once = 0;
     char *cp;
@@ -591,6 +612,17 @@ meta_init(const char *make_mode)
     if (cp) {
        str2Lst_Append(metaBailiwick, cp, NULL);
     }
+    /*
+     * We ignore any paths that start with ${.MAKE.META.IGNORE_PATHS}
+     */
+    metaIgnorePaths = Lst_Init(FALSE);
+    Var_Append(MAKE_META_IGNORE_PATHS,
+              "/dev /etc /proc /tmp /var/run /var/tmp ${TMPDIR}", VAR_GLOBAL);
+    cp = Var_Subst(NULL,
+                  "${" MAKE_META_IGNORE_PATHS ":O:u:tA}", VAR_GLOBAL, 0);
+    if (cp) {
+       str2Lst_Append(metaIgnorePaths, cp, NULL);
+    }
 }
 
 /*
@@ -828,6 +860,13 @@ string_match(const void *p, const void *q)
     continue; \
     }
 
+#define DEQUOTE(p) if (*p == '\'') {   \
+    char *ep; \
+    p++; \
+    if ((ep = strchr(p, '\''))) \
+       *ep = '\0'; \
+    }
+
 Boolean
 meta_oodate(GNode *gn, Boolean oodate)
 {
@@ -840,10 +879,12 @@ meta_oodate(GNode *gn, Boolean oodate)
     char fname2[MAXPATHLEN];
     char *p;
     char *cp;
+    char *link_src;
+    char *move_target;
     static size_t cwdlen = 0;
     static size_t tmplen = 0;
     FILE *fp;
-    Boolean ignoreOODATE = FALSE;
+    Boolean needOODATE = FALSE;
     Lst missingFiles;
     
     if (oodate)
@@ -906,6 +947,8 @@ meta_oodate(GNode *gn, Boolean oodate)
                oodate = TRUE;
                break;
            }
+           link_src = NULL;
+           move_target = NULL;
            /* Find the start of the build monitor section. */
            if (!f) {
                if (strncmp(buf, "-- filemon", 10) == 0) {
@@ -1019,16 +1062,21 @@ meta_oodate(GNode *gn, Boolean oodate)
                    break;
 
                case 'M':               /* renaMe */
-                   if (Lst_IsEmpty(missingFiles))
-                       break;
+                   /*
+                    * For 'M'oves we want to check
+                    * the src as for 'R'ead
+                    * and the target as for 'W'rite.
+                    */
+                   cp = p;             /* save this for a second */
+                   /* now get target */
+                   if (strsep(&p, " ") == NULL)
+                       continue;
+                   CHECK_VALID_META(p);
+                   move_target = p;
+                   p = cp;
                    /* 'L' and 'M' put single quotes around the args */
-                   if (*p == '\'') {
-                       char *ep;
-
-                       p++;
-                       if ((ep = strchr(p, '\'')))
-                           *ep = '\0';
-                   }
+                   DEQUOTE(p);
+                   DEQUOTE(move_target);
                    /* FALLTHROUGH */
                case 'D':               /* unlink */
                    if (*p == '/' && !Lst_IsEmpty(missingFiles)) {
@@ -1037,24 +1085,42 @@ meta_oodate(GNode *gn, Boolean oodate)
                            char *tp = Lst_Datum(ln);
                            Lst_Remove(missingFiles, ln);
                            free(tp);
+                           ln = NULL;  /* we're done with it */
                        }
                    }
+                   if (buf[0] == 'M') {
+                       /* the target of the mv is a file 'W'ritten */
+#ifdef DEBUG_META_MODE
+                       if (DEBUG(META))
+                           fprintf(debug_file, "meta_oodate: M %s -> %s\n",
+                                   p, move_target);
+#endif
+                       p = move_target;
+                       goto check_write;
+                   }
                    break;
                case 'L':               /* Link */
-                   /* we want the target */
+                   /*
+                    * For 'L'inks check
+                    * the src as for 'R'ead
+                    * and the target as for 'W'rite.
+                    */
+                   link_src = p;
+                   /* now get target */
                    if (strsep(&p, " ") == NULL)
                        continue;
                    CHECK_VALID_META(p);
                    /* 'L' and 'M' put single quotes around the args */
-                   if (*p == '\'') {
-                       char *ep;
-
-                       p++;
-                       if ((ep = strchr(p, '\'')))
-                           *ep = '\0';
-                   }
+                   DEQUOTE(p);
+                   DEQUOTE(link_src);
+#ifdef DEBUG_META_MODE
+                   if (DEBUG(META))
+                       fprintf(debug_file, "meta_oodate: L %s -> %s\n",
+                               link_src, p);
+#endif
                    /* FALLTHROUGH */
                case 'W':               /* Write */
+               check_write:
                    /*
                     * If a file we generated within our bailiwick
                     * but outside of .OBJDIR is missing,
@@ -1086,6 +1152,14 @@ meta_oodate(GNode *gn, Boolean oodate)
                        Lst_AtEnd(missingFiles, bmake_strdup(p));
                    }
                    break;
+               check_link_src:
+                   p = link_src;
+                   link_src = NULL;
+#ifdef DEBUG_META_MODE
+                   if (DEBUG(META))
+                       fprintf(debug_file, "meta_oodate: L src %s\n", p);
+#endif
+                   /* FALLTHROUGH */
                case 'R':               /* Read */
                case 'E':               /* Exec */
                    /*
@@ -1093,20 +1167,15 @@ meta_oodate(GNode *gn, Boolean oodate)
                     * be part of the dependencies because
                     * they are _expected_ to change.
                     */
-                   if (strncmp(p, "/tmp/", 5) == 0 ||
-                       (tmplen > 0 && strncmp(p, tmpdir, tmplen) == 0))
-                       break;
-
-                   if (strncmp(p, "/var/", 5) == 0)
-                       break;
-
-                   /* Ignore device files. */
-                   if (strncmp(p, "/dev/", 5) == 0)
-                       break;
-
-                   /* Ignore /etc/ files. */
-                   if (strncmp(p, "/etc/", 5) == 0)
+                   if (*p == '/' &&
+                       Lst_ForEach(metaIgnorePaths, prefix_match, p)) {
+#ifdef DEBUG_META_MODE
+                       if (DEBUG(META))
+                           fprintf(debug_file, "meta_oodate: ignoring: %s\n",
+                                   p);
+#endif
                        break;
+                   }
 
                    if ((cp = strrchr(p, '/'))) {
                        cp++;
@@ -1185,6 +1254,8 @@ meta_oodate(GNode *gn, Boolean oodate)
                default:
                    break;
                }
+               if (!oodate && buf[0] == 'L' && link_src != NULL)
+                   goto check_link_src;
            } else if (strcmp(buf, "CMD") == 0) {
                /*
                 * Compare the current command with the one in the
@@ -1196,17 +1267,19 @@ meta_oodate(GNode *gn, Boolean oodate)
                    oodate = TRUE;
                } else {
                    char *cmd = (char *)Lst_Datum(ln);
-
-                   if (!ignoreOODATE) {
-                       if (strstr(cmd, "$?"))
-                           ignoreOODATE = TRUE;
-                       else if ((cp = strstr(cmd, ".OODATE"))) {
-                           /* check for $[{(].OODATE[)}] */
-                           if (cp > cmd + 2 && cp[-2] == '$')
-                               ignoreOODATE = TRUE;
-                       }
-                       if (ignoreOODATE && DEBUG(META))
-                           fprintf(debug_file, "%s: %d: cannot compare commands using .OODATE\n", fname, lineno);
+                   Boolean hasOODATE = FALSE;
+
+                   if (strstr(cmd, "$?"))
+                       hasOODATE = TRUE;
+                   else if ((cp = strstr(cmd, ".OODATE"))) {
+                       /* check for $[{(].OODATE[:)}] */
+                       if (cp > cmd + 2 && cp[-2] == '$')
+                           hasOODATE = TRUE;
+                   }
+                   if (hasOODATE) {
+                       needOODATE = TRUE;
+                       if (DEBUG(META))
+                           fprintf(debug_file, "%s: %d: cannot compare command using .OODATE\n", fname, lineno);
                    }
                    cmd = Var_Subst(NULL, cmd, gn, TRUE);
 
@@ -1235,7 +1308,7 @@ meta_oodate(GNode *gn, Boolean oodate)
                        if (buf[x - 1] == '\n')
                            buf[x - 1] = '\0';
                    }
-                   if (!ignoreOODATE &&
+                   if (!hasOODATE &&
                        !(gn->type & OP_NOMETA_CMP) &&
                        strcmp(p, cmd) != 0) {
                        if (DEBUG(META))
@@ -1279,14 +1352,16 @@ meta_oodate(GNode *gn, Boolean oodate)
            oodate = TRUE;
        }
     }
-    if (oodate && ignoreOODATE) {
+    if (oodate && needOODATE) {
        /*
-        * Target uses .OODATE, so we need to re-compute it.
-        * We need to clean up what Make_DoAllVar() did.
+        * Target uses .OODATE which is empty; or we wouldn't be here.
+        * We have decided it is oodate, so .OODATE needs to be set.
+        * All we can sanely do is set it to .ALLSRC.
         */
-       Var_Delete(ALLSRC, gn);
        Var_Delete(OODATE, gn);
-       gn->flags &= ~DONE_ALLSRC;
+       Var_Set(OODATE, Var_Value(ALLSRC, gn, &cp), gn, 0);
+       if (cp)
+           free(cp);
     }
     return oodate;
 }
index 1ce01ca..57c73ca 100644 (file)
@@ -1,4 +1,4 @@
-/*      $NetBSD: meta.h,v 1.2 2011/03/30 22:03:49 sjg Exp $ */
+/*      $NetBSD: meta.h,v 1.3 2013/03/23 05:31:29 sjg Exp $ */
 
 /*
  * Things needed for 'meta' mode.
@@ -41,7 +41,8 @@ typedef struct BuildMon {
 extern Boolean useMeta;
 
 struct Job;                            /* not defined yet */
-void meta_init(const char *);
+void meta_init(void);
+void meta_mode_init(const char *);
 void meta_job_start(struct Job *, GNode *);
 void meta_job_child(struct Job *);
 void meta_job_error(struct Job *, GNode *, int, int);
diff --git a/contrib/bmake/mk/ChangeLog b/contrib/bmake/mk/ChangeLog
new file mode 100644 (file)
index 0000000..b547197
--- /dev/null
@@ -0,0 +1,758 @@
+2013-09-04  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * gendirdeps.mk (_objtops): fix typo also
+         while processing M2D_OBJROOTS to gather qualdir_list
+         qualify $ql with loop iterator to ensure correct results.
+
+2013-08-01  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): 20130801
+       * libs.mk: update to match progs.mk
+       
+2013-07-26  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): 20130726
+         some updates from Juniper and FreeBSD
+         o meta2deps.py: indicate file and line number when we hit parse
+           errors
+           also allow @file to provide huge list of .meta files.
+       * meta2deps.py: add try_parse() to cleanup the above.
+       
+2013-07-16  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): 20130716
+       * own.mk: add GPROG as an option
+       * prog.mk: honor MK_GPROF==yes
+       
+2013-05-10  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): 20130505
+       * gendirdeps.mk, meta2deps.py, meta2deps.sh: handle $TARGET_SPEC
+         for when $MACHINE isn't enough for objdir distinction.
+         Bring meta2deps.sh closer to par with meta2deps.py.
+
+2013-04-18  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * meta.stage.mk: set INSTALL to STAGE_INSTALL when making 'all'
+         also if the target 'beforeinstall' exists, make it depend on
+         .dirdep (incase it uses STAGE_INSTALL).
+
+2013-04-17  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): 20130401 ;-)
+       * meta.stage.mk (STAGE_INSTALL_SH): add stage-install.sh as
+         wrapper around install(1).
+       * options.mk (OPTION_PREFIX): Allow a prefix other than MK_
+
+2013-03-30  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * meta2deps.py (MetaFile.__init__): ensure self.cwd is initialized.
+       * install-mk (MK_VERSION): bump version
+
+2013-03-21  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version
+       * gendirdeps.mk: do not apply :tA to DPADD entries, since we lose
+         any trailing /., rather apply :tA only when needed.
+       * gendirdeps.mk: better mimic meta2deps handling of .dirdep files.
+       * meta.stage.mk (LN_CP_SCRIPT): Add LnCp to do the ln||cp dance
+         consistently.
+       * dirdeps.mk: better describe the dance in sys.mk for TARGET_SPEC.
+       
+2013-03-18  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * gendirdeps.mk: revert the dance around .MAKE.DEPENDFILE_DEFAULT
+         it is simpler to just not update when say building for "host"
+         (where we know we apply filters to DIRDEPS), and using a
+         non-machine qualified dependfile.
+
+2013-03-16  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * dirdeps.mk: improve DIRDEPS filtering by allowing DEP_SKIP_DIR
+         and DEP_DIRDEPS_FILTER to vary by DEP_MACHINE and DEP_TARGET_SPEC
+       * gendirdeps.mk: ensure _objroot has trailing / if it needs it.
+       * meta2deps.py: if machine is "host", then also trim
+         self.host_target from any OBJROOTS.
+       
+
+2013-03-11  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * gendirdeps.mk: if .MAKE.DEPENDFILE_DEFAULT is not machine
+         qualified but _DEPENDFILE is, and .MAKE.DEPENDFILE_DEFAULT exists
+         but _DEPENDFILE does not, compare the new _DEPENDFILE against
+         .MAKE.DEPENDFILE_DEFAULT and discard if the same.
+
+2013-03-08  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * meta.stage.mk: use STAGE_TARGETS to control .ORDER
+         and hook to all: via staging:
+
+2013-03-07  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * sys.dependfile.mk (.MAKE.DEPENDFILE_DEFAULT): 
+         use a separate variable for the default .MAKE.DEPENDFILE value
+         so that it can be controlled independently of
+         .MAKE.DEPENDFILE_PREFERENCE
+
+       * meta.stage.mk: throw error if cp fails etc.
+         Stage*() return early if passed no args.
+         .ORDER stage_*
+
+2013-03-03  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version
+       * gendirdeps.mk: handle multiple M2D_OBJROOTS better.
+
+2013-02-10  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20130210
+       * import latest dirdeps.mk, gendirdeps.mk and meta2deps.py 
+         from Juniper. 
+         o dirdeps.mk now fully supports TARGET_SPEC consisting of more
+           than just MACHINE.
+         o no longer use DEP_MACHINE from Makefile.depend* so remove it.
+       
+2013-01-23  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20130123
+       * meta.stage.mk: add stage_links (hard links).
+         if doing hard links, we add dest to link as well.
+         Default the stage dir for [sym]links to STAGE_OBJTOP since
+         these are typically specified as absolute paths.
+         Add -m "mode" flag to StageFiles and StageAs.
+
+2012-11-11  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20121111
+       * autoconf.mk: avoid meta mode seeing changed commands for config.status
+       * meta.autodep.mk: pass resolved MAKESYSPATH to gendirdeps
+         in case we were found via .../mk
+       * sys.clean-env.mk: move it from examples, we and others use it
+         "as is".
+       * FILES: add srctop.mk and options.mk
+       * own.mk: convert to using options.mk
+         which is modeled after FreeBSD's handling of MK_*
+         but more flexible.
+         This allows MK_* for boolean knobs to not be confused
+         with MK* which can be commands.
+
+       * examples/sys.clean-env.mk: add WITH[OUT]_ to
+         MAKE_ENV_SAVE_PREFIX_LIST.
+         Mention that HOME=/var/empty might be a good idea.
+
+2012-11-08  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * sys.dependfile.mk: if not depend file exists, $MACHINE
+         specific ones are supported but not the default,
+         check if any exist and follow suit.
+
+2012-11-06  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20121106
+
+2012-11-05  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * import latest dirdeps.mk and meta2deps.py from Juniper.
+       * progs.mk: add MAN and CXXFLAGS to PROG_VARS
+         also add PROGS_TARGETS and pass on PROG_CXX if it seems
+         appropriate.
+       
+2012-11-04  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * meta.stage.mk: update CLEANFILES
+         remove redundant cp of .dirdep from STAGE_AS_SCRIPT.
+       * progs.mk: Add LDADD to PROG_VARS
+       
+2012-10-12  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * meta.stage.mk (STAGE_DIR_FILTER): track dirs we stage to in
+         _STAGED_DIRS so that these can be turned into filters for
+         GENDIRDEPS_FILTER.
+
+2012-10-10  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20121010
+       * meta.stage.mk (STAGE_DIRDEP_SCRIPT): check that an existing
+       target.dirdep matches .dirdep
+
+2012-08-08  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20120808
+       * import latest meta2deps.py from Juniper.
+
+2012-07-11  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20120711
+       * dep.mk: add explicit dependencies on SRCS after applying
+         SRCS_DEP_FILTER 
+       * meta.autodep.mk: add explicit dependencies on SRCS after
+         applying SRCS_DEP_FILTER
+       * meta.autodep.mk: ensure GENDIRDEPS_FILTER is exported if needed.
+       
+2012-06-26  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20120626
+       * meta.sys.mk: ignore PYTHON if it does not exist
+         compare ${.MAKE.DEPENDFILE:E} against ${MACHINE} is more reliable.
+       * meta.stage.mk: examine .MAKE.DEPENDFILE_PREFERENCE for any
+         entries ending in .${MACHINE} to decide if qualified _dirdep is
+         needed.
+       * gendirdeps.mk: only produce unqualified deps if no
+         .MAKE.DEPENDFILE_PREFERENCE ends in .${MACHINE}
+       * meta.subdir.mk: apply SUBDIREPS_FILTER
+       
+2012-04-20  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20120420
+       * add sys.dependfile.mk so we can experiment with
+         .MAKE.DEPENDFILE_PREFERENCE 
+       * meta.autodep.mk: _DEPENDFILE is precious!
+       
+2012-03-15  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20120315
+       * install-new.mk: avoid being interrupted
+
+2012-02-26  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * man.mk: MAN might have multiple values so be careful with exists().
+
+2012-01-19  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20120112
+       * fix examples/sys.clean-env.mk so that MAKEOBJDIR is handled
+         as: MAKEOBJDIR='${.CURDIR:S,${SRCTOP},${OBJTOP},}'
+
+2011-12-03  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION):  bump version to 20111201
+       * import dirdeps.mk from Juniper sjg@
+         o more consistent handling of DEP_MACHINE, especially when
+           dealing with an odd Makefile.depend, when normally using
+           Makefile.depend.${MACHINE}
+
+2011-11-22  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20111122
+       * meta.autodep.mk: add some debug output, be more crisp about
+         updating.  Use ${.ALLTARGETS:M*.o} as a clue for .depend
+
+2011-11-13  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20111111
+         it's too cool to miss
+       * import meta* updates from Juniper sjg@
+         o dirdeps.mk set DEP_MACHINE for Makefile.depend (when we are
+           normally using Makefile.depend.${MACHINE}), handy for
+           read-only manually maintained dependencies.
+         o meta2deps.py add a clear 'ERROR:' token if an exception is raised.
+         o gendirdeps.mk if ERROR: from meta2deps.py do not update
+           anything.
+       
+2011-10-30  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-new.mk separate the cmp and copy logic to its own function.
+       
+2011-10-28  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20111028
+       * sys.mk: include auto.obj.mk if MKOBJDIRS is set to auto
+       * subdir.mk: ensure _SUBDIRUSE is provided
+       * meta.autodep.mk: remove dependency of gendirdeps.mk on auto.obj.mk 
+       * meta.subdir.mk: always allow for Makefile.depend
+       
+2011-10-10  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20111010
+         o minor tweak to *dirdeps.mk from Juniper sjg@
+       
+2011-10-01  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20111001
+         o add meta2deps.py from Juniper sjg@
+         o tweak gendirdeps.mk to work with meta2deps.py when not
+           cross-building 
+       * autoconf.mk: add autoconf-input as a hook for regenerating 
+         AUTOCONF_INPUTS (configure).
+
+2011-08-24  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * meta.autodep.mk: if we do not have OBJS, .depend isn't a useful
+         trigger for updating Makefile.depend* 
+
+2011-08-08  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20110808
+       * obj.mk: minor cleanup
+       * auto.obj.mk: improve description of Mkdirs and honor NO_OBJ too.
+
+2011-08-01  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * auto.obj.mk (.OBJDIR): throw an error if we cannot use the
+         specified dir.
+
+2011-06-28  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * meta.autodep.mk: if XMAKE_META_FILE is set
+         the makefile uses a foreign make, and so dependencies
+         can only be gathered from a clean tree build.
+
+2011-06-24  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20110622
+       * meta.autodep.mk: improve bootstraping
+
+2011-06-10  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * yacc.mk: handle the corner case of .c being removed
+         while .h remains.
+
+2011-06-08  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * yacc.mk: do .y.h and .y.c separately
+
+2011-06-04  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20110606
+       * don't store SRC_DIRDEPS in Makefile.depend* by default
+         not everyone needs it.
+
+2011-05-04  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20110505
+         first release including meta mode makefiles
+
+2011-05-02  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * meta.stage.mk: add STAGE_AS_SETS and stage_as
+         for things that need to be staged with different names.
+
+2011-05-01  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * meta.stage.mk: add notion of STAGE_SETS
+         so a makefile can stage to multiple dirs
+
+2011-04-03  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * rst2htm.mk: convert rst to s5 (slides) or plain html depending
+         on target name. 
+
+2011-03-30  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20110330
+
+2011-03-29  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * sys.mk (_DEBUG_MAKE_FLAGS): use indirection so that DEBUG_MAKE_FLAGS0
+         can be used to debug level 0 only and DEBUG_MAKE_FLAGS for the rest.
+       * sys.mk: re-define M_whence in terms of M_type.
+         M_type is useful for checking if something is a builtin.
+       
+2011-03-16  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * meta.stage.mk: add stage_symlinks and leverage StageLinks for
+         stage_libs 
+
+2011-03-10  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * dirdeps.mk: correct value for _depdir_files depends on
+         .MAKE.DEPENDFILE 
+         Add our copyright - just to make it clear we have frobbed this
+         quite a bit.
+         DEP_MACHINE needs to be set to MACHINE each time, if using only
+         Makefile.depend (cf. Makefile.depend.${MACHINE})
+
+       * meta.stage.mk: meta mode version of staging
+
+       * init.mk, final.mk: include local.*.mk to simplify customization
+
+2011-03-03  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * auto.obj.mk: just because we are doing mk destroy, we should
+         still set .OBJDIR correctly if it exists.
+
+       * install-mk (mksrc): do not exclude meta.sys.mk
+
+2011-03-01  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * host-target.mk: set/export _HOST_ARCH etc separately,
+         catch junk resulting from uname -p, so we can find sys/Linux.mk
+         correctly.
+
+2011-02-18  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * meta.sys.mk: throw an error if /dev/filemon is missing and we
+         expected to be updating Makefile.depend*
+
+2011-02-14  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20110214
+       * meta.subdir.mk: add support for -DBOOTSTRAP_DEPENDFILES
+
+2010-09-25  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * meta.sys.mk: not valid for older bmake
+
+2010-09-24  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20100919
+       include dirdeps.mk et al from Juniper Networks, 
+       for meta mode - requires filemon(9).
+       * sys.mk, subdir.mk: Add hooks for meta mode.
+       we do this as meta.sys.mk, meta.autodep.mk and meta.subdir.mk
+       to make turning it on/off simple.
+
+2010-06-16  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20100616
+       * fix typo in sys.mk
+
+2010-06-12  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20100612
+       * lib.mk: remove duplicate addition to SOBJS
+
+2010-06-10  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * sys.mk: Add a means of selectively turning on debug flags.
+         Eg. DEBUG_MAKE_FLAGS=-dv DEBUG_MAKE_DIRS="*lib/sjg"
+         will act as if we did make -dv if .CURDIR ends in lib/sjg
+         DEBUG_MAKE_SYS_DIRS does the same thing, but we set the flags at
+         the start of sys.mk rather than the end.
+         This only makes sense for leaf dirs, so we check that
+         .MAKE.LEVEL > 0
+
+2010-06-09  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20100608
+       * sys.mk: include sys.env.mk later so it can use M_ListToSkip et al.
+       * examples/sys.clean-env.mk: require MAKE_VERIONS >= 20100606
+         also make it easier for folk to tweak
+
+2010-06-08  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20100606
+         do not install examples/*
+       * FILES: add examples/sys.clean-env.mk
+       * examples/sys.clean-env.mk: use .export-env to handle MAKEOBJDIR
+         this requires bmake-20100606 or later to work.
+
+2010-05-13  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * sys.mk (M_tA): better simulate the result of :tA if not available.
+
+2010-05-04  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * sys.mk: canonicalize MAKE_VERSION
+         old versions reported bmake-<src-date> build-<build-date>
+         whereas we only care about <src-date>
+
+2010-04-25  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk: just warn about FORCE_{BSD,SYS}_MK being ignored
+       * lib.mk: we only build the shared lib if SHLIB_FULLVERSION
+         is !empty
+
+2010-04-22  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * dpadd.mk: use LDADD_* if defined.
+
+2010-04-21  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20100420
+       * sys/NetBSD.mk: add MACHINE_CPU to keep netbsd makefiles happy
+       * autoconf.mk allow AUTO_AUTOCONF
+       
+2010-04-19  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * obj.mk: add objwarn to keep freebsd makefiles happy
+       * auto.obj.mk: ensure Mkdirs is available.
+       * FILES: add auto.dep.mk - a simpler version of autodep.mk
+       * dep.mk: auto.dep.mk does not do 'make depend' so ignore it if
+         asked to do that.
+         fix/simplify the tests for when to run mkdep.
+       * auto.dep.mk: add some explaination of how/what we do.
+       * autodep.mk: skip the .OPTIONAL frobbing of .depend
+         bmake's FROM_DEPEND flag makes it redundant.
+       
+2010-04-13  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20100404
+       * subdir.mk: protect from multiple inclusion using _SUBDIRUSE.
+       * obj.mk: protect from multiple inclusion even as bsd.obj.mk
+       Also create a target _SUBDIRUSE so that we can  be used without
+       subdir.mk
+
+2010-04-12  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * dep.mk: use <> when .including so can override.
+
+2010-01-11  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * lib.mk (SHLIB_LINKS): ensure a string comparison.
+
+2010-01-04  Simon J. Gerraty  <sjg@bad.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20100102
+       * own.mk: ensure PRINTOBJDIR works
+       * autoconf.mk: pass on CONFIGURE_ARGS
+       * init.mk: handle COPTS.${.IMPSRC:T} etc.
+       * lib.mk: allow sys.mk to control SHLIB_FULLVERSION
+         fix handling of symlinks for darwin
+       * libnames.mk: add DSHLIBEXT for libs which only exist as shared.
+       * man.mk: suppress chown when not root.
+       * rst2htm.mk: allow srcs from multiple locations.
+       * sys.mk: M_whence, stop after 1st line of output.
+       * sys/Darwin.mk: Use .dylib for DSHLIBEXT and HOST_LIBEXT
+       * sys/SunOS.mk: we need to export PATH
+
+2009-12-23  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version
+         include rst2htm.mk
+
+2009-12-17  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * sys.mk,libnames.mk add .-include <local.*>
+         this allows local customization without the need to edit the
+         distributed files. 
+
+2009-12-14  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * dpadd.mk (__dpadd_libdirs): order -L's to avoid picking up
+         older versions already installed.
+
+2009-12-13  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * stage.mk (.stage-install): generalize lib.mk's .libinstall
+       * rules.mk rules for generic Makefile.
+       * inc.mk install for includes.
+
+2009-12-11  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * sys/NetBSD.mk (MAKE_VERSION): some of our *.mk want to check
+         this, so provide it if using native make.
+
+2009-12-10  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * FILES: move all the platform *.sys.mk files to sys/*.mk
+       * Rename Generic.sys.mk to sys.mk - we always want it.
+
+2009-11-17  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version
+       * host-target.mk: only export the expensive stuff 
+       * Generic.sys.mk (sys_mk): for SunOS we need to look for
+         ${HOST_OS}.${HOST_OSMAJOR} too!
+
+2009-11-07  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version
+       * lib.mk: if sys.mk doesn't give us an lorder, don't use it.
+         based on patch from Greg Olszewski.
+       * Generic.sys.mk: if we have nothing to work with
+       set LORDER etc only if we can find it.
+
+2009-09-08  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version
+       * man.mk: cleanman: remove CLEANMAN if defined.
+
+2009-09-04  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * SunOS.5.sys.mk (CC): Use ?= like the other *sys.mk
+
+2009-07-17  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version
+       include auto.obj.mk
+
+
+2009-03-26  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * prog.mk,lib.mk: ensure test of USE_DPADD_MK doesn't fail.
+
+2008-11-11  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version
+       man.mk: ensure we generate *.cat1 etc in .
+
+2008-07-16  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version
+       add prlist.mk
+
+2007-11-25  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * Generic.sys.mk: Allow os specific sys.mk to be in a
+       subdir of ${.PARSEDIR}
+
+2007-11-22  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version
+       * general cleanup
+       * dpadd.mk introduce DPMAGIC_LIBS_* 
+
+2007-04-30  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version
+
+       * libs.mk, progs.mk, autodep.mk: allow for per lib/prog
+       depend files and ensure clean is called for each lib/prog.
+
+2007-03-27  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * autodep.mk (.depend): delete lines that do not start with
+       space and do not contain ':'
+
+2007-02-16  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * autodep.mk (.depend): gcc may wrap lines if pathnames are long
+       so make sure the transform for .OPTIONAL copes.
+
+2007-02-03  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version
+
+       * own.mk: make sure RM and LN are defined.
+
+       * obj.mk: fix a typo, and objlink target.
+
+2006-12-30  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version
+       * added libs.mk - analagous to progs.mk
+         make both of them always inlcude {lib,prog}.mk
+
+2006-12-28  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * progs.mk: add a means of building multiple apps in one dir.
+
+2006-11-26  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20061126
+
+       * warnings.mk: detect invalid WARNINGS_SET
+       
+       * warnings.mk: use ${.TARGET:T:R}.o when looking for target
+       specific warnings. 
+       
+       * For .cc sources, turn off warnings that g++ vomits on.
+
+2006-11-08  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * own.mk: if __initialized__ target doesn't exist and we are
+       FreeBSD we got here directly from sys.mk
+
+2006-11-06  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20061106
+       add scripts.mk
+
+2006-03-18  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20060318
+
+       * autodep.mk: avoid := when modifying OBJS into __dependsrcs
+
+2006-03-02  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20060302
+       * autodep.mk: use -MF et al to help gcc+ccache DTRT.
+
+2006-03-01  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20060301
+       * autodep.mk (.depend): 
+       if MAKE_VERSION is newer than  20050530 we can make .END depend on
+       .depend and make .depend depend on __depsrcs that exist.
+       * dpadd.mk: add SRC_PATHADD
+       
+2005-11-04  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20051104
+       * prog.mk: remove all the LIBC?= junk, use
+       .-include libnames.mk instead (none by default).
+       also if USE_DPADD_MK is set, include that.
+
+2005-10-09  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20051001
+       Add UnixWare.sys.mk from Klaus Heinz.
+
+2005-04-05  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk: always install *.sys.mk and if need be symlink one
+       to sys.mk
+
+2005-03-22  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * subdir.mk, own.mk: use .MAKE rather than MAKE
+
+2004-02-15  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * own.mk: don't use NetBSD's _SRC_TOP_ it can
+       cause confusion.  Also don't take just 'mk' as a 
+       srctop indicator.
+
+2004-02-14  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * warnings.mk: overhauled, now very powerful.
+
+2004-02-03  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * Generic.sys.mk: need to use ${.PARSEDIR} with exists().
+
+2004-02-01  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): bump version to 20040201
+       * extract HOST_TARGET stuff to host-target.mk so own.mk and
+       Generic.sys.mk can share.
+       * fix typo in autodep.mk _SUBDIRUSE not _SUBDIR.
+
+2003-09-30  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): 20030930
+       * rename generic.sys.mk to Generic.sys.mk
+       so that it does not get installed (unless being used as sys.mk)
+       * set OS and ROOT_GROUP for those that we know the value.
+       for others (eg. Generic.sys.mk) wrap the != in an .ifndef so
+       we don't do it again for each sub-make.
+       
+2003-09-28  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk (MK_VERSION): 20030928
+       Add some extra *.sys.mk from bootstrap-pkgsrc
+       some of these likely still need work.
+       Make everything default to root:wheel ownership,
+       sys.mk can set ROOT_GROUP accordingly.
+
+2003-08-07  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk: if FORCE_BSD_MK={cp,ln} use the ones in SYS_MK_DIR
+       not the portable ones.
+
+2003-07-31  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk: add ability to use cp -f when updating 
+       destination .mk files.  Also now possible to play games with 
+       FORCE_SYS_MK=ln etc on *BSD machines to link /usr/share/mk/sys.mk
+       into dest - not recommended unless you seriously want to.
+
+2003-07-28  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * own.mk (IMPFLAGS): add support for COPTS.${IMPSRC:T} etc
+       for semi-compatability with NetBSD.
+
+2003-07-23  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * install-mk: add a version indicator
+
+2003-07-22  Simon J. Gerraty  <sjg@void.crufty.net>
+
+       * prog.mk: don't try and use ${LIBCRT0} if its /dev/null
+
+       * install-mk: Allow FORCE_SYS_MK to come from env
+
+
+       
diff --git a/contrib/bmake/mk/FILES b/contrib/bmake/mk/FILES
new file mode 100644 (file)
index 0000000..443aa2e
--- /dev/null
@@ -0,0 +1,61 @@
+ChangeLog
+FILES
+README
+auto.obj.mk
+autoconf.mk
+autodep.mk
+auto.dep.mk
+dep.mk
+doc.mk
+dpadd.mk
+final.mk
+host-target.mk
+host.libnames.mk
+inc.mk
+init.mk
+install-mk
+java.mk
+lib.mk
+libnames.mk
+libs.mk
+links.mk
+man.mk
+mk-files.txt
+nls.mk
+obj.mk
+options.mk
+own.mk
+prlist.mk
+prog.mk
+progs.mk
+rst2htm.mk
+scripts.mk
+srctop.mk
+stage-install.sh
+subdir.mk
+sys.mk
+sys.clean-env.mk
+sys.dependfile.mk
+sys/AIX.mk
+sys/Darwin.mk
+sys/Generic.mk
+sys/HP-UX.mk
+sys/IRIX.mk
+sys/Linux.mk
+sys/NetBSD.mk
+sys/OSF1.mk
+sys/OpenBSD.mk
+sys/SunOS.mk
+sys/UnixWare.mk
+target-flags.mk
+warnings.mk
+yacc.mk
+dirdeps.mk
+gendirdeps.mk
+install-new.mk
+meta2deps.py
+meta2deps.sh
+meta.sys.mk
+meta.autodep.mk
+meta.stage.mk
+meta.subdir.mk
diff --git a/contrib/bmake/mk/README b/contrib/bmake/mk/README
new file mode 100644 (file)
index 0000000..3d79b6a
--- /dev/null
@@ -0,0 +1,401 @@
+#      $Id: README,v 1.1 1997/03/11 07:27:15 sjg Exp $
+
+This directory contains some macro's derrived from the NetBSD bsd.*.mk
+macros.  They have the same names but without the bsd., separate macro
+files are needed to ensure we can make them do what we want for
+builing things outside of /usr/src.  Nearly all the comments below
+apply. 
+
+#      $NetBSD: bsd.README,v 1.18 1997/01/13 00:54:23 mark Exp $
+#      @(#)bsd.README  5.1 (Berkeley) 5/11/90
+
+This is the README file for the new make "include" files for the BSD
+source tree.  The files are installed in /usr/share/mk, and are, by
+convention, named with the suffix ".mk".
+
+Note, this file is not intended to replace reading through the .mk
+files for anything tricky.
+
+=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
+
+RANDOM THINGS WORTH KNOWING:
+
+The files are simply C-style #include files, and pretty much behave like
+you'd expect.  The syntax is slightly different in that a single '.' is
+used instead of the hash mark, i.e. ".include <bsd.prog.mk>".
+
+One difference that will save you lots of debugging time is that inclusion
+of the file is normally done at the *end* of the Makefile.  The reason for
+this is because .mk files often modify variables and behavior based on the
+values of variables set in the Makefile.  To make this work, remember that
+the FIRST target found is the target that is used, i.e. if the Makefile has:
+
+       a:
+               echo a
+       a:
+               echo a number two
+
+the command "make a" will echo "a".  To make things confusing, the SECOND
+variable assignment is the overriding one, i.e. if the Makefile has:
+
+       a=      foo
+       a=      bar
+
+       b:
+               echo ${a}
+
+the command "make b" will echo "bar".  This is for compatibility with the
+way the V7 make behaved.
+
+It's fairly difficult to make the BSD .mk files work when you're building
+multiple programs in a single directory.  It's a lot easier split up the
+programs than to deal with the problem.  Most of the agony comes from making
+the "obj" directory stuff work right, not because we switch to a new version
+of make.  So, don't get mad at us, figure out a better way to handle multiple
+architectures so we can quit using the symbolic link stuff.  (Imake doesn't
+count.)
+
+The file .depend in the source directory is expected to contain dependencies
+for the source files.  This file is read automatically by make after reading
+the Makefile.
+
+The variable DESTDIR works as before.  It's not set anywhere but will change
+the tree where the file gets installed.
+
+The profiled libraries are no longer built in a different directory than
+the regular libraries.  A new suffix, ".po", is used to denote a profiled
+object.
+
+=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
+
+The include file <sys.mk> has the default rules for all makes, in the BSD
+environment or otherwise.  You probably don't want to touch this file.
+
+=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
+
+The include file <bsd.man.mk> handles installing manual pages and their
+links.
+
+It has a single target:
+
+       maninstall:
+               Install the manual pages and their links.
+
+It sets/uses the following variables:
+
+MANDIR         Base path for manual installation.
+
+MANGRP         Manual group.
+
+MANOWN         Manual owner.
+
+MANMODE                Manual mode.
+
+MANSUBDIR      Subdirectory under the manual page section, i.e. "/vax"
+               or "/tahoe" for machine specific manual pages.
+
+MAN            The manual pages to be installed (use a .1 - .9 suffix).
+
+MLINKS         List of manual page links (using a .1 - .9 suffix).  The
+               linked-to file must come first, the linked file second,
+               and there may be multiple pairs.  The files are soft-linked.
+
+The include file <bsd.man.mk> includes a file named "../Makefile.inc" if
+it exists.
+
+=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
+
+The include file <bsd.own.mk> contains source tree configuration parameters,
+such as the owners, groups, etc. for both manual pages and binaries, and
+a few global "feature configuration" parameters.
+
+It has no targets.
+
+To get system-specific configuration parameters, bsd.own.mk will try to
+include the file specified by the "MAKECONF" variable.  If MAKECONF is not
+set, or no such file exists, the system make configuration file, /etc/mk.conf
+is included.  These files may define any of the variables described below.
+
+bsd.own.mk sets the following variables, if they are not already defined
+(defaults are in brackets):
+
+BSDSRCDIR      The real path to the system sources, so that 'make obj'
+               will work correctly. [/usr/src]
+
+BSDOBJDIR      The real path to the system 'obj' tree, so that 'make obj'
+               will work correctly. [/usr/obj]
+
+BINGRP         Binary group. [bin]
+
+BINOWN         Binary owner. [bin]
+
+BINMODE                Binary mode. [555]
+
+NONBINMODE     Mode for non-executable files. [444]
+
+MANDIR         Base path for manual installation. [/usr/share/man/cat]
+
+MANGRP         Manual group. [bin]
+
+MANOWN         Manual owner. [bin]
+
+MANMODE                Manual mode. [${NONBINMODE}]
+
+LIBDIR         Base path for library installation. [/usr/lib]
+
+LINTLIBDIR     Base path for lint(1) library installation. [/usr/libdata/lint]
+
+LIBGRP         Library group. [${BINGRP}]
+
+LIBOWN         Library owner. [${BINOWN}]
+
+LIBMODE                Library mode. [${NONBINMODE}]
+
+DOCDIR         Base path for system documentation (e.g. PSD, USD, etc.)
+               installation. [/usr/share/doc]
+
+DOCGRP         Documentation group. [bin]
+
+DOCOWN         Documentation owner. [bin]
+
+DOCMODE                Documentation mode. [${NONBINMODE}]
+
+NLSDIR         Base path for National Language Support files installation.
+               [/usr/share/nls]
+
+NLSGRP         National Language Support files group. [bin]
+
+NLSOWN         National Language Support files owner. [bin]
+
+NLSMODE                National Language Support files mode. [${NONBINMODE}]
+
+STRIP          The flag passed to the install program to cause the binary
+               to be stripped.  This is to be used when building your
+               own install script so that the entire system can be made
+               stripped/not-stripped using a single knob. [-s]
+
+COPY           The flag passed to the install program to cause the binary
+               to be copied rather than moved.  This is to be used when
+               building our own install script so that the entire system
+               can either be installed with copies, or with moves using
+               a single knob. [-c]
+
+Additionally, the following variables may be set by bsd.own.mk or in a
+make configuration file to modify the behaviour of the system build
+process (default values are in brackets along with comments, if set by
+bsd.own.mk):
+
+EXPORTABLE_SYSTEM
+               Do not build /usr/src/domestic, even if it is present.
+
+SKEY           Compile in support for S/key authentication. [yes, set
+               unconditionally]
+
+KERBEROS       Compile in support for Kerberos 4 authentication.
+
+KERBEROS5      Compile in support for Kerberos 5 authentication.
+
+MANZ           Compress manual pages at installation time.
+
+SYS_INCLUDE    Copy or symlink kernel include files into /usr/include.
+               Possible values are "symlinks" or "copies" (which is
+               the same as the variable being unset).
+
+NOPROFILE      Do not build profiled versions of system libraries
+
+NOPIC          Do not build PIC versions of system libraries, and
+               do not build shared libraries.  [set if ${MACHINE_ARCH}
+               is "mips", "vax", "alpha" or "arm32", unset otherwise.]
+
+NOLINT         Do not build lint libraries. [set, set unconditionally]
+
+bsd.own.mk is generally useful when building your own Makefiles so that
+they use the same default owners etc. as the rest of the tree.
+
+=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
+
+The include file <bsd.prog.mk> handles building programs from one or
+more source files, along with their manual pages.  It has a limited number
+of suffixes, consistent with the current needs of the BSD tree.
+
+It has eight targets:
+
+       all:
+               build the program and its manual page
+       clean:
+               remove the program, any object files and the files a.out,
+               Errs, errs, mklog, and core.
+       cleandir:
+               remove all of the files removed by the target clean, as
+               well as .depend, tags, and any manual pages.
+       depend:
+               make the dependencies for the source files, and store
+               them in the file .depend.
+       includes:
+               install any header files.
+       install:
+               install the program and its manual pages; if the Makefile
+               does not itself define the target install, the targets
+               beforeinstall and afterinstall may also be used to cause
+               actions immediately before and after the install target
+               is executed.
+       lint:
+               run lint on the source files
+       tags:
+               create a tags file for the source files.
+
+It sets/uses the following variables:
+
+BINGRP         Binary group.
+
+BINOWN         Binary owner.
+
+BINMODE                Binary mode.
+
+CLEANFILES     Additional files to remove for the clean and cleandir targets.
+
+COPTS          Additional flags to the compiler when creating C objects.
+
+HIDEGAME       If HIDEGAME is defined, the binary is installed in
+               /usr/games/hide, and a symbolic link is created to
+               /usr/games/dm.
+
+LDADD          Additional loader objects.  Usually used for libraries.
+               For example, to load with the compatibility and utility
+               libraries, use:
+
+                       LDADD+=-lutil -lcompat
+
+LDFLAGS                Additional loader flags.
+
+LINKS          The list of binary links; should be full pathnames, the
+               linked-to file coming first, followed by the linked
+               file.  The files are hard-linked.  For example, to link
+               /bin/test and /bin/[, use:
+
+                       LINKS=  ${DESTDIR}/bin/test ${DESTDIR}/bin/[
+
+MAN            Manual pages (should end in .1 - .9).  If no MAN variable is
+               defined, "MAN=${PROG}.1" is assumed.
+
+PROG           The name of the program to build.  If not supplied, nothing
+               is built.
+
+SRCS           List of source files to build the program.  If PROG is not
+               defined, it's assumed to be ${PROG}.c.
+
+DPADD          Additional dependencies for the program.  Usually used for
+               libraries.  For example, to depend on the compatibility and
+               utility libraries use:
+
+                       DPADD+=${LIBCOMPAT} ${LIBUTIL}
+
+               The following libraries are predefined for DPADD:
+
+                       LIBC            /lib/libc.a
+                       LIBCOMPAT       /usr/lib/libcompat.a
+                       LIBCRYPT        /usr/lib/libcrypt.a
+                       LIBCURSES       /usr/lib/libcurses.a
+                       LIBDBM          /usr/lib/libdbm.a
+                       LIBDES          /usr/lib/libdes.a
+                       LIBL            /usr/lib/libl.a
+                       LIBKDB          /usr/lib/libkdb.a
+                       LIBKRB          /usr/lib/libkrb.a
+                       LIBKVM          /usr/lib/libkvm.a
+                       LIBM            /usr/lib/libm.a
+                       LIBMP           /usr/lib/libmp.a
+                       LIBPC           /usr/lib/libpc.a
+                       LIBPLOT         /usr/lib/libplot.a
+                       LIBRPC          /usr/lib/sunrpc.a
+                       LIBTERM         /usr/lib/libterm.a
+                       LIBUTIL         /usr/lib/libutil.a
+
+SHAREDSTRINGS  If defined, a new .c.o rule is used that results in shared
+               strings, using xstr(1). Note that this will not work with
+               parallel makes.
+
+STRIP          The flag passed to the install program to cause the binary
+               to be stripped.
+
+SUBDIR         A list of subdirectories that should be built as well.
+               Each of the targets will execute the same target in the
+               subdirectories.
+
+The include file <bsd.prog.mk> includes the file named "../Makefile.inc"
+if it exists, as well as the include file <bsd.man.mk>.
+
+Some simple examples:
+
+To build foo from foo.c with a manual page foo.1, use:
+
+       PROG=   foo
+
+       .include <bsd.prog.mk>
+
+To build foo from foo.c with a manual page foo.2, add the line:
+
+       MAN=    foo.2
+
+If foo does not have a manual page at all, add the line:
+
+       NOMAN=  noman
+
+If foo has multiple source files, add the line:
+
+       SRCS=   a.c b.c c.c d.c
+
+=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
+
+The include file <bsd.subdir.mk> contains the default targets for building
+subdirectories.  It has the same eight targets as <bsd.prog.mk>: all, 
+clean, cleandir, depend, includes, install, lint, and tags.  For all of
+the directories listed in the variable SUBDIRS, the specified directory 
+will be visited and the target made.  There is also a default target which
+allows the command "make subdir" where subdir is any directory listed in
+the variable SUBDIRS.
+
+=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
+
+The include file <bsd.sys.mk> is used by <bsd.prog.mk> and
+<bsd.lib.mk>.  It contains overrides that are used when building
+the NetBSD source tree.  For instance, if "PARALLEL" is defined by
+the program/library Makefile, it includes a set of rules for lex and
+yacc that allow multiple lex and yacc targets to be built in parallel.
+
+=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=-=
+
+The include file <bsd.lib.mk> has support for building libraries.  It has
+the same eight targets as <bsd.prog.mk>: all, clean, cleandir, depend,
+includes, install, lint, and tags.  It has a limited number of suffixes,
+consistent with the current needs of the BSD tree.
+
+It sets/uses the following variables:
+
+LIB            The name of the library to build.
+
+LIBDIR         Target directory for libraries.
+
+LINTLIBDIR     Target directory for lint libraries.
+
+LIBGRP         Library group.
+
+LIBOWN         Library owner.
+
+LIBMODE                Library mode.
+
+LDADD          Additional loader objects.
+
+MAN            The manual pages to be installed (use a .1 - .9 suffix).
+
+SRCS           List of source files to build the library.  Suffix types
+               .s, .c, and .f are supported.  Note, .s files are preferred
+               to .c files of the same name.  (This is not the default for
+               versions of make.)
+
+The include file <bsd.lib.mk> includes the file named "../Makefile.inc"
+if it exists, as well as the include file <bsd.man.mk>.
+
+It has rules for building profiled objects; profiled libraries are
+built by default.
+
+Libraries are ranlib'd when made.
diff --git a/contrib/bmake/mk/auto.dep.mk b/contrib/bmake/mk/auto.dep.mk
new file mode 100644 (file)
index 0000000..bb2d4c1
--- /dev/null
@@ -0,0 +1,64 @@
+#
+# RCSid:
+#      $Id: auto.dep.mk,v 1.2 2010/04/19 17:37:19 sjg Exp $
+#
+#      @(#) Copyright (c) 2010, Simon J. Gerraty
+#
+#      This file is provided in the hope that it will
+#      be of use.  There is absolutely NO WARRANTY.
+#      Permission to copy, redistribute or otherwise
+#      use this file is hereby granted provided that 
+#      the above copyright notice and this notice are
+#      left intact. 
+#      
+#      Please send copies of changes and bug-fixes to:
+#      sjg@crufty.net
+#
+
+# This module provides automagic dependency generation along the
+# lines suggested in the GNU make.info
+
+# set MKDEP=auto.dep and dep.mk will include us
+
+# This version differs from autodep.mk, in that 
+# we use ${.TARGET:T}.d rather than ${.TARGET:T:R}.d
+# this makes it simpler to get the args to -MF and -MT right
+# and ensure we can simply include all the .d files.
+# 
+# However suffix rules do not work with something like .o.d so we
+# don't even try to handle 'make depend' gracefully.
+# dep.mk will handle that itself.
+#
+.if !target(__${.PARSEFILE}__)
+__${.PARSEFILE}__:
+
+# this what bmake > 20100401 will look for
+.MAKE.DEPENDFILE ?= .depend
+
+# set this to -MMD to ignore /usr/include
+# actually it ignores <> so may not be a great idea
+CFLAGS_MD ?= -MD 
+# -MF etc not available on all gcc versions.
+CFLAGS_MF ?= -MF ${.TARGET:T}.d -MT ${.TARGET:T}
+CFLAGS += ${CFLAGS_MD} ${CFLAGS_MF}
+CXXFLAGS += ${CFLAGS_MD} ${CFLAGS_MF}
+
+CLEANFILES += .depend ${.MAKE.DEPENDFILE} *.d
+
+# skip generating dependfile for misc targets
+.if ${.TARGETS:Uall:M*all} != ""
+.END:  ${.MAKE.DEPENDFILE}
+.endif
+
+# doing 'make depend' isn't a big win with this model
+.if !target(depend)
+depend: ${.MAKE.DEPENDFILE}
+.endif
+
+# this is trivial
+${.MAKE.DEPENDFILE}: ${OBJS} ${POBJS} ${SOBJS}
+       -@for f in ${.ALLSRC:M*o:T:O:u:%=%.d}; do \
+               echo ".-include \"$$f\""; \
+       done > $@
+
+.endif
diff --git a/contrib/bmake/mk/auto.obj.mk b/contrib/bmake/mk/auto.obj.mk
new file mode 100644 (file)
index 0000000..adccd4b
--- /dev/null
@@ -0,0 +1,56 @@
+# $Id: auto.obj.mk,v 1.8 2011/08/08 17:35:20 sjg Exp $
+#
+#      @(#) Copyright (c) 2004, Simon J. Gerraty
+#
+#      This file is provided in the hope that it will
+#      be of use.  There is absolutely NO WARRANTY.
+#      Permission to copy, redistribute or otherwise
+#      use this file is hereby granted provided that 
+#      the above copyright notice and this notice are
+#      left intact. 
+#      
+#      Please send copies of changes and bug-fixes to:
+#      sjg@crufty.net
+#
+
+ECHO_TRACE ?= echo
+
+.ifndef Mkdirs
+# A race condition in some versions of mkdir, means that it can bail 
+# if another process made a dir that mkdir expected to.
+# We repeat the mkdir -p a number of times to try and work around this.
+# We stop looping as soon as the dir exists.
+# If we get to the end of the loop, a plain mkdir will issue an error.
+Mkdirs= Mkdirs() { \
+       for d in $$*; do \
+               for i in 1 2 3 4 5 6; do \
+                       mkdir -p $$d; \
+                       test -d $$d && return 0; \
+               done > /dev/null 2>&1; \
+               mkdir $$d || exit $$?; \
+       done; }
+.endif
+
+# if MKOBJDIRS is set to auto (and NOOBJ isn't defined) do some magic...
+# This will automatically create objdirs as needed.
+# Skip it if we are just doing 'clean'.
+.if !defined(NOOBJ) && !defined(NO_OBJ) && ${MKOBJDIRS:Uno} == auto
+# Use __objdir here so it is easier to tweak without impacting
+# the logic.
+__objdir?= ${MAKEOBJDIR}
+.if ${.OBJDIR} != ${__objdir}
+# We need to chdir, make the directory if needed
+.if !exists(${__objdir}/) && \
+       (${.TARGETS} == "" || ${.TARGETS:Nclean*:N*clean:Ndestroy*} != "")
+# This will actually make it... 
+__objdir_made != echo ${__objdir}/; umask ${OBJDIR_UMASK:U002}; \
+        ${ECHO_TRACE} "[Creating objdir ${__objdir}...]" >&2; \
+        ${Mkdirs}; Mkdirs ${__objdir}
+.endif
+# This causes make to use the specified directory as .OBJDIR
+.OBJDIR: ${__objdir}
+.if ${.OBJDIR} != ${__objdir} && ${__objdir_made:Uno:M${__objdir}/*} != ""
+.error could not use ${__objdir}
+.endif
+.endif
+.endif
diff --git a/contrib/bmake/mk/autoconf.mk b/contrib/bmake/mk/autoconf.mk
new file mode 100644 (file)
index 0000000..573a715
--- /dev/null
@@ -0,0 +1,78 @@
+# $Id: autoconf.mk,v 1.8 2012/11/19 05:37:48 sjg Exp $
+#
+#      @(#) Copyright (c) 1996-2009, Simon J. Gerraty
+#
+#      This file is provided in the hope that it will
+#      be of use.  There is absolutely NO WARRANTY.
+#      Permission to copy, redistribute or otherwise
+#      use this file is hereby granted provided that 
+#      the above copyright notice and this notice are
+#      left intact. 
+#      
+#      Please send copies of changes and bug-fixes to:
+#      sjg@crufty.net
+#
+
+.NOPATH:       config.h config.status
+
+.if !target(config.h)
+config.h:      ${.CURDIR}/config.h.in config.status
+       ./config.status
+.endif
+
+.if !target(config.status)
+# avoid the targets behaving differently
+.if exists(${.OBJDIR}/config.status)
+config.status: config.recheck
+.else
+config.status:  config.gen
+.endif
+
+config.recheck: config.h.in ${.CURDIR}/configure
+       ./config.status --recheck
+       @touch $@
+
+config.gen: config.h.in ${.CURDIR}/configure
+       CC="${CC} ${CCMODE}" ${.CURDIR}/configure --no-create ${CONFIGURE_ARGS}
+       @touch $@ config.recheck
+
+CLEANFILES+= config.recheck config.gen config.status *.meta
+.endif
+
+# avoid things blowing up if these are not here...
+# this is not quite per the autoconf manual,
+# and is extremely convoluted - but all utterly necessary!
+
+.if make(autoconf-in) || make(configure) || make(config.h.in) || ${AUTO_AUTOCONF:Uno:tl} == "yes"
+AUTOCONF ?= autoconf
+AUTOHEADER ?= autoheader
+
+# expand it to a full path 
+AUTOCONF := ${AUTOCONF:${M_whence}}
+
+.if exists(${AUTOCONF})
+
+.PRECIOUS: configure config.h.in config.status
+
+ACLOCAL =
+ACCONFIG =
+
+.if exists(${.CURDIR}/aclocal.m4)
+ACLOCAL += aclocal.m4
+.endif
+# use of acconfig.h is deprecated!
+.if exists(${.CURDIR}/acconfig.h)
+ACCONFIG += acconfig.h
+.endif
+
+config.h.in:   ${.CURDIR}/configure.in ${ACCONFIG}
+       (cd ${.CURDIR} && ${AUTOHEADER})
+
+configure:     ${.CURDIR}/configure.in ${ACLOCAL}
+       (cd ${.CURDIR} && ${AUTOCONF})
+
+AUTOCONF_INPUTS += configure
+autoconf-input:        ${AUTOCONF_INPUTS}
+
+.endif
+.endif
diff --git a/contrib/bmake/mk/autodep.mk b/contrib/bmake/mk/autodep.mk
new file mode 100644 (file)
index 0000000..744770f
--- /dev/null
@@ -0,0 +1,216 @@
+#
+# RCSid:
+#      $Id: autodep.mk,v 1.32 2010/04/19 17:37:56 sjg Exp $
+#
+#      @(#) Copyright (c) 1999-2010, Simon J. Gerraty
+#
+#      This file is provided in the hope that it will
+#      be of use.  There is absolutely NO WARRANTY.
+#      Permission to copy, redistribute or otherwise
+#      use this file is hereby granted provided that 
+#      the above copyright notice and this notice are
+#      left intact. 
+#      
+#      Please send copies of changes and bug-fixes to:
+#      sjg@crufty.net
+
+# This module provides automagic dependency generation along the
+# lines suggested in the GNU make.info
+# The depend target is mainly for backwards compatability,
+# dependencies are normally updated as part of compilation.
+
+# set MKDEP=autodep and dep.mk will include us
+.if !target(__${.PARSEFILE}__)
+__${.PARSEFILE}__:
+
+# different versions of bsd.dep.mk use these
+MKDEP=autodep
+MKDEPCMD=autodep
+
+DEPENDFILE?= .depend
+.for d in ${DEPENDFILE:N.depend}
+# bmake only groks .depend
+.-include "$d"
+.endfor
+
+# it does nothing if SRCS is not defined or is empty
+.if defined(SRCS) && !empty(SRCS)
+DEPSRCS?=${SRCS}
+__depsrcs=${DEPSRCS:M*.c}
+__depsrcs+=${DEPSRCS:M*.y}
+__depsrcs+=${DEPSRCS:M*.l}
+__depsrcs+=${DEPSRCS:M*.s}
+__depsrcs+=${DEPSRCS:M*.S}
+__depsrcs+=${DEPSRCS:M*.cc}
+__depsrcs+=${DEPSRCS:M*.cpp}
+__depsrcs+=${DEPSRCS:M*.C}
+__depsrcs+=${DEPSRCS:M*.cxx}
+__depsrcs+=${DEPSRCS:M*.pc}
+
+.for s in ${__depsrcs}
+${s:T:R}.d:    $s
+.endfor
+
+__depsrcs:=${__depsrcs:T:R:S/$/.d/g}
+# we also need to handle makefiles where the .d's from __depsrcs 
+# don't  match those from OBJS
+# we avoid using := here, since the modifier applied to OBJS
+# can cause trouble if there are any undefined vars in OBJS.
+__dependsrcsx?= ${__depsrcs} ${OBJS:S/.o/.d/}
+__dependsrcs= ${__dependsrcsx:O:u}
+
+# clean up any .c files we may have generated
+#__gensrcs:= ${DEPSRCS:M*.y} ${DEPSRCS:M*.l}
+#CLEANFILES+= ${__gensrcs:T:R:S/$/.c/g}
+
+# set this to -MMD to ignore /usr/include
+# actually it ignores <> so may not be a great idea
+CFLAGS_MD?=-MD 
+# -MF etc not available on all gcc versions.
+# we "fix" the .o later
+CFLAGS_MF?=-MF ${.TARGET:T:R}.d -MT ${.TARGET:T:R}.o
+CFLAGS+= ${CFLAGS_MD} ${CFLAGS_MF}
+RM?= rm
+
+# watch out for people who don't use CPPFLAGS
+CPPFLAGS_MD=${CFLAGS:M-[IUD]*} ${CPPFLAGS} 
+CXXFLAGS_MD=${CXXFLAGS:M-[IUD]*} ${CPPFLAGS} 
+
+# just in case these need to be different
+CC_MD?=${CC}
+CXX_MD?=${CXX}
+
+# so we can do an explicit make depend, but not otherwise
+.if make(depend)
+.SUFFIXES:     .d
+
+.if empty(CFLAGS_MD)
+.y.d:
+       @echo updating dependencies for $<
+       @${YACC} ${YFLAGS} $<
+       @${SHELL} -ec "${CC_MD} -M ${CPPFLAGS_MD} y.tab.c | sed '/:/s/^/$@ /' > $@" || { ${RM} -f y.tab.c $@; false; }
+       @${RM} -f y.tab.c
+
+.l.d:
+       @echo updating dependencies for $<
+       ${LEX} ${LFLAGS} $<
+       @${SHELL} -ec "${CC_MD} -M ${CPPFLAGS_MD} lex.yy.c | sed '/:/s/^/$@ /' > $@" || { ${RM} -f lex.yy.c $@; false; }
+       @${RM} -f lex.yy.c
+
+.c.d:
+       @echo updating dependencies for $<
+       @${SHELL} -ec "${CC_MD} -M ${CPPFLAGS_MD} $< | sed '/:/s/^/$@ /' > $@" || { ${RM} -f $@; false; }
+
+.s.d .S.d:
+       @echo updating dependencies for $<
+       @${SHELL} -ec "${CC_MD} -M ${CPPFLAGS_MD} ${AINC} $< | sed '/:/s/^/$@ /' > $@" || { ${RM} -f $@; false; }
+
+.cc.d .cpp.d .C.d .cxx.d:
+       @echo updating dependencies for $<
+       @${SHELL} -ec "${CXX_MD} -M ${CXXFLAGS_MD} $< | sed '/:/s/^/$@ /' > $@" || { ${RM} -f $@; false; }
+.else
+.y.d:
+       ${YACC} ${YFLAGS} $<
+       ${CC_MD} ${CFLAGS_MD:S/D//} ${CPPFLAGS_MD} y.tab.c > $@ || { ${RM} -f y.tab.c $@; false; }
+       ${RM} -f y.tab.c
+
+.l.d:
+       ${LEX} ${LFLAGS} $<
+       ${CC_MD} ${CFLAGS_MD:S/D//} ${CPPFLAGS_MD} lex.yy.c > $@ || { ${RM} -f lex.yy.c $@; false; }
+       ${RM} -f lex.yy.c
+
+.c.d:
+       ${CC_MD} ${CFLAGS_MD:S/D//} ${CPPFLAGS_MD} $< > $@ || { ${RM} -f $@; false; }
+
+.s.d .S.d:
+       ${CC_MD} ${CFLAGS_MD:S/D//} ${CPPFLAGS_MD} ${AINC} $< > $@ || { ${RM} -f $@; false; }
+
+.cc.d .cpp.d .C.d .cxx.d:
+       ${CXX_MD} ${CFLAGS_MD:S/D//} ${CXXFLAGS_MD} $< > $@ || { ${RM} -f $@; false; }
+.endif
+
+.if !target(depend)
+depend: beforedepend ${DEPENDFILE} afterdepend _SUBDIRUSE
+
+${DEPENDFILE}: ${DEPSRCS} ${__dependsrcs}
+.NOPATH:       ${__dependsrcs}
+.OPTIONAL:     ${__dependsrcs}
+.endif
+.endif                         # make(depend)
+
+.if empty(CFLAGS_MD)
+# make sure the .d's are generated/updated
+${PROG} ${_LIBS}:      ${DEPENDFILE}
+.endif
+
+.ORDER:        beforedepend ${DEPENDFILE} afterdepend
+
+.if ${.OBJDIR} != ${.CURDIR}
+__depfiles= *.d
+.else
+__depfiles= ${__dependsrcs}
+.endif
+
+DEPCLEANFILES= ${DEPENDFILE} ${__depfiles} y.tab.d *.tmp.d
+
+cleandir: cleanautodepend
+cleanautodepend:
+       ${RM} -f ${DEPCLEANFILES}
+
+CLEANFILES+= ${DEPCLEANFILES}
+
+.if defined(__dependsrcs) && !empty(__dependsrcs)
+.if make(depend) || !(make(clean*) || make(destroy*) || make(obj) || make(*install) || make(install-*))
+# this ensures we do the right thing if only building a shared or
+# profiled lib
+OBJ_EXTENSIONS?=.o .po .so .So
+MDLIB_SED= -e '/:/s,^\([^\.:]*\)\.[psS]*o,${OBJ_EXTENSIONS:S,^,\1,},'
+.ifdef NOMD_SED
+.ifdef LIB
+MD_SED=sed ${MDLIB_SED}
+.else
+MD_SED=cat
+.endif
+.else
+# arrange to put some variable names into ${DEPENDFILE}
+.ifdef LIB
+MD_SED=sed ${MDLIB_SED}
+.else
+MD_SED=sed
+.endif
+SUBST_DEPVARS+= SB TOP BACKING SRC SRCDIR BASE BASEDIR
+.for v in ${SUBST_DEPVARS}
+.if defined(${v}) && !empty(${v})
+MD_SED+= -e 's,${$v},$${$v},'
+.endif
+.endfor
+.endif
+.if (${MD_SED} == "sed")
+MD_SED=cat
+.endif
+
+# this will be done whenever make finishes successfully
+.if ${MAKE_VERSION:U0:[1]:C/.*-//} < 20050530
+.END:
+.else
+.END:  ${DEPENDFILE}
+# we do not want to trigger building .d's just use them if they exist
+${DEPENDFILE}: ${__dependsrcs:@d@${exists($d):?$d:}@}
+.endif
+       -@${MD_SED} ${__depfiles} > ${DEPENDFILE}.new 2> /dev/null && \
+       test -s ${DEPENDFILE}.new && mv ${DEPENDFILE}.new ${DEPENDFILE}; \
+       ${RM} -f ${DEPENDFILE}.new
+.endif
+.endif
+.else
+depend: beforedepend afterdepend _SUBDIRUSE
+.endif
+
+.if !target(beforedepend)
+beforedepend:
+.endif
+.if !target(afterdepend)
+afterdepend:
+.endif
+
+.endif
diff --git a/contrib/bmake/mk/dep.mk b/contrib/bmake/mk/dep.mk
new file mode 100644 (file)
index 0000000..b754500
--- /dev/null
@@ -0,0 +1,133 @@
+# $Id: dep.mk,v 1.16 2012/11/11 22:37:02 sjg Exp $
+
+.if !target(__${.PARSEFILE}__)
+__${.PARSEFILE}__:
+
+# handle Proc*C as well...
+.if defined(SRCS)
+.if !empty(SRCS:M*.pc)
+.include <proc.mk>
+.endif
+
+# it would be nice to be able to query .SUFFIXES
+OBJ_EXTENSIONS+= .o .po .lo .So
+
+# explicit dependencies help short-circuit .SUFFIX searches
+SRCS_DEP_FILTER+= N*.[hly]
+.for s in ${SRCS:${SRCS_DEP_FILTER:O:u:ts:}}
+.for e in ${OBJ_EXTENSIONS:O:u}
+.if !target(${s:T:R}$e)
+${s:T:R}$e: $s
+.endif
+.endfor
+.endfor
+.endif
+
+.if exists(/usr/bin/mkdep)
+MKDEP_CMD?=    mkdep
+.elif exists(/usr/local/share/bin/mkdeps.sh)
+MKDEP_CMD?=    /usr/local/share/bin/mkdeps.sh -N
+.endif
+MKDEP_CMD?=    mkdep
+
+MKDEP ?= ${MKDEP_CMD}
+
+.NOPATH:       .depend
+
+.if ${MKDEP} == "auto.dep" && make(depend)
+# auto.dep.mk does not "do" depend
+MK_AUTODEP= no
+.endif
+
+.if ${MK_AUTODEP} == yes
+.if ${MKDEP:T:S,auto,,} != ${MKDEP:T}
+.include <${MKDEP}.mk>
+.else
+.include <autodep.mk>
+.endif
+.else
+.if ${MKDEP:T:S,auto,,} != ${MKDEP:T}
+MKDEP = ${MKDEP_CMD}
+.endif
+MKDEP_ENV_VARS += CC CXX
+.for v in ${MKDEP_ENV_VARS:O:u}
+.if !empty($v)
+MKDEP_ENV += $v='${$v}'
+.endif
+.endfor
+
+_MKDEP = ${MKDEP_ENV} ${MKDEP}
+
+# some of the rules involve .h sources, so remove them from mkdep line
+.if !target(depend)
+depend: beforedepend .depend _SUBDIRUSE afterdepend
+
+.if defined(SRCS)
+# libs can have too many SRCS for a single command line
+# so do them one at a time.
+.depend: ${SRCS} ${.PARSEDIR}/${.PASEFILE}
+       @rm -f .depend
+.ifdef LIB
+       @files="${.ALLSRC:M*.[sS]}"; \
+       set -x; for f in $$files; do ${_MKDEP} -a ${MKDEPFLAGS} \
+           ${CFLAGS:M-[ID]*} ${CPPFLAGS} ${AINC} $$f; done
+       @files="${.ALLSRC:M*.c} ${.ALLSRC:M*.pc:T:.pc=.c}"; \
+       set -x; for f in $$files; do ${_MKDEP} -a ${MKDEPFLAGS} \
+           ${CFLAGS:M-[ID]*} ${CPPFLAGS} $$f; done
+       @files="${.ALLSRC:M*.cc} ${.ALLSRC:M*.C} ${.ALLSRC:M*.cxx}"; \
+       set -x; for f in $$files; do ${_MKDEP} -a ${MKDEPFLAGS} \
+           ${CXXFLAGS:M-[ID]*} ${CPPFLAGS} $$f; done
+.else
+       @files="${.ALLSRC:M*.[Ss]}"; \
+       case "$$files" in *.[Ss]*) \
+         echo ${_MKDEP} -a ${MKDEPFLAGS} \
+           ${CFLAGS:M-[ID]*} ${CPPFLAGS} ${AINC} $$files; \
+         ${_MKDEP} -a ${MKDEPFLAGS} \
+           ${CFLAGS:M-[ID]*} ${CPPFLAGS} ${AINC} $$files;; \
+       esac
+       @files="${.ALLSRC:M*.c} ${.ALLSRC:M*.pc:T:.pc=.c}"; \
+       case "$$files" in *.c*) \
+         echo ${_MKDEP} -a ${MKDEPFLAGS} \
+           ${CFLAGS:M-[ID]*} ${CPPFLAGS} $$files; \
+         ${_MKDEP} -a ${MKDEPFLAGS} \
+           ${CFLAGS:M-[ID]*} ${CPPFLAGS} $$files;; \
+       esac
+       @files="${.ALLSRC:M*.cc} ${.ALLSRC:M*.C} ${.ALLSRC:M*.cxx}"; \
+       case "$$files" in *.[Cc]*) \
+         echo ${_MKDEP} -a ${MKDEPFLAGS} \
+           ${CXXFLAGS:M-[ID]*} ${CPPFLAGS} $$files; \
+         ${_MKDEP} -a ${MKDEPFLAGS} \
+           ${CXXFLAGS:M-[ID]*} ${CPPFLAGS} $$files;; \
+       esac
+.endif
+.else
+.depend:
+.endif
+.if !target(beforedepend)
+beforedepend:
+.endif
+.if !target(afterdepend)
+afterdepend:
+.endif
+.endif
+.endif
+
+.if !target(tags)
+.if defined(SRCS)
+tags: ${SRCS} _SUBDIRUSE
+       -cd ${.CURDIR}; ctags -f /dev/stdout ${.ALLSRC:N*.h} | \
+           sed "s;\${.CURDIR}/;;" > tags
+.else
+tags:
+.endif
+.endif
+
+.if defined(SRCS)
+cleandir: cleandepend
+.if !target(cleandepend)
+cleandepend:
+       rm -f .depend ${.CURDIR}/tags
+.endif
+.endif
+
+.endif
diff --git a/contrib/bmake/mk/dirdeps.mk b/contrib/bmake/mk/dirdeps.mk
new file mode 100644 (file)
index 0000000..e812416
--- /dev/null
@@ -0,0 +1,500 @@
+# $Id: dirdeps.mk,v 1.28 2013/03/25 21:11:43 sjg Exp $
+
+# Copyright (c) 2010-2013, Juniper Networks, Inc.
+# All rights reserved.
+# 
+# Redistribution and use in source and binary forms, with or without
+# modification, are permitted provided that the following conditions 
+# are met: 
+# 1. Redistributions of source code must retain the above copyright
+#    notice, this list of conditions and the following disclaimer. 
+# 2. Redistributions in binary form must reproduce the above copyright
+#    notice, this list of conditions and the following disclaimer in the
+#    documentation and/or other materials provided with the distribution.  
+# 
+# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
+# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
+# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
+# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
+# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
+# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
+# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
+# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
+# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
+
+# Much of the complexity here is for supporting cross-building.
+# If a tree does not support that, simply using plain Makefile.depend
+# should provide sufficient clue.
+# Otherwise the recommendation is to use Makefile.depend.${MACHINE}
+# as expected below.
+
+# Note: this file gets multiply included.
+# This is what we do with DIRDEPS
+
+# DIRDEPS:
+#      This is a list of directories - relative to SRCTOP, it is
+#      normally only of interest to .MAKE.LEVEL 0.
+#      In some cases the entry may be qualified with a .<machine>
+#      or .<target_spec> suffix (see TARGET_SPEC_VARS below),
+#      for example to force building something for the pseudo
+#      machines "host" or "common" regardless of current ${MACHINE}.
+#      
+#      All unqualified entries end up being qualified with .${TARGET_SPEC}
+#      and partially qualified (if TARGET_SPEC_VARS has multiple
+#      entries) are also expanded to a full .<target_spec>.
+#      The  _DIRDEPS_USE target uses the suffix to set TARGET_SPEC
+#      correctly when visiting each entry.
+#
+#      The fully qualified directory entries are used to construct a
+#      dependency graph that will drive the build later.
+#      
+#      Also, for each fully qualified directory target, we will search
+#      using ${.MAKE.DEPENDFILE_PREFERENCE} to find additional
+#      dependencies.  We use Makefile.depend (default value for
+#      .MAKE.DEPENDFILE_PREFIX) to refer to these makefiles to
+#      distinguish them from others.
+#      
+#      Each Makefile.depend file sets DEP_RELDIR to be the
+#      the RELDIR (path relative to SRCTOP) for its directory, and
+#      since each Makefile.depend file includes dirdeps.mk, this
+#      processing is recursive and results in .MAKE.LEVEL 0 learning the
+#      dependencies of the tree wrt the initial directory (_DEP_RELDIR).
+#
+# BUILD_AT_LEVEL0
+#      Indicates whether .MAKE.LEVEL 0 builds anything:
+#      if "no" sub-makes are used to build everything,
+#      if "yes" sub-makes are only used to build for other machines.
+#      It is best to use "no", but this can require fixing some
+#      makefiles to not do anything at .MAKE.LEVEL 0.
+#
+# TARGET_SPEC_VARS
+#      The default value is just MACHINE, and for most environments
+#      this is sufficient.  The _DIRDEPS_USE target actually sets
+#      both MACHINE and TARGET_SPEC to the suffix of the current
+#      target so that in the general case TARGET_SPEC can be ignored.
+#
+#      If more than MACHINE is needed then sys.mk needs to decompose
+#      TARGET_SPEC and set the relevant variables accordingly.
+#      It is important that MACHINE be included in and actually be
+#      the first member of TARGET_SPEC_VARS.  This allows other
+#      variables to be considered optional, and some of the treatment
+#      below relies on MACHINE being the first entry.
+#      Note: TARGET_SPEC cannot contain any '.'s so the target
+#      triple used by compiler folk won't work (directly anyway).
+#
+#      For example:
+#
+#              # Always list MACHINE first, 
+#              # other variables might be optional.
+#              TARGET_SPEC_VARS = MACHINE TARGET_OS
+#              .if ${TARGET_SPEC:Uno:M*,*} != ""
+#              _tspec := ${TARGET_SPEC:S/,/ /g}
+#              MACHINE := ${_tspec:[1]}
+#              TARGET_OS := ${_tspec:[2]}
+#              # etc.
+#              # We need to stop that TARGET_SPEC affecting any submakes
+#              # and deal with MACHINE=${TARGET_SPEC} in the environment.
+#              TARGET_SPEC =
+#              # export but do not track
+#              .export-env TARGET_SPEC 
+#              .export ${TARGET_SPEC_VARS}
+#              .for v in ${TARGET_SPEC_VARS:O:u}
+#              .if empty($v)
+#              .undef $v
+#              .endif
+#              .endfor
+#              .endif
+#              # make sure we know what TARGET_SPEC is
+#              # as we may need it to find Makefile.depend*
+#              TARGET_SPEC = ${TARGET_SPEC_VARS:@v@${$v:U}@:ts,}
+#      
+
+.if ${.MAKE.LEVEL} == 0
+# only the first instance is interested in all this
+
+# First off, we want to know what ${MACHINE} to build for.
+# This can be complicated if we are using a mixture of ${MACHINE} specific
+# and non-specific Makefile.depend*
+
+.if !target(_DIRDEP_USE)
+# do some setup we only n