xref: /freebsd/contrib/bmake/unit-tests/varparse-errors.mk (revision e6bfd18d21b225af6a0ed67ceeaf1293b7b9eba5)
1# $NetBSD: varparse-errors.mk,v 1.8 2023/02/14 21:56:48 rillig Exp $
2
3# Tests for parsing and evaluating all kinds of variable expressions.
4#
5# This is the basis for redesigning the error handling in Var_Parse and
6# Var_Subst, collecting typical and not so typical use cases.
7#
8# See also:
9#	Var_Parse
10#	Var_Subst
11
12PLAIN=		plain value
13
14LITERAL_DOLLAR=	To get a dollar, double $$ it.
15
16INDIRECT=	An ${:Uindirect} value.
17
18REF_UNDEF=	A reference to an ${UNDEF}undefined variable.
19
20ERR_UNCLOSED=	An ${UNCLOSED variable expression.
21
22ERR_BAD_MOD=	An ${:Uindirect:Z} expression with an unknown modifier.
23
24ERR_EVAL=	An evaluation error ${:Uvalue:C,.,\3,}.
25
26# In a conditional, a variable expression that is not enclosed in quotes is
27# expanded using the mode VARE_UNDEFERR.
28# The variable itself must be defined.
29# It may refer to undefined variables though.
30.if ${REF_UNDEF} != "A reference to an undefined variable."
31.  error
32.endif
33
34# As of 2020-12-01, errors in the variable name are silently ignored.
35# Since var.c 1.754 from 2020-12-20, unknown modifiers at parse time result
36# in an error message and a non-zero exit status.
37VAR.${:U:Z}=	unknown modifier in the variable name
38.if ${VAR.} != "unknown modifier in the variable name"
39.  error
40.endif
41
42# As of 2020-12-01, errors in the variable name are silently ignored.
43# Since var.c 1.754 from 2020-12-20, unknown modifiers at parse time result
44# in an error message and a non-zero exit status.
45VAR.${:U:Z}post=	unknown modifier with text in the variable name
46.if ${VAR.post} != "unknown modifier with text in the variable name"
47.  error
48.endif
49
50# Demonstrate an edge case in which the 'static' for 'errorReported' in
51# Var_Subst actually makes a difference, preventing "a plethora of messages".
52# Given that this is an edge case and the error message is wrong and thus
53# misleading anyway, that piece of code is probably not necessary.  The wrong
54# condition was added in var.c 1.185 from 2014-05-19.
55#
56# To trigger this difference, the variable assignment must use the assignment
57# operator ':=' to make VarEvalMode_ShouldKeepUndef return true.  There must
58# be 2 expressions that create a parse error, which in this case is ':OX'.
59# These expressions must be nested in some way.  The below expressions are
60# minimal, that is, removing any part of it destroys the effect.
61#
62# Without the 'static', there would be one more message like this:
63#	Undefined variable "${:U:OX"
64#
65#.MAKEFLAGS: -dv
66IND=	${:OX}
67_:=	${:U:OX:U${IND}} ${:U:OX:U${IND}}
68#.MAKEFLAGS: -d0
69
70
71# Before var.c 1.032 from 2022-08-24, make complained about 'Unknown modifier'
72# or 'Bad modifier' when in fact the modifier was entirely correct, it was
73# just not delimited by either ':' or '}' but instead by '\0'.
74UNCLOSED:=	${:U:Q
75UNCLOSED:=	${:U:sh
76UNCLOSED:=	${:U:tA
77UNCLOSED:=	${:U:tsX
78UNCLOSED:=	${:U:ts
79UNCLOSED:=	${:U:ts\040
80UNCLOSED:=	${:U:u
81UNCLOSED:=	${:U:H
82UNCLOSED:=	${:U:[1]
83UNCLOSED:=	${:U:hash
84UNCLOSED:=	${:U:range
85UNCLOSED:=	${:U:_
86UNCLOSED:=	${:U:gmtime
87UNCLOSED:=	${:U:localtime
88