Module Name: src
Committed By: rillig
Date: Sun Jul 26 22:15:36 UTC 2020
Modified Files:
src/distrib/sets/lists/tests: mi
src/usr.bin/make/unit-tests: Makefile
Added Files:
src/usr.bin/make/unit-tests: varparse-dynamic.exp varparse-dynamic.mk
Log Message:
make(1): add test for off-by-one error in Var_Parse
To generate a diff of this commit:
cvs rdiff -u -r1.877 -r1.878 src/distrib/sets/lists/tests/mi
cvs rdiff -u -r1.65 -r1.66 src/usr.bin/make/unit-tests/Makefile
cvs rdiff -u -r0 -r1.1 src/usr.bin/make/unit-tests/varparse-dynamic.exp \
src/usr.bin/make/unit-tests/varparse-dynamic.mk
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/distrib/sets/lists/tests/mi
diff -u src/distrib/sets/lists/tests/mi:1.877 src/distrib/sets/lists/tests/mi:1.878
--- src/distrib/sets/lists/tests/mi:1.877 Sun Jul 26 14:22:22 2020
+++ src/distrib/sets/lists/tests/mi Sun Jul 26 22:15:36 2020
@@ -1,4 +1,4 @@
-# $NetBSD: mi,v 1.877 2020/07/26 14:22:22 riastradh Exp $
+# $NetBSD: mi,v 1.878 2020/07/26 22:15:36 rillig Exp $
#
# Note: don't delete entries from here - mark them as "obsolete" instead.
#
@@ -4608,6 +4608,8 @@
./usr/tests/usr.bin/make/unit-tests/varmisc.mk tests-usr.bin-tests compattestfile,atf
./usr/tests/usr.bin/make/unit-tests/varmod-edge.exp tests-usr.bin-tests compattestfile,atf
./usr/tests/usr.bin/make/unit-tests/varmod-edge.mk tests-usr.bin-tests compattestfile,atf
+./usr/tests/usr.bin/make/unit-tests/varparse-dynamic.exp tests-usr.bin-tests compattestfile,atf
+./usr/tests/usr.bin/make/unit-tests/varparse-dynamic.mk tests-usr.bin-tests compattestfile,atf
./usr/tests/usr.bin/make/unit-tests/varquote.exp tests-usr.bin-tests compattestfile,atf
./usr/tests/usr.bin/make/unit-tests/varquote.mk tests-usr.bin-tests compattestfile,atf
./usr/tests/usr.bin/make/unit-tests/varshell.exp tests-usr.bin-tests compattestfile,atf
Index: src/usr.bin/make/unit-tests/Makefile
diff -u src/usr.bin/make/unit-tests/Makefile:1.65 src/usr.bin/make/unit-tests/Makefile:1.66
--- src/usr.bin/make/unit-tests/Makefile:1.65 Sun Jul 26 11:10:29 2020
+++ src/usr.bin/make/unit-tests/Makefile Sun Jul 26 22:15:36 2020
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.65 2020/07/26 11:10:29 rillig Exp $
+# $NetBSD: Makefile,v 1.66 2020/07/26 22:15:36 rillig Exp $
#
# Unit tests for make(1)
#
@@ -72,6 +72,7 @@ TESTS+= vardebug
TESTS+= varfind
TESTS+= varmisc
TESTS+= varmod-edge
+TESTS+= varparse-dynamic
TESTS+= varquote
TESTS+= varshell
Added files:
Index: src/usr.bin/make/unit-tests/varparse-dynamic.exp
diff -u /dev/null src/usr.bin/make/unit-tests/varparse-dynamic.exp:1.1
--- /dev/null Sun Jul 26 22:15:36 2020
+++ src/usr.bin/make/unit-tests/varparse-dynamic.exp Sun Jul 26 22:15:36 2020
@@ -0,0 +1,4 @@
+make: "varparse-dynamic.mk" line 10: Malformed conditional (${.TARGXX})
+make: Fatal errors encountered -- cannot continue
+make: stopped in unit-tests
+exit status 1
Index: src/usr.bin/make/unit-tests/varparse-dynamic.mk
diff -u /dev/null src/usr.bin/make/unit-tests/varparse-dynamic.mk:1.1
--- /dev/null Sun Jul 26 22:15:36 2020
+++ src/usr.bin/make/unit-tests/varparse-dynamic.mk Sun Jul 26 22:15:36 2020
@@ -0,0 +1,14 @@
+# $NetBSD: varparse-dynamic.mk,v 1.1 2020/07/26 22:15:36 rillig Exp $
+
+# Before 2020-07-27, there was an off-by-one error in Var_Parse that skipped
+# the last character in the variable name.
+# To trigger the bug, the variable must not be defined.
+.if ${.TARGET} # exact match, may be undefined
+.endif
+.if ${.TARGEX} # 1 character difference, must be defined
+.endif
+.if ${.TARGXX} # 2 characters difference, must be defined
+.endif
+
+all:
+ @: