82d30f4f85
Providing a realistic build environment has priority over having a convenient shell with auto-completion and all the likes.
218 lines
6.1 KiB
Makefile
218 lines
6.1 KiB
Makefile
# $NetBSD: build.mk,v 1.34 2020/06/12 17:33:23 rillig Exp $
|
|
#
|
|
# This file defines what happens in the build phase, excluding the
|
|
# self-test, which is defined in test.mk.
|
|
#
|
|
# Public targets for developers:
|
|
#
|
|
# build-env:
|
|
# Runs an interactive shell (BUILD_ENV_SHELL) in the environment
|
|
# that is used for building the package.
|
|
#
|
|
# Package-settable variables:
|
|
#
|
|
# BUILD_MAKE_FLAGS is the list of arguments that is passed to the make
|
|
# process, in addition to the usual MAKE_FLAGS.
|
|
#
|
|
# BUILD_TARGET is the target from ${MAKE_FILE} that should be invoked
|
|
# to build the sources.
|
|
#
|
|
# MAKE_JOBS_SAFE
|
|
# Whether the package supports parallel builds. If set to yes,
|
|
# at most MAKE_JOBS jobs are carried out in parallel. The default
|
|
# value is "yes", and packages that don't support it must
|
|
# explicitly set it to "no".
|
|
#
|
|
# Keywords: parallel
|
|
#
|
|
# Variables defined in this file:
|
|
#
|
|
# BUILD_MAKE_CMD
|
|
# This command sets the proper environment for the build phase
|
|
# and runs make(1) on it. It takes a list of make targets and
|
|
# flags as argument.
|
|
#
|
|
# See also:
|
|
# mk/build/test.mk
|
|
#
|
|
# Keywords: build make
|
|
|
|
_VARGROUPS+= build
|
|
_DEF_VARS.build= _MAKE_JOBS_N
|
|
_USER_VARS.build= MAKE_JOBS BUILD_ENV_SHELL
|
|
_PKG_VARS.build= MAKE_ENV MAKE_FLAGS BUILD_MAKE_FLAGS BUILD_TARGET MAKE_JOBS_SAFE
|
|
_SYS_VARS.build= BUILD_MAKE_CMD
|
|
_SORTED_VARS.build= *_ENV
|
|
_LISTED_VARS.build= *_FLAGS *_CMD
|
|
|
|
BUILD_MAKE_FLAGS?= # none
|
|
BUILD_TARGET?= all
|
|
|
|
BUILD_MAKE_CMD= \
|
|
${PKGSRC_SETENV} ${MAKE_ENV} \
|
|
${MAKE_PROGRAM} ${_MAKE_JOBS} \
|
|
${MAKE_FLAGS} ${BUILD_MAKE_FLAGS} \
|
|
-f ${MAKE_FILE}
|
|
|
|
.if defined(MAKE_JOBS_SAFE) && !empty(MAKE_JOBS_SAFE:M[nN][oO])
|
|
_MAKE_JOBS= # nothing
|
|
_MAKE_JOBS_N= 1
|
|
.elif defined(MAKE_JOBS.${PKGPATH})
|
|
_MAKE_JOBS= -j${MAKE_JOBS.${PKGPATH}}
|
|
_MAKE_JOBS_N= ${MAKE_JOBS.${PKGPATH}}
|
|
.elif defined(MAKE_JOBS)
|
|
_MAKE_JOBS= -j${MAKE_JOBS}
|
|
_MAKE_JOBS_N= ${MAKE_JOBS}
|
|
.else
|
|
_MAKE_JOBS_N= 1
|
|
.endif
|
|
|
|
######################################################################
|
|
### build (PUBLIC)
|
|
######################################################################
|
|
### build is a public target to build the sources from the package.
|
|
###
|
|
_BUILD_TARGETS+= check-vulnerable
|
|
_BUILD_TARGETS+= configure
|
|
_BUILD_TARGETS+= acquire-build-lock
|
|
_BUILD_TARGETS+= ${_COOKIE.build}
|
|
_BUILD_TARGETS+= release-build-lock
|
|
.if ${_USE_NEW_PKGINSTALL:Uno} == "no"
|
|
_BUILD_TARGETS+= pkginstall
|
|
.endif
|
|
|
|
.PHONY: build
|
|
.if !target(build)
|
|
. if exists(${_COOKIE.build}) && !${_CLEANING}
|
|
build:
|
|
@${DO_NADA}
|
|
. elif defined(_PKGSRC_BARRIER)
|
|
build: ${_BUILD_TARGETS}
|
|
. else
|
|
build: barrier
|
|
. endif
|
|
.endif
|
|
|
|
.PHONY: acquire-build-lock release-build-lock
|
|
acquire-build-lock: acquire-lock
|
|
release-build-lock: release-lock
|
|
|
|
.if exists(${_COOKIE.build}) && !${_CLEANING}
|
|
${_COOKIE.build}:
|
|
@${DO_NADA}
|
|
.else
|
|
${_COOKIE.build}: real-build
|
|
.endif
|
|
|
|
######################################################################
|
|
### rebuild (PUBLIC)
|
|
######################################################################
|
|
### rebuild is a special target to re-run the build target.
|
|
###
|
|
|
|
.PHONY: rebuild
|
|
rebuild: build-clean
|
|
${RUN} ${RECURSIVE_MAKE} ${MAKEFLAGS} build
|
|
|
|
######################################################################
|
|
### build-clean (PRIVATE)
|
|
######################################################################
|
|
### build-clean removes the state files for the "build" and
|
|
### later phases so that the "build" target may be re-invoked.
|
|
###
|
|
.PHONY: build-clean
|
|
build-clean: install-clean _package-clean
|
|
${RUN} ${RM} -f ${_COOKIE.build}
|
|
|
|
######################################################################
|
|
### real-build (PRIVATE)
|
|
######################################################################
|
|
### real-build is a helper target onto which one can hook all of the
|
|
### targets that do the actual building of the sources.
|
|
###
|
|
_REAL_BUILD_TARGETS+= build-check-interactive
|
|
_REAL_BUILD_TARGETS+= build-message
|
|
_REAL_BUILD_TARGETS+= build-vars
|
|
_REAL_BUILD_TARGETS+= pre-build-checks-hook
|
|
_REAL_BUILD_TARGETS+= pre-build
|
|
_REAL_BUILD_TARGETS+= do-build
|
|
_REAL_BUILD_TARGETS+= post-build
|
|
_REAL_BUILD_TARGETS+= build-cookie
|
|
_REAL_BUILD_TARGETS+= error-check
|
|
|
|
.PHONY: real-build
|
|
real-build: ${_REAL_BUILD_TARGETS}
|
|
|
|
.PHONY: build-message
|
|
build-message:
|
|
@${PHASE_MSG} "Building for ${PKGNAME}"
|
|
|
|
######################################################################
|
|
### build-check-interactive (PRIVATE)
|
|
######################################################################
|
|
### build-check-interactive checks whether we must do an interactive
|
|
### build or not.
|
|
###
|
|
build-check-interactive:
|
|
.if !empty(INTERACTIVE_STAGE:Mbuild) && defined(BATCH)
|
|
@${ERROR_MSG} "The build stage of this package requires user interaction"
|
|
@${ERROR_MSG} "Please build manually with:"
|
|
@${ERROR_MSG} " \"cd ${.CURDIR} && ${MAKE} build\""
|
|
${RUN} ${FALSE}
|
|
.else
|
|
@${DO_NADA}
|
|
.endif
|
|
|
|
######################################################################
|
|
### pre-build, do-build, post-build (PUBLIC, override)
|
|
######################################################################
|
|
### {pre,do,post}-build are the heart of the package-customizable
|
|
### build targets, and may be overridden within a package Makefile.
|
|
###
|
|
.PHONY: pre-build do-build post-build
|
|
|
|
.if !target(do-build)
|
|
do-build:
|
|
. for _dir_ in ${BUILD_DIRS}
|
|
${RUN}${_ULIMIT_CMD} \
|
|
cd ${WRKSRC} && cd ${_dir_} && \
|
|
${BUILD_MAKE_CMD} ${BUILD_TARGET}
|
|
. endfor
|
|
.endif
|
|
|
|
.if !target(pre-build)
|
|
pre-build:
|
|
@${DO_NADA}
|
|
.endif
|
|
|
|
.if !target(post-build)
|
|
post-build:
|
|
@${DO_NADA}
|
|
.endif
|
|
|
|
# build-env:
|
|
# Starts an interactive shell in WRKSRC.
|
|
#
|
|
# This is only used during development and testing of a package
|
|
# to work in the environment (MAKE_ENV) that is used by default
|
|
# for building the packages.
|
|
#
|
|
# User-settable variables:
|
|
#
|
|
# BUILD_ENV_SHELL
|
|
# The shell to start.
|
|
#
|
|
# Default: ${SH}, to realistically match the build environment.
|
|
#
|
|
# Keywords: debug build
|
|
|
|
BUILD_ENV_SHELL?= ${SH}
|
|
build-env: .PHONY ${_PKGSRC_BARRIER:Ubarrier:D_build-env}
|
|
_build-env: .PHONY configure
|
|
@${STEP_MSG} "Entering the build environment for ${PKGNAME}"
|
|
.if ${BUILD_DIRS:[#]} > 1 || ${BUILD_DIRS} != ${WRKSRC}
|
|
@${ECHO_MSG} "The BUILD_DIRS are:" \
|
|
${BUILD_DIRS:S,^${WRKSRC}$,.,:S,^${WRKSRC}/,,:Q}
|
|
.endif
|
|
${RUN}${_ULIMIT_CMD} \
|
|
cd ${WRKSRC} && ${PKGSRC_SETENV} ${MAKE_ENV} ${BUILD_ENV_SHELL}
|