o allow env var MAKE_OBJDIR_CHECK_WRITABLE=no to skip writable checks in InitObjdir. Explicit .OBJDIR target always allows read-only directory. o More code cleanup and refactoring. o More unit tests MFC after: 1 week
41 lines
1.2 KiB
Makefile
41 lines
1.2 KiB
Makefile
# $NetBSD: cmdline-undefined.mk,v 1.2 2020/11/04 04:49:33 rillig Exp $
|
|
#
|
|
# Tests for undefined variable expressions in the command line.
|
|
|
|
all:
|
|
# When the command line is parsed, variable assignments using the
|
|
# '=' assignment operator do get their variable name expanded
|
|
# (which probably occurs rarely in practice, if at all), but their
|
|
# variable value is not expanded, as usual.
|
|
#
|
|
@echo 'The = assignment operator'
|
|
@${.MAKE} -f ${MAKEFILE} print-undefined \
|
|
CMDLINE='Undefined is $${UNDEFINED}.'
|
|
@echo
|
|
|
|
# The interesting case is using the ':=' assignment operator, which
|
|
# expands its right-hand side. But only those variables that are
|
|
# defined.
|
|
@echo 'The := assignment operator'
|
|
@${.MAKE} -f ${MAKEFILE} print-undefined \
|
|
CMDLINE:='Undefined is $${UNDEFINED}.'
|
|
@echo
|
|
|
|
.if make(print-undefined)
|
|
|
|
.MAKEFLAGS: MAKEFLAGS_ASSIGN='Undefined is $${UNDEFINED}.'
|
|
.MAKEFLAGS: MAKEFLAGS_SUBST:='Undefined is $${UNDEFINED}.'
|
|
|
|
.info From the command line: ${CMDLINE}
|
|
.info From .MAKEFLAGS '=': ${MAKEFLAGS_ASSIGN}
|
|
.info From .MAKEFLAGS ':=': ${MAKEFLAGS_SUBST}
|
|
|
|
UNDEFINED?= now defined
|
|
|
|
.info From the command line: ${CMDLINE}
|
|
.info From .MAKEFLAGS '=': ${MAKEFLAGS_ASSIGN}
|
|
.info From .MAKEFLAGS ':=': ${MAKEFLAGS_SUBST}
|
|
|
|
print-undefined:
|
|
.endif
|