Fix regression from r289734 that caused crunchgen "subdirs" to not be
properly recursed. The .for loop was defining a ${__dir} variable that was being set at a different evaluation time than the target itself, so every 'cd ${__dir}' became the last value that was in ${__dir}. This resulted in 'make obj' not properly being ran in the tree that would leave .depend files scattered around when 'make all' was ran in rescue/. To fix this, define a CRUNCH_SRCDIR_* for every prog if it does not already have one and then use that variable in every relevant place. This allows simplifying some logic as well. Reported by: emaste X-MFC-With: r289734 MFC after: 3 weeks Sponsored by: EMC / Isilon Storage Division
This commit is contained in:
parent
f11412f79e
commit
fab547dc0c
@ -50,15 +50,18 @@ CLEANFILES+= ${CONF} *.o *.lo *.c *.mk *.cache *.a *.h
|
|||||||
# Don't try to extract debug info from ${PROG}.
|
# Don't try to extract debug info from ${PROG}.
|
||||||
MK_DEBUG_FILES= no
|
MK_DEBUG_FILES= no
|
||||||
|
|
||||||
|
# Set a default SRCDIR for each for simpler handling below.
|
||||||
|
.for D in ${CRUNCH_SRCDIRS}
|
||||||
|
.for P in ${CRUNCH_PROGS_${D}}
|
||||||
|
CRUNCH_SRCDIR_${P}?= ${.CURDIR}/../../${D}/${P}
|
||||||
|
.endfor
|
||||||
|
.endfor
|
||||||
|
|
||||||
# Program names and their aliases contribute hardlinks to 'rescue' executable,
|
# Program names and their aliases contribute hardlinks to 'rescue' executable,
|
||||||
# except for those that get suppressed.
|
# except for those that get suppressed.
|
||||||
.for D in ${CRUNCH_SRCDIRS}
|
.for D in ${CRUNCH_SRCDIRS}
|
||||||
.for P in ${CRUNCH_PROGS_${D}}
|
.for P in ${CRUNCH_PROGS_${D}}
|
||||||
.ifdef CRUNCH_SRCDIR_${P}
|
|
||||||
${OUTPUTS}: ${CRUNCH_SRCDIR_${P}}/Makefile
|
${OUTPUTS}: ${CRUNCH_SRCDIR_${P}}/Makefile
|
||||||
.else
|
|
||||||
${OUTPUTS}: ${.CURDIR}/../../${D}/${P}/Makefile
|
|
||||||
.endif
|
|
||||||
.if ${CRUNCH_GENERATE_LINKS} == "yes"
|
.if ${CRUNCH_GENERATE_LINKS} == "yes"
|
||||||
.ifndef CRUNCH_SUPPRESS_LINK_${P}
|
.ifndef CRUNCH_SUPPRESS_LINK_${P}
|
||||||
LINKS+= ${BINDIR}/${PROG} ${BINDIR}/${P}
|
LINKS+= ${BINDIR}/${PROG} ${BINDIR}/${P}
|
||||||
@ -89,11 +92,7 @@ ${CONF}: Makefile
|
|||||||
.for D in ${CRUNCH_SRCDIRS}
|
.for D in ${CRUNCH_SRCDIRS}
|
||||||
.for P in ${CRUNCH_PROGS_${D}}
|
.for P in ${CRUNCH_PROGS_${D}}
|
||||||
echo progs ${P} >>${.TARGET}
|
echo progs ${P} >>${.TARGET}
|
||||||
.ifdef CRUNCH_SRCDIR_${P}
|
|
||||||
echo special ${P} srcdir ${CRUNCH_SRCDIR_${P}} >>${.TARGET}
|
echo special ${P} srcdir ${CRUNCH_SRCDIR_${P}} >>${.TARGET}
|
||||||
.else
|
|
||||||
echo special ${P} srcdir ${.CURDIR}/../../${D}/${P} >>${.TARGET}
|
|
||||||
.endif
|
|
||||||
.ifdef CRUNCH_BUILDOPTS_${P}
|
.ifdef CRUNCH_BUILDOPTS_${P}
|
||||||
echo special ${P} buildopts DIRPRFX=${DIRPRFX}${P}/ \
|
echo special ${P} buildopts DIRPRFX=${DIRPRFX}${P}/ \
|
||||||
${CRUNCH_BUILDOPTS_${P}} >>${.TARGET}
|
${CRUNCH_BUILDOPTS_${P}} >>${.TARGET}
|
||||||
@ -138,13 +137,8 @@ build-tools: build-tools-${_tool}
|
|||||||
.for __target in clean cleandepend cleandir obj objlink
|
.for __target in clean cleandepend cleandir obj objlink
|
||||||
.for D in ${CRUNCH_SRCDIRS}
|
.for D in ${CRUNCH_SRCDIRS}
|
||||||
.for P in ${CRUNCH_PROGS_${D}}
|
.for P in ${CRUNCH_PROGS_${D}}
|
||||||
.ifdef CRUNCH_SRCDIR_${P}
|
|
||||||
__dir= ${CRUNCH_SRCDIR_${P}}
|
|
||||||
.else
|
|
||||||
__dir= ${.CURDIR}/../../${D}/${P}
|
|
||||||
.endif
|
|
||||||
${__target}_crunchdir_${P}: .PHONY .MAKE
|
${__target}_crunchdir_${P}: .PHONY .MAKE
|
||||||
${_+_}cd ${__dir} && \
|
${_+_}cd ${CRUNCH_SRCDIR_${P}} && \
|
||||||
${CRUNCHENV} MAKEOBJDIRPREFIX=${CANONICALOBJDIR} ${MAKE} \
|
${CRUNCHENV} MAKEOBJDIRPREFIX=${CANONICALOBJDIR} ${MAKE} \
|
||||||
DIRPRFX=${DIRPRFX}${P}/ ${CRUNCH_BUILDOPTS} ${__target}
|
DIRPRFX=${DIRPRFX}${P}/ ${CRUNCH_BUILDOPTS} ${__target}
|
||||||
${__target}: ${__target}_crunchdir_${P}
|
${__target}: ${__target}_crunchdir_${P}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user