c6ab7e7128
Usage: ${MAKEDIRTARGET} dir target [params] Runs "cd $${dir} && ${MAKE} [params] $${target}", displaying a "pretty" message whilst doing so. Use MAKEDIRPREFIX to implement the __recurse .USE macro in <bsd.subdir.mk>
43 lines
930 B
Makefile
43 lines
930 B
Makefile
# $NetBSD: bsd.subdir.mk,v 1.48 2004/04/13 12:25:03 lukem Exp $
|
|
# @(#)bsd.subdir.mk 8.1 (Berkeley) 6/8/93
|
|
|
|
.include <bsd.init.mk>
|
|
|
|
.for dir in ${SUBDIR}
|
|
.if exists(${dir}.${MACHINE})
|
|
__REALSUBDIR+=${dir}.${MACHINE}
|
|
.else
|
|
__REALSUBDIR+=${dir}
|
|
.endif
|
|
.endfor
|
|
|
|
__recurse: .USE
|
|
@${MAKEDIRTARGET} ${.TARGET:C/^[^-]*-//} ${.TARGET:C/-.*$//}
|
|
|
|
.if make(cleandir)
|
|
__RECURSETARG= ${TARGETS:Nclean}
|
|
clean:
|
|
.else
|
|
__RECURSETARG= ${TARGETS}
|
|
.endif
|
|
|
|
# for obscure reasons, we can't do a simple .if ${dir} == ".WAIT"
|
|
# but have to assign to __TARGDIR first.
|
|
.for targ in ${__RECURSETARG}
|
|
.for dir in ${__REALSUBDIR}
|
|
__TARGDIR := ${dir}
|
|
.if ${__TARGDIR} == ".WAIT"
|
|
SUBDIR_${targ} += .WAIT
|
|
.elif !commands(${targ}-${dir})
|
|
${targ}-${dir}: .PHONY .MAKE __recurse
|
|
SUBDIR_${targ} += ${targ}-${dir}
|
|
.endif
|
|
.endfor
|
|
.if defined(__REALSUBDIR)
|
|
subdir-${targ}: .PHONY ${SUBDIR_${targ}}
|
|
${targ}: subdir-${targ}
|
|
.endif
|
|
.endfor
|
|
|
|
${TARGETS}: # ensure existence
|