xref: /aosp_15_r20/external/libtraceevent/scripts/utilities.mak (revision 436bf2bcd5202612ffffe471bbcc1f277cc8d28e)
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