Variables need not always be expanded verbatim. PMake defines several modifiers that may be applied to a variable's value before it is expanded. You apply a modifier by placing it after the variable name with a colon between the two, like so:
${VARIABLE:modifier}
Each modifier is a single character followed by something specific to the modifier itself. You may apply as many modifiers as you want - each one is applied to the result of the previous and is separated from the previous by another colon.
There are seven ways to modify a variable's expansion, most of which come from the C shell variable modification characters:
This is used to select only those words (a word is a series of characters that are
neither spaces nor tabs) that match the given pattern. The pattern is a wildcard pattern
like that used by the shell, where * means 0 or more characters of any sort; ? is any
single character; [abcd] matches any single character that is
either a, b, c
or d (there may be any number of characters between the
brackets); [0-9] matches any single character that is between
0 and 9 (i.e. any digit. This form may
be freely mixed with the other bracket form), and \ is used to
escape any of the characters *, ?, [ or :, leaving them as regular characters
to match themselves in a word. For example, the system makefile <makedepend.mk> uses $(CFLAGS:M-[ID]*) to extract all the -I
and -D
flags that would be passed to the C compiler. This
allows it to properly locate include files and generate the correct dependencies.
This is identical to :M except it substitutes all words that do not match the given pattern.
Causes the first occurrence of search-string in the variable to be replaced by
replacement-string, unless the g
flag is given at the end, in
which case all occurrences of the string are replaced. The substitution is performed on
each word in the variable in turn. If search-string begins with a ^, the string must match starting at the beginning of the word. If
search-string ends with a $, the string must match to the end of
the word (these two may be combined to force an exact match). If a backslash precedes
these two characters, however, they lose their special meaning. Variable expansion also
occurs in the normal fashion inside both the search-string and the replacement-string,
except that a backslash is used to prevent the expansion of a $,
not another dollar sign, as is usual. Note that search-string is just a string, not a
pattern, so none of the usual regularexpression/wildcard characters have any special
meaning save ^ and $. In the
replacement string, the & character is replaced by the
search-string unless it is preceded by a backslash. You are allowed to use any character
except colon or exclamation point to separate the two strings. This so-called delimiter
character may be placed in either string by preceding it with a backslash.
Replaces each word in the variable expansion by its last component (its “tail”). For example, given:
OBJS = ../lib/a.o b /usr/lib/libm.a TAILS = $(OBJS:T)
the variable TAILS would expand to a.o b libm.a.
This is similar to :T, except that every word is replaced by everything but the tail (the “head”). Using the same definition of OBJS, the string $(OBJS:H) would expand to ../lib /usr/lib. Note that the final slash on the heads is removed and anything without a head is replaced by the empty string.
:E replaces each word by its suffix (“extension”). So $(OBJS:E) would give you .o .a.
This replaces each word by everything but the suffix (the “root” of the word). $(OBJS:R) expands to ../lib/a b /usr/lib/libm.
In addition, the System V style of substitution is also supported. This looks like:
$(VARIABLE:search-string=replacement)
It must be the last modifier in the chain. The search is anchored at the end of each word, so only suffixes or whole words may be replaced.