Module Name: src Committed By: rillig Date: Tue Sep 21 22:38:25 UTC 2021
Modified Files: src/usr.bin/make: cond.c src/usr.bin/make/unit-tests: cond-token-plain.exp cond-token-plain.mk Log Message: make: do not allow unquoted 'left == right' after modifier ':?' Having a static variable for state that clearly belongs in the parser looked suspicious, and indeed it was wrong. When the distinction between .if conditions and expressions of the form ${condition:?:} was added in cond.c 1.68 from 2015-05-05, a new unit test was added, but it didn't cover this edge case. At that time, the state of the condition parser consisted of a few global variables instead of a separate data type, as would have been appropriate for parsing nested conditions. To generate a diff of this commit: cvs rdiff -u -r1.275 -r1.276 src/usr.bin/make/cond.c cvs rdiff -u -r1.11 -r1.12 src/usr.bin/make/unit-tests/cond-token-plain.exp \ src/usr.bin/make/unit-tests/cond-token-plain.mk Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.