moderrs.mk revision 1.14 1 1.14 rillig # $Id: moderrs.mk,v 1.14 2020/08/09 15:15:29 rillig Exp $
2 1.1 apb #
3 1.1 apb # various modifier error tests
4 1.1 apb
5 1.1 apb VAR=TheVariable
6 1.1 apb # incase we have to change it ;-)
7 1.1 apb MOD_UNKN=Z
8 1.1 apb MOD_TERM=S,V,v
9 1.1 apb MOD_S:= ${MOD_TERM},
10 1.1 apb
11 1.7 rillig FIB= 1 1 2 3 5 8 13 21 34
12 1.7 rillig
13 1.2 rillig all: modunkn modunknV varterm vartermV modtermV modloop
14 1.5 rillig all: modloop-close
15 1.3 rillig all: modwords
16 1.4 rillig all: modexclam
17 1.6 rillig all: mod-subst-delimiter
18 1.7 rillig all: mod-regex-delimiter
19 1.13 rillig all: mod-regex-undefined-subexpression
20 1.7 rillig all: mod-ts-parse
21 1.7 rillig all: mod-t-parse
22 1.7 rillig all: mod-ifelse-parse
23 1.7 rillig all: mod-assign-parse
24 1.7 rillig all: mod-remember-parse
25 1.7 rillig all: mod-sysv-parse
26 1.1 apb
27 1.1 apb modunkn:
28 1.1 apb @echo "Expect: Unknown modifier 'Z'"
29 1.1 apb @echo "VAR:Z=${VAR:Z}"
30 1.1 apb
31 1.1 apb modunknV:
32 1.1 apb @echo "Expect: Unknown modifier 'Z'"
33 1.1 apb @echo "VAR:${MOD_UNKN}=${VAR:${MOD_UNKN}}"
34 1.1 apb
35 1.1 apb varterm:
36 1.1 apb @echo "Expect: Unclosed variable specification for VAR"
37 1.1 apb @echo VAR:S,V,v,=${VAR:S,V,v,
38 1.1 apb
39 1.1 apb vartermV:
40 1.1 apb @echo "Expect: Unclosed variable specification for VAR"
41 1.1 apb @echo VAR:${MOD_TERM},=${VAR:${MOD_S}
42 1.1 apb
43 1.1 apb modtermV:
44 1.12 rillig @echo "Expect: Unfinished modifier for VAR (',' missing)"
45 1.1 apb -@echo "VAR:${MOD_TERM}=${VAR:${MOD_TERM}}"
46 1.2 rillig
47 1.2 rillig modloop:
48 1.3 rillig @echo "Expect: 2 errors about missing @ delimiter"
49 1.2 rillig @echo ${UNDEF:U1 2 3:@var}
50 1.2 rillig @echo ${UNDEF:U1 2 3:@var (a] ...}
51 1.2 rillig @echo ${UNDEF:U1 2 3:@var@${var}@}
52 1.3 rillig
53 1.5 rillig # The closing brace after the ${var} is part of the replacement string.
54 1.5 rillig # In ParseModifierPart, braces and parentheses don't have to be balanced.
55 1.5 rillig # This is contrary to the :M, :N modifiers, where both parentheses and
56 1.5 rillig # braces must be balanced.
57 1.5 rillig # This is also contrary to the SysV modifier, where only the actually
58 1.5 rillig # used delimiter (either braces or parentheses) must be balanced.
59 1.5 rillig modloop-close:
60 1.5 rillig @echo $@:
61 1.5 rillig @echo ${UNDEF:U1 2 3:@var@${var}}...@
62 1.5 rillig @echo ${UNDEF:U1 2 3:@var@${var}}...@}
63 1.5 rillig
64 1.3 rillig modwords:
65 1.3 rillig @echo "Expect: 2 errors about missing ] delimiter"
66 1.3 rillig @echo ${UNDEF:U1 2 3:[}
67 1.3 rillig @echo ${UNDEF:U1 2 3:[#}
68 1.3 rillig
69 1.3 rillig # out of bounds => empty
70 1.3 rillig @echo 13=${UNDEF:U1 2 3:[13]}
71 1.3 rillig
72 1.3 rillig # Word index out of bounds.
73 1.3 rillig #
74 1.3 rillig # On LP64I32, strtol returns LONG_MAX,
75 1.3 rillig # which is then truncated to int (undefined behavior),
76 1.3 rillig # typically resulting in -1.
77 1.3 rillig # This -1 is interpreted as "the last word".
78 1.3 rillig #
79 1.3 rillig # On ILP32, strtol returns LONG_MAX,
80 1.3 rillig # which is a large number.
81 1.3 rillig # This results in a range from LONG_MAX - 1 to 3,
82 1.3 rillig # which is empty.
83 1.3 rillig @echo 12345=${UNDEF:U1 2 3:[123451234512345123451234512345]:S,^$,ok,:S,^3$,ok,}
84 1.4 rillig
85 1.4 rillig modexclam:
86 1.4 rillig @echo "Expect: 2 errors about missing ! delimiter"
87 1.4 rillig @echo ${VARNAME:!echo}
88 1.4 rillig # When the final exclamation mark is missing, there is no
89 1.4 rillig # fallback to the SysV substitution modifier.
90 1.4 rillig # If there were a fallback, the output would be "exclam",
91 1.4 rillig # and the above would have produced an "Unknown modifier '!'".
92 1.4 rillig @echo ${!:L:!=exclam}
93 1.6 rillig
94 1.6 rillig mod-subst-delimiter:
95 1.6 rillig @echo $@:
96 1.6 rillig @echo ${VAR:S
97 1.6 rillig @echo ${VAR:S,
98 1.6 rillig @echo ${VAR:S,from
99 1.6 rillig @echo ${VAR:S,from,
100 1.6 rillig @echo ${VAR:S,from,to
101 1.6 rillig @echo ${VAR:S,from,to,
102 1.6 rillig @echo ${VAR:S,from,to,}
103 1.6 rillig @echo 1: ${VAR:S
104 1.6 rillig @echo 2: ${VAR:S,
105 1.6 rillig @echo 3: ${VAR:S,from
106 1.6 rillig @echo ${VAR:S,from,
107 1.6 rillig @echo ${VAR:S,from,to
108 1.6 rillig @echo ${VAR:S,from,to,
109 1.6 rillig @echo ${VAR:S,from,to,}
110 1.7 rillig
111 1.7 rillig mod-regex-delimiter:
112 1.7 rillig @echo $@:
113 1.7 rillig @echo ${VAR:C
114 1.7 rillig @echo ${VAR:C,
115 1.7 rillig @echo ${VAR:C,from
116 1.7 rillig @echo ${VAR:C,from,
117 1.7 rillig @echo ${VAR:C,from,to
118 1.7 rillig @echo ${VAR:C,from,to,
119 1.7 rillig @echo ${VAR:C,from,to,}
120 1.7 rillig @echo 1: ${VAR:C
121 1.7 rillig @echo 2: ${VAR:C,
122 1.7 rillig @echo 3: ${VAR:C,from
123 1.7 rillig @echo ${VAR:C,from,
124 1.7 rillig @echo ${VAR:C,from,to
125 1.7 rillig @echo ${VAR:C,from,to,
126 1.7 rillig @echo ${VAR:C,from,to,}
127 1.7 rillig
128 1.13 rillig # In regular expressions with alternatives, not all capturing groups are
129 1.13 rillig # always set; some may be missing. Warn about these.
130 1.13 rillig #
131 1.13 rillig # Since there is no way to turn off this warning, the combination of
132 1.13 rillig # alternative matches and capturing groups is not widely used.
133 1.13 rillig #
134 1.13 rillig # A newly added modifier 'U' such as in :C,(a.)|(b.),\1\2,U might be added
135 1.13 rillig # for treating undefined capturing groups as empty, but that would create a
136 1.13 rillig # syntactical ambiguity since the :S and :C modifiers are open-ended (see
137 1.13 rillig # mod-subst-chain). Luckily the modifier :U does not make sense after :C,
138 1.13 rillig # therefore this case does not happen in practice.
139 1.13 rillig # The sub-modifier for the :C modifier would have to be chosen wisely.
140 1.13 rillig mod-regex-undefined-subexpression:
141 1.13 rillig @echo $@:
142 1.13 rillig @echo ${FIB:C,1(.*),one\1,} # all ok
143 1.14 rillig @echo ${FIB:C,1(.*)|2(.*),(\1)+(\2),:Q} # no match for subexpression
144 1.13 rillig
145 1.7 rillig mod-ts-parse:
146 1.7 rillig @echo $@:
147 1.7 rillig @echo ${FIB:ts}
148 1.7 rillig @echo ${FIB:ts\65} # octal 065 == U+0035 == '5'
149 1.7 rillig @echo ${FIB:ts\65oct} # bad modifier
150 1.7 rillig @echo ${FIB:tsxy} # modifier too long
151 1.7 rillig
152 1.7 rillig mod-t-parse:
153 1.7 rillig @echo $@:
154 1.10 rillig @echo ${FIB:t
155 1.7 rillig @echo ${FIB:txy}
156 1.7 rillig @echo ${FIB:t}
157 1.7 rillig @echo ${FIB:t:M*}
158 1.7 rillig
159 1.7 rillig mod-ifelse-parse:
160 1.7 rillig @echo $@:
161 1.7 rillig @echo ${FIB:?
162 1.7 rillig @echo ${FIB:?then
163 1.7 rillig @echo ${FIB:?then:
164 1.7 rillig @echo ${FIB:?then:else
165 1.7 rillig @echo ${FIB:?then:else}
166 1.7 rillig
167 1.7 rillig mod-assign-parse:
168 1.7 rillig @echo $@:
169 1.7 rillig @echo ${ASSIGN::x} # 'x' is an unknown assignment operator
170 1.8 rillig @echo ${::=value} # trying to set the empty variable
171 1.7 rillig @echo ${ASSIGN::=value # missing closing brace
172 1.7 rillig
173 1.7 rillig mod-remember-parse:
174 1.7 rillig @echo $@:
175 1.7 rillig @echo ${FIB:_} # ok
176 1.7 rillig @echo ${FIB:__} # modifier name too long
177 1.7 rillig
178 1.7 rillig mod-sysv-parse:
179 1.7 rillig @echo $@:
180 1.7 rillig @echo ${FIB:3
181 1.7 rillig @echo ${FIB:3=
182 1.7 rillig @echo ${FIB:3=x3
183 1.7 rillig @echo ${FIB:3=x3} # ok
184