Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/usr.bin/make/unit-tests make(1): document the actual cause f...



details:   https://anonhg.NetBSD.org/src/rev/23c1d40fb9f6
branches:  trunk
changeset: 1011499:23c1d40fb9f6
user:      rillig <rillig%NetBSD.org@localhost>
date:      Thu Jul 02 09:44:51 2020 +0000

description:
make(1): document the actual cause for "recursive variable"

That wrong error message had nothing to do with the .for loop, it was
only caused because the .for loop uses the :U modifier internally.

diffstat:

 usr.bin/make/unit-tests/varmisc.mk |  12 +++++++++++-
 1 files changed, 11 insertions(+), 1 deletions(-)

diffs (23 lines):

diff -r 0d3102fd436b -r 23c1d40fb9f6 usr.bin/make/unit-tests/varmisc.mk
--- a/usr.bin/make/unit-tests/varmisc.mk        Thu Jul 02 09:07:24 2020 +0000
+++ b/usr.bin/make/unit-tests/varmisc.mk        Thu Jul 02 09:44:51 2020 +0000
@@ -1,4 +1,4 @@
-# $Id: varmisc.mk,v 1.9 2020/07/01 18:02:26 sjg Exp $
+# $Id: varmisc.mk,v 1.10 2020/07/02 09:44:51 rillig Exp $
 #
 # Miscellaneous variable tests.
 
@@ -72,3 +72,13 @@
 
 manok:
        @echo MAN=${MAN}
+
+# This is an expanded variant of the above .for loop.
+# Between 2020-08-28 and 2020-07-02 this paragraph generated a wrong
+# error message "Variable VARNAME is recursive".
+# When evaluating the !empty expression, the ${:U1} was not expanded and
+# thus resulted in the seeming definition VARNAME=${VARNAME}, which is
+# obviously recursive.
+VARNAME=       ${VARNAME${:U1}}
+.if defined(VARNAME${:U2}) && !empty(VARNAME${:U2})
+.endif



Home | Main Index | Thread Index | Old Index