mirror of
https://github.com/freebsd/freebsd-src
synced 2024-07-21 10:19:04 +00:00
![Simon J. Gerraty](/assets/img/avatar_default.png)
Changes since 20181221 are mostly portability related hence the large gap in versions imported. There are however some bug fixes, and a rework of filemon handling. In NetBSD make/filemon/filemon_ktrace.c allows use of fktrace and elimination of filemon(4) which has not had the TLC it needs. FreeBSD filemon(4) is in much better shape, so bmake/filemon/filemon_dev.c allows use of that, with a bit less overhead than the ktrace model. Summary of changes from ChangeLog o str.c: empty string does not match % pattern plus unit-test changes o var.c: import handling of old sysV style modifier using '%' o str.c: refactor brk_string o meta.c: meta_oodate, CHECK_VALID_META is too aggressive for CMD a blank command is perfectly valid. o meta.c: meta_oodate, check for corrupted meta file earlier and more often. * meta.c: meta_compat_parent check for USE_FILEMON patch from Soeren Tempel o meta.c: fix compat mode, need to call meta_job_output() o job.c: extra fds for meta mode not needed if using filemon_dev o meta.c: avoid passing NULL to filemon_*() when meta_needed() returns FALSE. o filemon/filemon_{dev,ktrace}.c: allow selection of filemon implementation. filemon_dev.c uses the kernel module while filemon_ktrace.c leverages the fktrace api available in NetBSD. filemon_ktrace.c can hopefully form the basis for adding support for other tracing mechanisms such as strace on Linux. o meta.c: when target is out-of-date per normal make rules record value of .OODATE in meta file. o parse.c: don't pass NULL to realpath(3) some versions cannot handle it. o parse.c: ParseDoDependency: free paths rather than assert plus more unit-tests
54 lines
1.1 KiB
Makefile
54 lines
1.1 KiB
Makefile
# $Id: forloop.mk,v 1.1.1.2 2020/05/05 00:54:40 sjg Exp $
|
|
|
|
all: for-loop
|
|
|
|
LIST = one "two and three" four "five"
|
|
|
|
.if make(for-fail)
|
|
for-fail:
|
|
|
|
XTRA_LIST = xtra
|
|
.else
|
|
|
|
.for x in ${LIST}
|
|
X!= echo 'x=$x' >&2; echo
|
|
.endfor
|
|
|
|
CFL = -I/this -I"This or that" -Ithat "-DTHIS=\"this and that\""
|
|
cfl=
|
|
.for x in ${CFL}
|
|
X!= echo 'x=$x' >&2; echo
|
|
.if empty(cfl)
|
|
cfl= $x
|
|
.else
|
|
cfl+= $x
|
|
.endif
|
|
.endfor
|
|
X!= echo 'cfl=${cfl}' >&2; echo
|
|
|
|
.if ${cfl} != ${CFL}
|
|
.error ${.newline}'${cfl}' != ${.newline}'${CFL}'
|
|
.endif
|
|
|
|
.for a b in ${EMPTY}
|
|
X!= echo 'a=$a b=$b' >&2; echo
|
|
.endfor
|
|
|
|
# Since at least 1993, iteration stops at the first newline.
|
|
# Back then, the .newline variable didn't exist, therefore it was unlikely
|
|
# that a newline ever occured.
|
|
.for var in a${.newline}b${.newline}c
|
|
X!= echo 'newline-item=('${var:Q}')' 1>&2; echo
|
|
.endfor
|
|
|
|
.endif # for-fail
|
|
|
|
.for a b in ${LIST} ${LIST:tu} ${XTRA_LIST}
|
|
X!= echo 'a=$a b=$b' >&2; echo
|
|
.endfor
|
|
|
|
for-loop:
|
|
@echo We expect an error next:
|
|
@(cd ${.CURDIR} && ${.MAKE} -f ${MAKEFILE} for-fail) && \
|
|
{ echo "Oops that should have failed!"; exit 1; } || echo OK
|