1 # This allows us to work with the newline character:
10 # Usage: escape = $(call nl-escape[,escape])
12 # This is used as the common way to specify
13 # what should replace a newline when escaping
14 # newlines; the default is a bizarre string.
16 nl-escape
= $(or
$(1),m822df3020w6a44id34bt574ctac44eb9f4n
)
20 # Usage: escaped-text = $(call escape-nl,text[,escape])
22 # GNU make's $(shell ...) function converts to a
23 # single space each newline character in the output
24 # produced during the expansion; this may not be
27 # The only solution is to change each newline into
28 # something that won't be converted, so that the
29 # information can be recovered later with
30 # $(call unescape-nl...)
32 escape-nl
= $(subst $(newline
),$(call nl-escape
,$(2)),$(1))
36 # Usage: text = $(call unescape-nl,escaped-text[,escape])
40 unescape-nl
= $(subst $(call nl-escape
,$(2)),$(newline
),$(1))
44 # Usage: $(shell some-command | $(call shell-escape-nl[,escape]))
46 # Use this to escape newlines from within a shell call;
47 # the default escape is a bizarre string.
49 # NOTE: The escape is used directly as a string constant
50 # in an `awk' program that is delimited by shell
51 # single-quotes, so be wary of the characters
54 define shell-escape-nl
55 awk
'NR==1 {t=$$0} NR>1 {t=t "$(nl-escape)" $$0} END {printf t}'
60 # Usage: $(shell some-command | $(call shell-unescape-nl[,escape]))
62 # Use this to unescape newlines from within a shell call;
63 # the default escape is a bizarre string.
65 # NOTE: The escape is used directly as an extended regular
66 # expression constant in an `awk' program that is
67 # delimited by shell single-quotes, so be wary
68 # of the characters that are chosen.
70 # (The bash shell has a bug where `{gsub(...),...}' is
71 # misinterpreted as a brace expansion; this can be
72 # overcome by putting a space between `{' and `gsub').
74 define shell-unescape-nl
75 awk
'NR==1 {t=$$0} NR>1 {t=t "\n" $$0} END { gsub(/$(nl-escape)/,"\n",t); printf t }'
80 # Usage: embeddable-text = $(call escape-for-shell-sq,text)
82 # This function produces text that is suitable for
83 # embedding in a shell string that is delimited by
86 escape-for-shell-sq
= $(subst ','\'',$(1))
90 # Usage: single-quoted-and-escaped-text = $(call shell-sq,text)
92 shell-sq = '$(escape-for-shell-sq
)'
96 # Usage: wordified-text = $(call shell-wordify,text)
106 # | echo $(call shell-wordify,$(text))
108 # At least GNU make gets confused by expanding a newline
109 # within the context of a command line of a makefile rule
110 # (this is in constrast to a `$(shell ...)' function call
,
111 # which can handle it just fine).
113 # This function avoids the problem by producing a string
114 # that works as a shell word, regardless of whether or
115 # not it contains a newline.
117 # If the text to be wordified contains a newline, then
118 # an intrictate shell command substitution is constructed
119 # to render the text as a single line; when the shell
120 # processes the resulting escaped text, it transforms
121 # it into the original unescaped text.
123 # If the text does not contain a newline, then this function
124 # produces the same results as the `$(shell-sq)' function.
126 shell-wordify
= $(if
$(findstring $(newline
),$(1)),$(_sw-esc-nl
),$(shell-sq
))
128 "$$(echo $(call escape-nl,$(shell-sq),$(2)) | $(call shell-unescape-nl,$(2)))"
133 # Usage: bool-value = $(call is-absolute,path)
135 is-absolute
= $(shell echo
$(shell-sq
) | grep ^
/ -q
&& echo y
)
139 # Usage: absolute-executable-path-or-empty = $(call lookup,path)
141 # (It's necessary to use `sh -c' because GNU make messes up by
142 # trying too hard and getting things wrong).
144 lookup
= $(call unescape-nl
,$(shell sh
-c
$(_l-sh
)))
145 _l-sh
= $(call shell-sq
,command
-v
$(shell-sq
) |
$(call shell-escape-nl
,))
149 # Usage: bool-value = $(call is-executable,path)
151 # (It's necessary to use `sh -c' because GNU make messes up by
152 # trying too hard and getting things wrong).
154 is-executable
= $(call _is-executable-helper
,$(shell-sq
))
155 _is-executable-helper
= $(shell sh
-c
$(_is-executable-sh
))
156 _is-executable-sh
= $(call shell-sq
,test -f
$(1) -a
-x
$(1) && echo y
)
160 # Usage: absolute-executable-path-or-empty = $(call get-executable,path)
162 # The goal is to get an absolute path for an executable;
163 # the `command -v' is defined by POSIX, but it's not
164 # necessarily very portable, so it's only used if
165 # relative path resolution is requested, as determined
166 # by the presence of a leading `/'.
168 get-executable
= $(if
$(1),$(if
$(is-absolute
),$(_ge-abspath
),$(lookup
)))
169 _ge-abspath
= $(if
$(is-executable
),$(1))
171 # get-supplied-or-default-executable
173 # Usage: absolute-executable-path-or-empty = $(call get-executable-or-default,variable,default)
175 define get-executable-or-default
176 $(if
$($(1)),$(call _ge_attempt
,$($(1)),$(1)),$(call _ge_attempt
,$(2)))
178 _ge_attempt
= $(or
$(get-executable
),$(_gea_warn
),$(call _gea_err
,$(2)))
179 _gea_warn
= $(warning The path
'$(1)' is not executable.
)
180 _gea_err
= $(if
$(1),$(error Please set
'$(1)' appropriately
))
183 # Usage: option = $(call try-cc, source-to-build, cc-options)
184 try-cc
= $(shell sh
-c \
185 'TMP="$(OUTPUT)$(TMPOUT).$$$$"; \
187 $(CC) -x c - $(2) -o "$$TMP" > /dev/null 2>&1 && echo y; \