moderrs.mk revision 1.5 1 1.5 rillig # $Id: moderrs.mk,v 1.5 2020/07/28 00:13: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.2 rillig all: modunkn modunknV varterm vartermV modtermV modloop
12 1.5 rillig all: modloop-close
13 1.3 rillig all: modwords
14 1.4 rillig all: modexclam
15 1.1 apb
16 1.1 apb modunkn:
17 1.1 apb @echo "Expect: Unknown modifier 'Z'"
18 1.1 apb @echo "VAR:Z=${VAR:Z}"
19 1.1 apb
20 1.1 apb modunknV:
21 1.1 apb @echo "Expect: Unknown modifier 'Z'"
22 1.1 apb @echo "VAR:${MOD_UNKN}=${VAR:${MOD_UNKN}}"
23 1.1 apb
24 1.1 apb varterm:
25 1.1 apb @echo "Expect: Unclosed variable specification for VAR"
26 1.1 apb @echo VAR:S,V,v,=${VAR:S,V,v,
27 1.1 apb
28 1.1 apb vartermV:
29 1.1 apb @echo "Expect: Unclosed variable specification for VAR"
30 1.1 apb @echo VAR:${MOD_TERM},=${VAR:${MOD_S}
31 1.1 apb
32 1.1 apb modtermV:
33 1.1 apb @echo "Expect: Unclosed substitution for VAR (, missing)"
34 1.1 apb -@echo "VAR:${MOD_TERM}=${VAR:${MOD_TERM}}"
35 1.2 rillig
36 1.2 rillig modloop:
37 1.3 rillig @echo "Expect: 2 errors about missing @ delimiter"
38 1.2 rillig @echo ${UNDEF:U1 2 3:@var}
39 1.2 rillig @echo ${UNDEF:U1 2 3:@var (a] ...}
40 1.2 rillig @echo ${UNDEF:U1 2 3:@var@${var}@}
41 1.3 rillig
42 1.5 rillig # The closing brace after the ${var} is part of the replacement string.
43 1.5 rillig # In ParseModifierPart, braces and parentheses don't have to be balanced.
44 1.5 rillig # This is contrary to the :M, :N modifiers, where both parentheses and
45 1.5 rillig # braces must be balanced.
46 1.5 rillig # This is also contrary to the SysV modifier, where only the actually
47 1.5 rillig # used delimiter (either braces or parentheses) must be balanced.
48 1.5 rillig modloop-close:
49 1.5 rillig @echo $@:
50 1.5 rillig @echo ${UNDEF:U1 2 3:@var@${var}}...@
51 1.5 rillig @echo ${UNDEF:U1 2 3:@var@${var}}...@}
52 1.5 rillig
53 1.3 rillig modwords:
54 1.3 rillig @echo "Expect: 2 errors about missing ] delimiter"
55 1.3 rillig @echo ${UNDEF:U1 2 3:[}
56 1.3 rillig @echo ${UNDEF:U1 2 3:[#}
57 1.3 rillig
58 1.3 rillig # out of bounds => empty
59 1.3 rillig @echo 13=${UNDEF:U1 2 3:[13]}
60 1.3 rillig
61 1.3 rillig # Word index out of bounds.
62 1.3 rillig #
63 1.3 rillig # On LP64I32, strtol returns LONG_MAX,
64 1.3 rillig # which is then truncated to int (undefined behavior),
65 1.3 rillig # typically resulting in -1.
66 1.3 rillig # This -1 is interpreted as "the last word".
67 1.3 rillig #
68 1.3 rillig # On ILP32, strtol returns LONG_MAX,
69 1.3 rillig # which is a large number.
70 1.3 rillig # This results in a range from LONG_MAX - 1 to 3,
71 1.3 rillig # which is empty.
72 1.3 rillig @echo 12345=${UNDEF:U1 2 3:[123451234512345123451234512345]:S,^$,ok,:S,^3$,ok,}
73 1.4 rillig
74 1.4 rillig modexclam:
75 1.4 rillig @echo "Expect: 2 errors about missing ! delimiter"
76 1.4 rillig @echo ${VARNAME:!echo}
77 1.4 rillig # When the final exclamation mark is missing, there is no
78 1.4 rillig # fallback to the SysV substitution modifier.
79 1.4 rillig # If there were a fallback, the output would be "exclam",
80 1.4 rillig # and the above would have produced an "Unknown modifier '!'".
81 1.4 rillig @echo ${!:L:!=exclam}
82