mirror of
https://git.FreeBSD.org/src.git
synced 2025-01-11 14:10:34 +00:00
bd808d4133
a kludge. However, it also effectively works around the issues for high -j builds on systems that do not have the rm fixes. A better fix would be to rmdir here, and fix the places where we're sloppy and not list all the files we create in CLEANFILES, should anybody have the time to chase them all to ground.
142 lines
3.5 KiB
Makefile
142 lines
3.5 KiB
Makefile
# $FreeBSD$
|
|
#
|
|
# The include file <bsd.obj.mk> handles creating the 'obj' directory
|
|
# and cleaning up object files, etc.
|
|
#
|
|
# +++ variables +++
|
|
#
|
|
# CLEANDIRS Additional directories to remove for the clean target.
|
|
#
|
|
# CLEANFILES Additional files to remove for the clean target.
|
|
#
|
|
# MAKEOBJDIR A pathname for the directory where the targets
|
|
# are built. Note: MAKEOBJDIR is an *environment* variable
|
|
# and works properly only if set as an environment variable,
|
|
# not as a global or command line variable!
|
|
#
|
|
# E.g. use `env MAKEOBJDIR=temp-obj make'
|
|
#
|
|
# MAKEOBJDIRPREFIX Specifies somewhere other than /usr/obj to root the object
|
|
# tree. Note: MAKEOBJDIRPREFIX is an *environment* variable
|
|
# and works properly only if set as an environment variable,
|
|
# not as a global or command line variable!
|
|
#
|
|
# E.g. use `env MAKEOBJDIRPREFIX=/somewhere/obj make'
|
|
#
|
|
# NO_OBJ Do not create object directories. This should not be set
|
|
# if anything is built.
|
|
#
|
|
# +++ targets +++
|
|
#
|
|
# clean:
|
|
# remove ${CLEANFILES}; remove ${CLEANDIRS} and all contents.
|
|
#
|
|
# cleandir:
|
|
# remove the build directory (and all its contents) created by obj
|
|
#
|
|
# obj:
|
|
# create build directory.
|
|
#
|
|
|
|
.if !target(__<bsd.obj.mk>__)
|
|
__<bsd.obj.mk>__:
|
|
.include <bsd.own.mk>
|
|
|
|
.if defined(MAKEOBJDIRPREFIX)
|
|
CANONICALOBJDIR:=${MAKEOBJDIRPREFIX}${.CURDIR}
|
|
.elif defined(MAKEOBJDIR) && ${MAKEOBJDIR:M/*} != ""
|
|
CANONICALOBJDIR:=${MAKEOBJDIR}
|
|
.else
|
|
CANONICALOBJDIR:=/usr/obj${.CURDIR}
|
|
.endif
|
|
|
|
#
|
|
# Warn of unorthodox object directory.
|
|
#
|
|
# The following directories are tried in order for ${.OBJDIR}:
|
|
#
|
|
# 1. ${MAKEOBJDIRPREFIX}/`pwd`
|
|
# 2. ${MAKEOBJDIR}
|
|
# 3. obj.${MACHINE}
|
|
# 4. obj
|
|
# 5. /usr/obj/`pwd`
|
|
# 6. ${.CURDIR}
|
|
#
|
|
# If ${.OBJDIR} is constructed using canonical cases 1 or 5, or
|
|
# case 2 (using MAKEOBJDIR), don't issue a warning. Otherwise,
|
|
# issue a warning differentiating between cases 6 and (3 or 4).
|
|
#
|
|
objwarn:
|
|
.if !defined(NO_OBJ) && ${.OBJDIR} != ${CANONICALOBJDIR} && \
|
|
!(defined(MAKEOBJDIRPREFIX) && exists(${CANONICALOBJDIR}/)) && \
|
|
!(defined(MAKEOBJDIR) && exists(${MAKEOBJDIR}/))
|
|
.if ${.OBJDIR} == ${.CURDIR}
|
|
@${ECHO} "Warning: Object directory not changed from original ${.CURDIR}"
|
|
.elif exists(${.CURDIR}/obj.${MACHINE}/) || exists(${.CURDIR}/obj/)
|
|
@${ECHO} "Warning: Using ${.OBJDIR} as object directory instead of\
|
|
canonical ${CANONICALOBJDIR}"
|
|
.endif
|
|
.endif
|
|
|
|
.if !defined(NO_OBJ)
|
|
.if !target(obj)
|
|
obj: .PHONY
|
|
@if ! test -d ${CANONICALOBJDIR}/; then \
|
|
mkdir -p ${CANONICALOBJDIR}; \
|
|
if ! test -d ${CANONICALOBJDIR}/; then \
|
|
${ECHO} "Unable to create ${CANONICALOBJDIR}."; \
|
|
exit 1; \
|
|
fi; \
|
|
${ECHO} "${CANONICALOBJDIR} created for ${.CURDIR}"; \
|
|
fi
|
|
.endif
|
|
|
|
.if !target(objlink)
|
|
objlink:
|
|
@if test -d ${CANONICALOBJDIR}/; then \
|
|
rm -f ${.CURDIR}/obj; \
|
|
ln -s ${CANONICALOBJDIR} ${.CURDIR}/obj; \
|
|
else \
|
|
echo "No ${CANONICALOBJDIR} to link to - do a make obj."; \
|
|
fi
|
|
.endif
|
|
.endif # !defined(NO_OBJ)
|
|
|
|
#
|
|
# where would that obj directory be?
|
|
#
|
|
.if !target(whereobj)
|
|
whereobj:
|
|
@echo ${.OBJDIR}
|
|
.endif
|
|
|
|
.if ${CANONICALOBJDIR} != ${.CURDIR} && exists(${CANONICALOBJDIR}/)
|
|
cleanobj:
|
|
@-rm -rf ${CANONICALOBJDIR}
|
|
.else
|
|
cleanobj: clean cleandepend
|
|
.endif
|
|
@if [ -L ${.CURDIR}/obj ]; then rm -f ${.CURDIR}/obj; fi
|
|
|
|
# Tell bmake not to look for generated files via .PATH
|
|
NOPATH_FILES+= ${CLEANFILES}
|
|
.if !empty(NOPATH_FILES)
|
|
.NOPATH: ${NOPATH_FILES}
|
|
.endif
|
|
|
|
.if !target(clean)
|
|
clean:
|
|
.if defined(CLEANFILES) && !empty(CLEANFILES)
|
|
rm -f ${CLEANFILES}
|
|
.endif
|
|
.if defined(CLEANDIRS) && !empty(CLEANDIRS)
|
|
-rm -rf ${CLEANDIRS}
|
|
.endif
|
|
.endif
|
|
|
|
cleandir: cleanobj
|
|
|
|
.include <bsd.subdir.mk>
|
|
|
|
.endif # !target(__<bsd.obj.mk>__)
|