deptgt-makeflags.mk revision 1.7 1 # $NetBSD: deptgt-makeflags.mk,v 1.7 2021/11/29 00:17:10 rillig Exp $
2 #
3 # Tests for the special target .MAKEFLAGS in dependency declarations,
4 # which adds command line options later, at parse time.
5 #
6 # In these unit tests, it is often used to temporarily toggle the debug log
7 # during parsing.
8
9 # The -D option sets a variable in the "Global" scope and thus can be
10 # undefined later.
11 .MAKEFLAGS: -D VAR
12 .if ${VAR} != 1
13 . error
14 .endif
15
16 # Variables that are set via the -D command line option are normal global
17 # variables and can thus be undefined later.
18 .undef VAR
19 .if defined(VAR)
20 . error
21 .endif
22
23 # The -D command line option can define a variable again, after it has been
24 # undefined.
25 .MAKEFLAGS: -D VAR
26 .if ${VAR} != 1
27 . error
28 .endif
29
30 # The "dependency" for .MAKEFLAGS is split into words, interpreting the usual
31 # quotes and escape sequences from the backslash.
32 .MAKEFLAGS: VAR="value"' with'\ spaces
33 .if ${VAR} != "value with spaces"
34 . error
35 .endif
36
37 # Variables set on the command line as VAR=value are placed in the
38 # "Command" scope and thus cannot be undefined.
39 .undef VAR
40 .if ${VAR} != "value with spaces"
41 . error
42 .endif
43
44 # When parsing this line, each '$$' becomes '$', resulting in '$$$$'.
45 # This is assigned to the variable DOLLAR.
46 # In the condition, that variable is expanded, and at that point, each '$$'
47 # becomes '$' again, the final expression is thus '$$'.
48 .MAKEFLAGS: -dcv
49 .MAKEFLAGS: DOLLAR=$$$$$$$$
50 .if ${DOLLAR} != "\$\$"
51 .endif
52 .MAKEFLAGS: -d0
53
54 # An empty command line is skipped.
55 .MAKEFLAGS: # none
56
57 # Escape sequences like \n are interpreted.
58 # The following line looks as if it assigned a newline to nl, but it doesn't.
59 # Instead, the \n ends up as a line that is then interpreted as a variable
60 # assignment. At that point, the line is simply "nl=\n", and the \n is
61 # skipped since it is whitespace (see Parse_IsVar).
62 .MAKEFLAGS: nl="\n"
63 .if ${nl} != ""
64 . error
65 .endif
66
67 # Next try at defining another newline variable. Since whitespace around the
68 # variable value is trimmed, two empty variable expressions ${:U} surround the
69 # literal newline now. This prevents the newline from being skipped during
70 # parsing. The ':=' assignment operator expands the empty variable
71 # expressions, leaving only the newline as the variable value.
72 #
73 # This is one of the very few ways (maybe even the only one) to inject literal
74 # newlines into a line that is being parsed. This may confuse the parser.
75 # For example, in cond.c the parser only expects horizontal whitespace (' '
76 # and '\t'), but no newlines.
77 #.MAKEFLAGS: -dcpv
78 .MAKEFLAGS: nl:="$${:U}\n$${:U}"
79 .if ${nl} != ${.newline}
80 . error
81 .endif
82 #.MAKEFLAGS: -d0
83
84 # Now do the same for the other escape sequences; see Substring_Words.
85 .MAKEFLAGS: CHAR_BS:="$${:U}\b$${:U}"
86 .MAKEFLAGS: CHAR_FF:="$${:U}\f$${:U}"
87 .MAKEFLAGS: CHAR_NL:="$${:U}\n$${:U}"
88 .MAKEFLAGS: CHAR_CR:="$${:U}\r$${:U}"
89 .MAKEFLAGS: CHAR_TAB:="$${:U}\t$${:U}"
90
91 # Note: backspace is not whitespace, it is a control character.
92 .if ${CHAR_BS:C,^[[:cntrl:]]$,found,W} != "found"
93 . error
94 .endif
95 .if ${CHAR_FF:C,^[[:space:]]$,found,W} != "found"
96 . error
97 .endif
98 .if ${CHAR_NL:C,^[[:space:]]$,found,W} != "found"
99 . error
100 .endif
101 .if ${CHAR_CR:C,^[[:space:]]$,found,W} != "found"
102 . error
103 .endif
104 .if ${CHAR_TAB:C,^[[:space:]]$,found,W} != "found"
105 . error
106 .endif
107
108
109 # Unbalanced quotes produce an error message. If they occur anywhere in the
110 # command line, the whole command line is skipped.
111 .MAKEFLAGS: VAR=previous
112 .MAKEFLAGS: VAR=initial UNBALANCED='
113 .if ${VAR} != "previous"
114 . error
115 .endif
116
117 all:
118 @:;
119