1*436bf2bcSAndroid Build Coastguard Worker# SPDX-License-Identifier: GPL-2.0 2*436bf2bcSAndroid Build Coastguard Worker# This allows us to work with the newline character: 3*436bf2bcSAndroid Build Coastguard Workerdefine newline 4*436bf2bcSAndroid Build Coastguard Worker 5*436bf2bcSAndroid Build Coastguard Worker 6*436bf2bcSAndroid Build Coastguard Workerendef 7*436bf2bcSAndroid Build Coastguard Workernewline := $(newline) 8*436bf2bcSAndroid Build Coastguard Worker 9*436bf2bcSAndroid Build Coastguard Worker# nl-escape 10*436bf2bcSAndroid Build Coastguard Worker# 11*436bf2bcSAndroid Build Coastguard Worker# Usage: escape = $(call nl-escape[,escape]) 12*436bf2bcSAndroid Build Coastguard Worker# 13*436bf2bcSAndroid Build Coastguard Worker# This is used as the common way to specify 14*436bf2bcSAndroid Build Coastguard Worker# what should replace a newline when escaping 15*436bf2bcSAndroid Build Coastguard Worker# newlines; the default is a bizarre string. 16*436bf2bcSAndroid Build Coastguard Worker# 17*436bf2bcSAndroid Build Coastguard Workernl-escape = $(if $(1),$(1),m822df3020w6a44id34bt574ctac44eb9f4n) 18*436bf2bcSAndroid Build Coastguard Worker 19*436bf2bcSAndroid Build Coastguard Worker# escape-nl 20*436bf2bcSAndroid Build Coastguard Worker# 21*436bf2bcSAndroid Build Coastguard Worker# Usage: escaped-text = $(call escape-nl,text[,escape]) 22*436bf2bcSAndroid Build Coastguard Worker# 23*436bf2bcSAndroid Build Coastguard Worker# GNU make's $(shell ...) function converts to a 24*436bf2bcSAndroid Build Coastguard Worker# single space each newline character in the output 25*436bf2bcSAndroid Build Coastguard Worker# produced during the expansion; this may not be 26*436bf2bcSAndroid Build Coastguard Worker# desirable. 27*436bf2bcSAndroid Build Coastguard Worker# 28*436bf2bcSAndroid Build Coastguard Worker# The only solution is to change each newline into 29*436bf2bcSAndroid Build Coastguard Worker# something that won't be converted, so that the 30*436bf2bcSAndroid Build Coastguard Worker# information can be recovered later with 31*436bf2bcSAndroid Build Coastguard Worker# $(call unescape-nl...) 32*436bf2bcSAndroid Build Coastguard Worker# 33*436bf2bcSAndroid Build Coastguard Workerescape-nl = $(subst $(newline),$(call nl-escape,$(2)),$(1)) 34*436bf2bcSAndroid Build Coastguard Worker 35*436bf2bcSAndroid Build Coastguard Worker# unescape-nl 36*436bf2bcSAndroid Build Coastguard Worker# 37*436bf2bcSAndroid Build Coastguard Worker# Usage: text = $(call unescape-nl,escaped-text[,escape]) 38*436bf2bcSAndroid Build Coastguard Worker# 39*436bf2bcSAndroid Build Coastguard Worker# See escape-nl. 40*436bf2bcSAndroid Build Coastguard Worker# 41*436bf2bcSAndroid Build Coastguard Workerunescape-nl = $(subst $(call nl-escape,$(2)),$(newline),$(1)) 42*436bf2bcSAndroid Build Coastguard Worker 43*436bf2bcSAndroid Build Coastguard Worker# shell-escape-nl 44*436bf2bcSAndroid Build Coastguard Worker# 45*436bf2bcSAndroid Build Coastguard Worker# Usage: $(shell some-command | $(call shell-escape-nl[,escape])) 46*436bf2bcSAndroid Build Coastguard Worker# 47*436bf2bcSAndroid Build Coastguard Worker# Use this to escape newlines from within a shell call; 48*436bf2bcSAndroid Build Coastguard Worker# the default escape is a bizarre string. 49*436bf2bcSAndroid Build Coastguard Worker# 50*436bf2bcSAndroid Build Coastguard Worker# NOTE: The escape is used directly as a string constant 51*436bf2bcSAndroid Build Coastguard Worker# in an `awk' program that is delimited by shell 52*436bf2bcSAndroid Build Coastguard Worker# single-quotes, so be wary of the characters 53*436bf2bcSAndroid Build Coastguard Worker# that are chosen. 54*436bf2bcSAndroid Build Coastguard Worker# 55*436bf2bcSAndroid Build Coastguard Workerdefine shell-escape-nl 56*436bf2bcSAndroid Build Coastguard Workerawk 'NR==1 {t=$$0} NR>1 {t=t "$(nl-escape)" $$0} END {printf t}' 57*436bf2bcSAndroid Build Coastguard Workerendef 58*436bf2bcSAndroid Build Coastguard Worker 59*436bf2bcSAndroid Build Coastguard Worker# shell-unescape-nl 60*436bf2bcSAndroid Build Coastguard Worker# 61*436bf2bcSAndroid Build Coastguard Worker# Usage: $(shell some-command | $(call shell-unescape-nl[,escape])) 62*436bf2bcSAndroid Build Coastguard Worker# 63*436bf2bcSAndroid Build Coastguard Worker# Use this to unescape newlines from within a shell call; 64*436bf2bcSAndroid Build Coastguard Worker# the default escape is a bizarre string. 65*436bf2bcSAndroid Build Coastguard Worker# 66*436bf2bcSAndroid Build Coastguard Worker# NOTE: The escape is used directly as an extended regular 67*436bf2bcSAndroid Build Coastguard Worker# expression constant in an `awk' program that is 68*436bf2bcSAndroid Build Coastguard Worker# delimited by shell single-quotes, so be wary 69*436bf2bcSAndroid Build Coastguard Worker# of the characters that are chosen. 70*436bf2bcSAndroid Build Coastguard Worker# 71*436bf2bcSAndroid Build Coastguard Worker# (The bash shell has a bug where `{gsub(...),...}' is 72*436bf2bcSAndroid Build Coastguard Worker# misinterpreted as a brace expansion; this can be 73*436bf2bcSAndroid Build Coastguard Worker# overcome by putting a space between `{' and `gsub'). 74*436bf2bcSAndroid Build Coastguard Worker# 75*436bf2bcSAndroid Build Coastguard Workerdefine shell-unescape-nl 76*436bf2bcSAndroid Build Coastguard Workerawk 'NR==1 {t=$$0} NR>1 {t=t "\n" $$0} END { gsub(/$(nl-escape)/,"\n",t); printf t }' 77*436bf2bcSAndroid Build Coastguard Workerendef 78*436bf2bcSAndroid Build Coastguard Worker 79*436bf2bcSAndroid Build Coastguard Worker# escape-for-shell-sq 80*436bf2bcSAndroid Build Coastguard Worker# 81*436bf2bcSAndroid Build Coastguard Worker# Usage: embeddable-text = $(call escape-for-shell-sq,text) 82*436bf2bcSAndroid Build Coastguard Worker# 83*436bf2bcSAndroid Build Coastguard Worker# This function produces text that is suitable for 84*436bf2bcSAndroid Build Coastguard Worker# embedding in a shell string that is delimited by 85*436bf2bcSAndroid Build Coastguard Worker# single-quotes. 86*436bf2bcSAndroid Build Coastguard Worker# 87*436bf2bcSAndroid Build Coastguard Workerescape-for-shell-sq = $(subst ','\'',$(1)) 88*436bf2bcSAndroid Build Coastguard Worker 89*436bf2bcSAndroid Build Coastguard Worker# shell-sq 90*436bf2bcSAndroid Build Coastguard Worker# 91*436bf2bcSAndroid Build Coastguard Worker# Usage: single-quoted-and-escaped-text = $(call shell-sq,text) 92*436bf2bcSAndroid Build Coastguard Worker# 93*436bf2bcSAndroid Build Coastguard Workershell-sq = '$(escape-for-shell-sq)' 94*436bf2bcSAndroid Build Coastguard Worker 95*436bf2bcSAndroid Build Coastguard Worker# shell-wordify 96*436bf2bcSAndroid Build Coastguard Worker# 97*436bf2bcSAndroid Build Coastguard Worker# Usage: wordified-text = $(call shell-wordify,text) 98*436bf2bcSAndroid Build Coastguard Worker# 99*436bf2bcSAndroid Build Coastguard Worker# For instance: 100*436bf2bcSAndroid Build Coastguard Worker# 101*436bf2bcSAndroid Build Coastguard Worker# |define text 102*436bf2bcSAndroid Build Coastguard Worker# |hello 103*436bf2bcSAndroid Build Coastguard Worker# |world 104*436bf2bcSAndroid Build Coastguard Worker# |endef 105*436bf2bcSAndroid Build Coastguard Worker# | 106*436bf2bcSAndroid Build Coastguard Worker# |target: 107*436bf2bcSAndroid Build Coastguard Worker# | echo $(call shell-wordify,$(text)) 108*436bf2bcSAndroid Build Coastguard Worker# 109*436bf2bcSAndroid Build Coastguard Worker# At least GNU make gets confused by expanding a newline 110*436bf2bcSAndroid Build Coastguard Worker# within the context of a command line of a makefile rule 111*436bf2bcSAndroid Build Coastguard Worker# (this is in constrast to a `$(shell ...)' function call, 112*436bf2bcSAndroid Build Coastguard Worker# which can handle it just fine). 113*436bf2bcSAndroid Build Coastguard Worker# 114*436bf2bcSAndroid Build Coastguard Worker# This function avoids the problem by producing a string 115*436bf2bcSAndroid Build Coastguard Worker# that works as a shell word, regardless of whether or 116*436bf2bcSAndroid Build Coastguard Worker# not it contains a newline. 117*436bf2bcSAndroid Build Coastguard Worker# 118*436bf2bcSAndroid Build Coastguard Worker# If the text to be wordified contains a newline, then 119*436bf2bcSAndroid Build Coastguard Worker# an intrictate shell command substitution is constructed 120*436bf2bcSAndroid Build Coastguard Worker# to render the text as a single line; when the shell 121*436bf2bcSAndroid Build Coastguard Worker# processes the resulting escaped text, it transforms 122*436bf2bcSAndroid Build Coastguard Worker# it into the original unescaped text. 123*436bf2bcSAndroid Build Coastguard Worker# 124*436bf2bcSAndroid Build Coastguard Worker# If the text does not contain a newline, then this function 125*436bf2bcSAndroid Build Coastguard Worker# produces the same results as the `$(shell-sq)' function. 126*436bf2bcSAndroid Build Coastguard Worker# 127*436bf2bcSAndroid Build Coastguard Workershell-wordify = $(if $(findstring $(newline),$(1)),$(_sw-esc-nl),$(shell-sq)) 128*436bf2bcSAndroid Build Coastguard Workerdefine _sw-esc-nl 129*436bf2bcSAndroid Build Coastguard Worker"$$(echo $(call escape-nl,$(shell-sq),$(2)) | $(call shell-unescape-nl,$(2)))" 130*436bf2bcSAndroid Build Coastguard Workerendef 131*436bf2bcSAndroid Build Coastguard Worker 132*436bf2bcSAndroid Build Coastguard Worker# is-absolute 133*436bf2bcSAndroid Build Coastguard Worker# 134*436bf2bcSAndroid Build Coastguard Worker# Usage: bool-value = $(call is-absolute,path) 135*436bf2bcSAndroid Build Coastguard Worker# 136*436bf2bcSAndroid Build Coastguard Workeris-absolute = $(shell echo $(shell-sq) | grep -q ^/ && echo y) 137*436bf2bcSAndroid Build Coastguard Worker 138*436bf2bcSAndroid Build Coastguard Worker# lookup 139*436bf2bcSAndroid Build Coastguard Worker# 140*436bf2bcSAndroid Build Coastguard Worker# Usage: absolute-executable-path-or-empty = $(call lookup,path) 141*436bf2bcSAndroid Build Coastguard Worker# 142*436bf2bcSAndroid Build Coastguard Worker# (It's necessary to use `sh -c' because GNU make messes up by 143*436bf2bcSAndroid Build Coastguard Worker# trying too hard and getting things wrong). 144*436bf2bcSAndroid Build Coastguard Worker# 145*436bf2bcSAndroid Build Coastguard Workerlookup = $(call unescape-nl,$(shell sh -c $(_l-sh))) 146*436bf2bcSAndroid Build Coastguard Worker_l-sh = $(call shell-sq,command -v $(shell-sq) | $(call shell-escape-nl,)) 147*436bf2bcSAndroid Build Coastguard Worker 148*436bf2bcSAndroid Build Coastguard Worker# is-executable 149*436bf2bcSAndroid Build Coastguard Worker# 150*436bf2bcSAndroid Build Coastguard Worker# Usage: bool-value = $(call is-executable,path) 151*436bf2bcSAndroid Build Coastguard Worker# 152*436bf2bcSAndroid Build Coastguard Worker# (It's necessary to use `sh -c' because GNU make messes up by 153*436bf2bcSAndroid Build Coastguard Worker# trying too hard and getting things wrong). 154*436bf2bcSAndroid Build Coastguard Worker# 155*436bf2bcSAndroid Build Coastguard Workeris-executable = $(call _is-executable-helper,$(shell-sq)) 156*436bf2bcSAndroid Build Coastguard Worker_is-executable-helper = $(shell sh -c $(_is-executable-sh)) 157*436bf2bcSAndroid Build Coastguard Worker_is-executable-sh = $(call shell-sq,test -f $(1) -a -x $(1) && echo y) 158*436bf2bcSAndroid Build Coastguard Worker 159*436bf2bcSAndroid Build Coastguard Worker# get-executable 160*436bf2bcSAndroid Build Coastguard Worker# 161*436bf2bcSAndroid Build Coastguard Worker# Usage: absolute-executable-path-or-empty = $(call get-executable,path) 162*436bf2bcSAndroid Build Coastguard Worker# 163*436bf2bcSAndroid Build Coastguard Worker# The goal is to get an absolute path for an executable; 164*436bf2bcSAndroid Build Coastguard Worker# the `command -v' is defined by POSIX, but it's not 165*436bf2bcSAndroid Build Coastguard Worker# necessarily very portable, so it's only used if 166*436bf2bcSAndroid Build Coastguard Worker# relative path resolution is requested, as determined 167*436bf2bcSAndroid Build Coastguard Worker# by the presence of a leading `/'. 168*436bf2bcSAndroid Build Coastguard Worker# 169*436bf2bcSAndroid Build Coastguard Workerget-executable = $(if $(1),$(if $(is-absolute),$(_ge-abspath),$(lookup))) 170*436bf2bcSAndroid Build Coastguard Worker_ge-abspath = $(if $(is-executable),$(1)) 171*436bf2bcSAndroid Build Coastguard Worker 172*436bf2bcSAndroid Build Coastguard Worker# get-supplied-or-default-executable 173*436bf2bcSAndroid Build Coastguard Worker# 174*436bf2bcSAndroid Build Coastguard Worker# Usage: absolute-executable-path-or-empty = $(call get-executable-or-default,variable,default) 175*436bf2bcSAndroid Build Coastguard Worker# 176*436bf2bcSAndroid Build Coastguard Workerdefine get-executable-or-default 177*436bf2bcSAndroid Build Coastguard Worker$(if $($(1)),$(call _ge_attempt,$($(1)),$(1)),$(call _ge_attempt,$(2))) 178*436bf2bcSAndroid Build Coastguard Workerendef 179*436bf2bcSAndroid Build Coastguard Worker_ge_attempt = $(if $(get-executable),$(get-executable),$(call _gea_err,$(2))) 180*436bf2bcSAndroid Build Coastguard Worker_gea_err = $(if $(1),$(error Please set '$(1)' appropriately)) 181