xref: /aosp_15_r20/prebuilts/build-tools/common/bison/m4sugar/foreach.m4 (revision cda5da8d549138a6648c5ee6d7a49cf8f4a657be)
1*cda5da8dSAndroid Build Coastguard Worker#                                                  -*- Autoconf -*-
2*cda5da8dSAndroid Build Coastguard Worker# This file is part of Autoconf.
3*cda5da8dSAndroid Build Coastguard Worker# foreach-based replacements for recursive functions.
4*cda5da8dSAndroid Build Coastguard Worker# Speeds up GNU M4 1.4.x by avoiding quadratic $@ recursion, but penalizes
5*cda5da8dSAndroid Build Coastguard Worker# GNU M4 1.6 by requiring more memory and macro expansions.
6*cda5da8dSAndroid Build Coastguard Worker#
7*cda5da8dSAndroid Build Coastguard Worker# Copyright (C) 2008-2017, 2020 Free Software Foundation, Inc.
8*cda5da8dSAndroid Build Coastguard Worker
9*cda5da8dSAndroid Build Coastguard Worker# This file is part of Autoconf.  This program is free
10*cda5da8dSAndroid Build Coastguard Worker# software; you can redistribute it and/or modify it under the
11*cda5da8dSAndroid Build Coastguard Worker# terms of the GNU General Public License as published by the
12*cda5da8dSAndroid Build Coastguard Worker# Free Software Foundation, either version 3 of the License, or
13*cda5da8dSAndroid Build Coastguard Worker# (at your option) any later version.
14*cda5da8dSAndroid Build Coastguard Worker#
15*cda5da8dSAndroid Build Coastguard Worker# This program is distributed in the hope that it will be useful,
16*cda5da8dSAndroid Build Coastguard Worker# but WITHOUT ANY WARRANTY; without even the implied warranty of
17*cda5da8dSAndroid Build Coastguard Worker# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18*cda5da8dSAndroid Build Coastguard Worker# GNU General Public License for more details.
19*cda5da8dSAndroid Build Coastguard Worker#
20*cda5da8dSAndroid Build Coastguard Worker# Under Section 7 of GPL version 3, you are granted additional
21*cda5da8dSAndroid Build Coastguard Worker# permissions described in the Autoconf Configure Script Exception,
22*cda5da8dSAndroid Build Coastguard Worker# version 3.0, as published by the Free Software Foundation.
23*cda5da8dSAndroid Build Coastguard Worker#
24*cda5da8dSAndroid Build Coastguard Worker# You should have received a copy of the GNU General Public License
25*cda5da8dSAndroid Build Coastguard Worker# and a copy of the Autoconf Configure Script Exception along with
26*cda5da8dSAndroid Build Coastguard Worker# this program; see the files COPYINGv3 and COPYING.EXCEPTION
27*cda5da8dSAndroid Build Coastguard Worker# respectively.  If not, see <https://www.gnu.org/licenses/>.
28*cda5da8dSAndroid Build Coastguard Worker
29*cda5da8dSAndroid Build Coastguard Worker# Written by Eric Blake.
30*cda5da8dSAndroid Build Coastguard Worker
31*cda5da8dSAndroid Build Coastguard Worker# In M4 1.4.x, every byte of $@ is rescanned.  This means that an
32*cda5da8dSAndroid Build Coastguard Worker# algorithm on n arguments that recurses with one less argument each
33*cda5da8dSAndroid Build Coastguard Worker# iteration will scan n * (n + 1) / 2 arguments, for O(n^2) time.  In
34*cda5da8dSAndroid Build Coastguard Worker# M4 1.6, this was fixed so that $@ is only scanned once, then
35*cda5da8dSAndroid Build Coastguard Worker# back-references are made to information stored about the scan.
36*cda5da8dSAndroid Build Coastguard Worker# Thus, n iterations need only scan n arguments, for O(n) time.
37*cda5da8dSAndroid Build Coastguard Worker# Additionally, in M4 1.4.x, recursive algorithms did not clean up
38*cda5da8dSAndroid Build Coastguard Worker# memory very well, requiring O(n^2) memory rather than O(n) for n
39*cda5da8dSAndroid Build Coastguard Worker# iterations.
40*cda5da8dSAndroid Build Coastguard Worker#
41*cda5da8dSAndroid Build Coastguard Worker# This file is designed to overcome the quadratic nature of $@
42*cda5da8dSAndroid Build Coastguard Worker# recursion by writing a variant of m4_foreach that uses m4_for rather
43*cda5da8dSAndroid Build Coastguard Worker# than $@ recursion to operate on the list.  This involves more macro
44*cda5da8dSAndroid Build Coastguard Worker# expansions, but avoids the need to rescan a quadratic number of
45*cda5da8dSAndroid Build Coastguard Worker# arguments, making these replacements very attractive for M4 1.4.x.
46*cda5da8dSAndroid Build Coastguard Worker# On the other hand, in any version of M4, expanding additional macros
47*cda5da8dSAndroid Build Coastguard Worker# costs additional time; therefore, in M4 1.6, where $@ recursion uses
48*cda5da8dSAndroid Build Coastguard Worker# fewer macros, these replacements actually pessimize performance.
49*cda5da8dSAndroid Build Coastguard Worker# Additionally, the use of $10 to mean the tenth argument violates
50*cda5da8dSAndroid Build Coastguard Worker# POSIX; although all versions of m4 1.4.x support this meaning, a
51*cda5da8dSAndroid Build Coastguard Worker# future m4 version may switch to take it as the first argument
52*cda5da8dSAndroid Build Coastguard Worker# concatenated with a literal 0, so the implementations in this file
53*cda5da8dSAndroid Build Coastguard Worker# are not future-proof.  Thus, this file is conditionally included as
54*cda5da8dSAndroid Build Coastguard Worker# part of m4_init(), only when it is detected that M4 probably has
55*cda5da8dSAndroid Build Coastguard Worker# quadratic behavior (ie. it lacks the macro __m4_version__).
56*cda5da8dSAndroid Build Coastguard Worker#
57*cda5da8dSAndroid Build Coastguard Worker# Please keep this file in sync with m4sugar.m4.
58*cda5da8dSAndroid Build Coastguard Worker
59*cda5da8dSAndroid Build Coastguard Worker# _m4_foreach(PRE, POST, IGNORED, ARG...)
60*cda5da8dSAndroid Build Coastguard Worker# ---------------------------------------
61*cda5da8dSAndroid Build Coastguard Worker# Form the common basis of the m4_foreach and m4_map macros.  For each
62*cda5da8dSAndroid Build Coastguard Worker# ARG, expand PRE[ARG]POST[].  The IGNORED argument makes recursion
63*cda5da8dSAndroid Build Coastguard Worker# easier, and must be supplied rather than implicit.
64*cda5da8dSAndroid Build Coastguard Worker#
65*cda5da8dSAndroid Build Coastguard Worker# This version minimizes the number of times that $@ is evaluated by
66*cda5da8dSAndroid Build Coastguard Worker# using m4_for to generate a boilerplate into _m4_f then passing $@ to
67*cda5da8dSAndroid Build Coastguard Worker# that temporary macro.  Thus, the recursion is done in m4_for without
68*cda5da8dSAndroid Build Coastguard Worker# reparsing any user input, and is not quadratic.  For an idea of how
69*cda5da8dSAndroid Build Coastguard Worker# this works, note that m4_foreach(i,[1,2],[i]) calls
70*cda5da8dSAndroid Build Coastguard Worker#   _m4_foreach([m4_define([i],],[)i],[],[1],[2])
71*cda5da8dSAndroid Build Coastguard Worker# which defines _m4_f:
72*cda5da8dSAndroid Build Coastguard Worker#   $1[$4]$2[]$1[$5]$2[]_m4_popdef([_m4_f])
73*cda5da8dSAndroid Build Coastguard Worker# then calls _m4_f([m4_define([i],],[)i],[],[1],[2]) for a net result:
74*cda5da8dSAndroid Build Coastguard Worker#   m4_define([i],[1])i[]m4_define([i],[2])i[]_m4_popdef([_m4_f]).
75*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_foreach],
76*cda5da8dSAndroid Build Coastguard Worker[m4_if([$#], [3], [],
77*cda5da8dSAndroid Build Coastguard Worker       [m4_pushdef([_m4_f], _m4_for([4], [$#], [1],
78*cda5da8dSAndroid Build Coastguard Worker   [$0_([1], [2],], [)])[_m4_popdef([_m4_f])])_m4_f($@)])])
79*cda5da8dSAndroid Build Coastguard Worker
80*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_foreach_],
81*cda5da8dSAndroid Build Coastguard Worker[[$$1[$$3]$$2[]]])
82*cda5da8dSAndroid Build Coastguard Worker
83*cda5da8dSAndroid Build Coastguard Worker# m4_case(SWITCH, VAL1, IF-VAL1, VAL2, IF-VAL2, ..., DEFAULT)
84*cda5da8dSAndroid Build Coastguard Worker# -----------------------------------------------------------
85*cda5da8dSAndroid Build Coastguard Worker# Find the first VAL that SWITCH matches, and expand the corresponding
86*cda5da8dSAndroid Build Coastguard Worker# IF-VAL.  If there are no matches, expand DEFAULT.
87*cda5da8dSAndroid Build Coastguard Worker#
88*cda5da8dSAndroid Build Coastguard Worker# Use m4_for to create a temporary macro in terms of a boilerplate
89*cda5da8dSAndroid Build Coastguard Worker# m4_if with final cleanup.  If $# is even, we have DEFAULT; if it is
90*cda5da8dSAndroid Build Coastguard Worker# odd, then rounding the last $# up in the temporary macro is
91*cda5da8dSAndroid Build Coastguard Worker# harmless.  For example, both m4_case(1,2,3,4,5) and
92*cda5da8dSAndroid Build Coastguard Worker# m4_case(1,2,3,4,5,6) result in the intermediate _m4_case being
93*cda5da8dSAndroid Build Coastguard Worker#   m4_if([$1],[$2],[$3],[$1],[$4],[$5],_m4_popdef([_m4_case])[$6])
94*cda5da8dSAndroid Build Coastguard Workerm4_define([m4_case],
95*cda5da8dSAndroid Build Coastguard Worker[m4_if(m4_eval([$# <= 2]), [1], [$2],
96*cda5da8dSAndroid Build Coastguard Worker[m4_pushdef([_$0], [m4_if(]_m4_for([2], m4_eval([($# - 1) / 2 * 2]), [2],
97*cda5da8dSAndroid Build Coastguard Worker     [_$0_(], [)])[_m4_popdef(
98*cda5da8dSAndroid Build Coastguard Worker	 [_$0])]m4_dquote($m4_eval([($# + 1) & ~1]))[)])_$0($@)])])
99*cda5da8dSAndroid Build Coastguard Worker
100*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_case_],
101*cda5da8dSAndroid Build Coastguard Worker[$0_([1], [$1], m4_incr([$1]))])
102*cda5da8dSAndroid Build Coastguard Worker
103*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_case__],
104*cda5da8dSAndroid Build Coastguard Worker[[[$$1],[$$2],[$$3],]])
105*cda5da8dSAndroid Build Coastguard Worker
106*cda5da8dSAndroid Build Coastguard Worker# m4_bmatch(SWITCH, RE1, VAL1, RE2, VAL2, ..., DEFAULT)
107*cda5da8dSAndroid Build Coastguard Worker# -----------------------------------------------------
108*cda5da8dSAndroid Build Coastguard Worker# m4 equivalent of
109*cda5da8dSAndroid Build Coastguard Worker#
110*cda5da8dSAndroid Build Coastguard Worker# if (SWITCH =~ RE1)
111*cda5da8dSAndroid Build Coastguard Worker#   VAL1;
112*cda5da8dSAndroid Build Coastguard Worker# elif (SWITCH =~ RE2)
113*cda5da8dSAndroid Build Coastguard Worker#   VAL2;
114*cda5da8dSAndroid Build Coastguard Worker# elif ...
115*cda5da8dSAndroid Build Coastguard Worker#   ...
116*cda5da8dSAndroid Build Coastguard Worker# else
117*cda5da8dSAndroid Build Coastguard Worker#   DEFAULT
118*cda5da8dSAndroid Build Coastguard Worker#
119*cda5da8dSAndroid Build Coastguard Worker# We build the temporary macro _m4_b:
120*cda5da8dSAndroid Build Coastguard Worker#   m4_define([_m4_b], _m4_defn([_m4_bmatch]))_m4_b([$1], [$2], [$3])...
121*cda5da8dSAndroid Build Coastguard Worker#   _m4_b([$1], [$m-1], [$m])_m4_b([], [], [$m+1]_m4_popdef([_m4_b]))
122*cda5da8dSAndroid Build Coastguard Worker# then invoke m4_unquote(_m4_b($@)), for concatenation with later text.
123*cda5da8dSAndroid Build Coastguard Workerm4_define([m4_bmatch],
124*cda5da8dSAndroid Build Coastguard Worker[m4_if([$#], 0, [m4_fatal([$0: too few arguments: $#])],
125*cda5da8dSAndroid Build Coastguard Worker       [$#], 1, [m4_fatal([$0: too few arguments: $#: $1])],
126*cda5da8dSAndroid Build Coastguard Worker       [$#], 2, [$2],
127*cda5da8dSAndroid Build Coastguard Worker       [m4_pushdef([_m4_b], [m4_define([_m4_b],
128*cda5da8dSAndroid Build Coastguard Worker  _m4_defn([_$0]))]_m4_for([3], m4_eval([($# + 1) / 2 * 2 - 1]),
129*cda5da8dSAndroid Build Coastguard Worker  [2], [_$0_(], [)])[_m4_b([], [],]m4_dquote([$]m4_eval(
130*cda5da8dSAndroid Build Coastguard Worker  [($# + 1) / 2 * 2]))[_m4_popdef([_m4_b]))])m4_unquote(_m4_b($@))])])
131*cda5da8dSAndroid Build Coastguard Worker
132*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_bmatch],
133*cda5da8dSAndroid Build Coastguard Worker[m4_if(m4_bregexp([$1], [$2]), [-1], [], [[$3]m4_define([$0])])])
134*cda5da8dSAndroid Build Coastguard Worker
135*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_bmatch_],
136*cda5da8dSAndroid Build Coastguard Worker[$0_([1], m4_decr([$1]), [$1])])
137*cda5da8dSAndroid Build Coastguard Worker
138*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_bmatch__],
139*cda5da8dSAndroid Build Coastguard Worker[[_m4_b([$$1], [$$2], [$$3])]])
140*cda5da8dSAndroid Build Coastguard Worker
141*cda5da8dSAndroid Build Coastguard Worker
142*cda5da8dSAndroid Build Coastguard Worker# m4_cond(TEST1, VAL1, IF-VAL1, TEST2, VAL2, IF-VAL2, ..., [DEFAULT])
143*cda5da8dSAndroid Build Coastguard Worker# -------------------------------------------------------------------
144*cda5da8dSAndroid Build Coastguard Worker# Similar to m4_if, except that each TEST is expanded when encountered.
145*cda5da8dSAndroid Build Coastguard Worker# If the expansion of TESTn matches the string VALn, the result is IF-VALn.
146*cda5da8dSAndroid Build Coastguard Worker# The result is DEFAULT if no tests passed.  This macro allows
147*cda5da8dSAndroid Build Coastguard Worker# short-circuiting of expensive tests, where it pays to arrange quick
148*cda5da8dSAndroid Build Coastguard Worker# filter tests to run first.
149*cda5da8dSAndroid Build Coastguard Worker#
150*cda5da8dSAndroid Build Coastguard Worker# m4_cond already guarantees either 3*n or 3*n + 1 arguments, 1 <= n.
151*cda5da8dSAndroid Build Coastguard Worker# We only have to speed up _m4_cond, by building the temporary _m4_c:
152*cda5da8dSAndroid Build Coastguard Worker#   m4_define([_m4_c], _m4_defn([m4_unquote]))_m4_c([m4_if(($1), [($2)],
153*cda5da8dSAndroid Build Coastguard Worker#   [[$3]m4_define([_m4_c])])])_m4_c([m4_if(($4), [($5)],
154*cda5da8dSAndroid Build Coastguard Worker#   [[$6]m4_define([_m4_c])])])..._m4_c([m4_if(($m-2), [($m-1)],
155*cda5da8dSAndroid Build Coastguard Worker#   [[$m]m4_define([_m4_c])])])_m4_c([[$m+1]]_m4_popdef([_m4_c]))
156*cda5da8dSAndroid Build Coastguard Worker# We invoke m4_unquote(_m4_c($@)), for concatenation with later text.
157*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_cond],
158*cda5da8dSAndroid Build Coastguard Worker[m4_pushdef([_m4_c], [m4_define([_m4_c],
159*cda5da8dSAndroid Build Coastguard Worker  _m4_defn([m4_unquote]))]_m4_for([2], m4_eval([$# / 3 * 3 - 1]), [3],
160*cda5da8dSAndroid Build Coastguard Worker  [$0_(], [)])[_m4_c(]m4_dquote(m4_dquote(
161*cda5da8dSAndroid Build Coastguard Worker  [$]m4_eval([$# / 3 * 3 + 1])))[_m4_popdef([_m4_c]))])m4_unquote(_m4_c($@))])
162*cda5da8dSAndroid Build Coastguard Worker
163*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_cond_],
164*cda5da8dSAndroid Build Coastguard Worker[$0_(m4_decr([$1]), [$1], m4_incr([$1]))])
165*cda5da8dSAndroid Build Coastguard Worker
166*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_cond__],
167*cda5da8dSAndroid Build Coastguard Worker[[_m4_c([m4_if(($$1), [($$2)], [[$$3]m4_define([_m4_c])])])]])
168*cda5da8dSAndroid Build Coastguard Worker
169*cda5da8dSAndroid Build Coastguard Worker# m4_bpatsubsts(STRING, RE1, SUBST1, RE2, SUBST2, ...)
170*cda5da8dSAndroid Build Coastguard Worker# ----------------------------------------------------
171*cda5da8dSAndroid Build Coastguard Worker# m4 equivalent of
172*cda5da8dSAndroid Build Coastguard Worker#
173*cda5da8dSAndroid Build Coastguard Worker#   $_ = STRING;
174*cda5da8dSAndroid Build Coastguard Worker#   s/RE1/SUBST1/g;
175*cda5da8dSAndroid Build Coastguard Worker#   s/RE2/SUBST2/g;
176*cda5da8dSAndroid Build Coastguard Worker#   ...
177*cda5da8dSAndroid Build Coastguard Worker#
178*cda5da8dSAndroid Build Coastguard Worker# m4_bpatsubsts already validated an odd number of arguments; we only
179*cda5da8dSAndroid Build Coastguard Worker# need to speed up _m4_bpatsubsts.  To avoid nesting, we build the
180*cda5da8dSAndroid Build Coastguard Worker# temporary _m4_p:
181*cda5da8dSAndroid Build Coastguard Worker#   m4_define([_m4_p], [$1])m4_define([_m4_p],
182*cda5da8dSAndroid Build Coastguard Worker#   m4_bpatsubst(m4_dquote(_m4_defn([_m4_p])), [$2], [$3]))m4_define([_m4_p],
183*cda5da8dSAndroid Build Coastguard Worker#   m4_bpatsubst(m4_dquote(_m4_defn([_m4_p])), [$4], [$5]))m4_define([_m4_p],...
184*cda5da8dSAndroid Build Coastguard Worker#   m4_bpatsubst(m4_dquote(_m4_defn([_m4_p])), [$m-1], [$m]))m4_unquote(
185*cda5da8dSAndroid Build Coastguard Worker#   _m4_defn([_m4_p])_m4_popdef([_m4_p]))
186*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_bpatsubsts],
187*cda5da8dSAndroid Build Coastguard Worker[m4_pushdef([_m4_p], [m4_define([_m4_p],
188*cda5da8dSAndroid Build Coastguard Worker  ]m4_dquote([$]1)[)]_m4_for([3], [$#], [2], [$0_(],
189*cda5da8dSAndroid Build Coastguard Worker  [)])[m4_unquote(_m4_defn([_m4_p])_m4_popdef([_m4_p]))])_m4_p($@)])
190*cda5da8dSAndroid Build Coastguard Worker
191*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_bpatsubsts_],
192*cda5da8dSAndroid Build Coastguard Worker[$0_(m4_decr([$1]), [$1])])
193*cda5da8dSAndroid Build Coastguard Worker
194*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_bpatsubsts__],
195*cda5da8dSAndroid Build Coastguard Worker[[m4_define([_m4_p],
196*cda5da8dSAndroid Build Coastguard Workerm4_bpatsubst(m4_dquote(_m4_defn([_m4_p])), [$$1], [$$2]))]])
197*cda5da8dSAndroid Build Coastguard Worker
198*cda5da8dSAndroid Build Coastguard Worker# m4_shiftn(N, ...)
199*cda5da8dSAndroid Build Coastguard Worker# -----------------
200*cda5da8dSAndroid Build Coastguard Worker# Returns ... shifted N times.  Useful for recursive "varargs" constructs.
201*cda5da8dSAndroid Build Coastguard Worker#
202*cda5da8dSAndroid Build Coastguard Worker# m4_shiftn already validated arguments; we only need to speed up
203*cda5da8dSAndroid Build Coastguard Worker# _m4_shiftn.  If N is 3, then we build the temporary _m4_s, defined as
204*cda5da8dSAndroid Build Coastguard Worker#   ,[$5],[$6],...,[$m]_m4_popdef([_m4_s])
205*cda5da8dSAndroid Build Coastguard Worker# before calling m4_shift(_m4_s($@)).
206*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_shiftn],
207*cda5da8dSAndroid Build Coastguard Worker[m4_if(m4_incr([$1]), [$#], [], [m4_pushdef([_m4_s],
208*cda5da8dSAndroid Build Coastguard Worker  _m4_for(m4_eval([$1 + 2]), [$#], [1],
209*cda5da8dSAndroid Build Coastguard Worker  [[,]m4_dquote($], [)])[_m4_popdef([_m4_s])])m4_shift(_m4_s($@))])])
210*cda5da8dSAndroid Build Coastguard Worker
211*cda5da8dSAndroid Build Coastguard Worker# m4_do(STRING, ...)
212*cda5da8dSAndroid Build Coastguard Worker# ------------------
213*cda5da8dSAndroid Build Coastguard Worker# This macro invokes all its arguments (in sequence, of course).  It is
214*cda5da8dSAndroid Build Coastguard Worker# useful for making your macros more structured and readable by dropping
215*cda5da8dSAndroid Build Coastguard Worker# unnecessary dnl's and have the macros indented properly.
216*cda5da8dSAndroid Build Coastguard Worker#
217*cda5da8dSAndroid Build Coastguard Worker# Here, we use the temporary macro _m4_do, defined as
218*cda5da8dSAndroid Build Coastguard Worker#   $1[]$2[]...[]$n[]_m4_popdef([_m4_do])
219*cda5da8dSAndroid Build Coastguard Workerm4_define([m4_do],
220*cda5da8dSAndroid Build Coastguard Worker[m4_if([$#], [0], [],
221*cda5da8dSAndroid Build Coastguard Worker       [m4_pushdef([_$0], _m4_for([1], [$#], [1],
222*cda5da8dSAndroid Build Coastguard Worker		   [$], [[[]]])[_m4_popdef([_$0])])_$0($@)])])
223*cda5da8dSAndroid Build Coastguard Worker
224*cda5da8dSAndroid Build Coastguard Worker# m4_dquote_elt(ARGS)
225*cda5da8dSAndroid Build Coastguard Worker# -------------------
226*cda5da8dSAndroid Build Coastguard Worker# Return ARGS as an unquoted list of double-quoted arguments.
227*cda5da8dSAndroid Build Coastguard Worker#
228*cda5da8dSAndroid Build Coastguard Worker# _m4_foreach to the rescue.
229*cda5da8dSAndroid Build Coastguard Workerm4_define([m4_dquote_elt],
230*cda5da8dSAndroid Build Coastguard Worker[m4_if([$#], [0], [], [[[$1]]_m4_foreach([,m4_dquote(], [)], $@)])])
231*cda5da8dSAndroid Build Coastguard Worker
232*cda5da8dSAndroid Build Coastguard Worker# m4_reverse(ARGS)
233*cda5da8dSAndroid Build Coastguard Worker# ----------------
234*cda5da8dSAndroid Build Coastguard Worker# Output ARGS in reverse order.
235*cda5da8dSAndroid Build Coastguard Worker#
236*cda5da8dSAndroid Build Coastguard Worker# Invoke _m4_r($@) with the temporary _m4_r built as
237*cda5da8dSAndroid Build Coastguard Worker#   [$m], [$m-1], ..., [$2], [$1]_m4_popdef([_m4_r])
238*cda5da8dSAndroid Build Coastguard Workerm4_define([m4_reverse],
239*cda5da8dSAndroid Build Coastguard Worker[m4_if([$#], [0], [], [$#], [1], [[$1]],
240*cda5da8dSAndroid Build Coastguard Worker[m4_pushdef([_m4_r], [[$$#]]_m4_for(m4_decr([$#]), [1], [-1],
241*cda5da8dSAndroid Build Coastguard Worker    [[, ]m4_dquote($], [)])[_m4_popdef([_m4_r])])_m4_r($@)])])
242*cda5da8dSAndroid Build Coastguard Worker
243*cda5da8dSAndroid Build Coastguard Worker
244*cda5da8dSAndroid Build Coastguard Worker# m4_map_args_pair(EXPRESSION, [END-EXPR = EXPRESSION], ARG...)
245*cda5da8dSAndroid Build Coastguard Worker# -------------------------------------------------------------
246*cda5da8dSAndroid Build Coastguard Worker# Perform a pairwise grouping of consecutive ARGs, by expanding
247*cda5da8dSAndroid Build Coastguard Worker# EXPRESSION([ARG1], [ARG2]).  If there are an odd number of ARGs, the
248*cda5da8dSAndroid Build Coastguard Worker# final argument is expanded with END-EXPR([ARGn]).
249*cda5da8dSAndroid Build Coastguard Worker#
250*cda5da8dSAndroid Build Coastguard Worker# Build the temporary macro _m4_map_args_pair, with the $2([$m+1])
251*cda5da8dSAndroid Build Coastguard Worker# only output if $# is odd:
252*cda5da8dSAndroid Build Coastguard Worker#   $1([$3], [$4])[]$1([$5], [$6])[]...$1([$m-1],
253*cda5da8dSAndroid Build Coastguard Worker#   [$m])[]m4_default([$2], [$1])([$m+1])[]_m4_popdef([_m4_map_args_pair])
254*cda5da8dSAndroid Build Coastguard Workerm4_define([m4_map_args_pair],
255*cda5da8dSAndroid Build Coastguard Worker[m4_if([$#], [0], [m4_fatal([$0: too few arguments: $#])],
256*cda5da8dSAndroid Build Coastguard Worker       [$#], [1], [m4_fatal([$0: too few arguments: $#: $1])],
257*cda5da8dSAndroid Build Coastguard Worker       [$#], [2], [],
258*cda5da8dSAndroid Build Coastguard Worker       [$#], [3], [m4_default([$2], [$1])([$3])[]],
259*cda5da8dSAndroid Build Coastguard Worker       [m4_pushdef([_$0], _m4_for([3],
260*cda5da8dSAndroid Build Coastguard Worker   m4_eval([$# / 2 * 2 - 1]), [2], [_$0_(], [)])_$0_end(
261*cda5da8dSAndroid Build Coastguard Worker   [1], [2], [$#])[_m4_popdef([_$0])])_$0($@)])])
262*cda5da8dSAndroid Build Coastguard Worker
263*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_map_args_pair_],
264*cda5da8dSAndroid Build Coastguard Worker[$0_([1], [$1], m4_incr([$1]))])
265*cda5da8dSAndroid Build Coastguard Worker
266*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_map_args_pair__],
267*cda5da8dSAndroid Build Coastguard Worker[[$$1([$$2], [$$3])[]]])
268*cda5da8dSAndroid Build Coastguard Worker
269*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_map_args_pair_end],
270*cda5da8dSAndroid Build Coastguard Worker[m4_if(m4_eval([$3 & 1]), [1], [[m4_default([$$2], [$$1])([$$3])[]]])])
271*cda5da8dSAndroid Build Coastguard Worker
272*cda5da8dSAndroid Build Coastguard Worker# m4_join(SEP, ARG1, ARG2...)
273*cda5da8dSAndroid Build Coastguard Worker# ---------------------------
274*cda5da8dSAndroid Build Coastguard Worker# Produce ARG1SEPARG2...SEPARGn.  Avoid back-to-back SEP when a given ARG
275*cda5da8dSAndroid Build Coastguard Worker# is the empty string.  No expansion is performed on SEP or ARGs.
276*cda5da8dSAndroid Build Coastguard Worker#
277*cda5da8dSAndroid Build Coastguard Worker# Use a self-modifying separator, since we don't know how many
278*cda5da8dSAndroid Build Coastguard Worker# arguments might be skipped before a separator is first printed, but
279*cda5da8dSAndroid Build Coastguard Worker# be careful if the separator contains $.  _m4_foreach to the rescue.
280*cda5da8dSAndroid Build Coastguard Workerm4_define([m4_join],
281*cda5da8dSAndroid Build Coastguard Worker[m4_pushdef([_m4_sep], [m4_define([_m4_sep], _m4_defn([m4_echo]))])]dnl
282*cda5da8dSAndroid Build Coastguard Worker[_m4_foreach([_$0([$1],], [)], $@)_m4_popdef([_m4_sep])])
283*cda5da8dSAndroid Build Coastguard Worker
284*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_join],
285*cda5da8dSAndroid Build Coastguard Worker[m4_if([$2], [], [], [_m4_sep([$1])[$2]])])
286*cda5da8dSAndroid Build Coastguard Worker
287*cda5da8dSAndroid Build Coastguard Worker# m4_joinall(SEP, ARG1, ARG2...)
288*cda5da8dSAndroid Build Coastguard Worker# ------------------------------
289*cda5da8dSAndroid Build Coastguard Worker# Produce ARG1SEPARG2...SEPARGn.  An empty ARG results in back-to-back SEP.
290*cda5da8dSAndroid Build Coastguard Worker# No expansion is performed on SEP or ARGs.
291*cda5da8dSAndroid Build Coastguard Worker#
292*cda5da8dSAndroid Build Coastguard Worker# A bit easier than m4_join.  _m4_foreach to the rescue.
293*cda5da8dSAndroid Build Coastguard Workerm4_define([m4_joinall],
294*cda5da8dSAndroid Build Coastguard Worker[[$2]m4_if(m4_eval([$# <= 2]), [1], [],
295*cda5da8dSAndroid Build Coastguard Worker	   [_m4_foreach([$1], [], m4_shift($@))])])
296*cda5da8dSAndroid Build Coastguard Worker
297*cda5da8dSAndroid Build Coastguard Worker# m4_list_cmp(A, B)
298*cda5da8dSAndroid Build Coastguard Worker# -----------------
299*cda5da8dSAndroid Build Coastguard Worker# Compare the two lists of integer expressions A and B.
300*cda5da8dSAndroid Build Coastguard Worker#
301*cda5da8dSAndroid Build Coastguard Worker# m4_list_cmp takes care of any side effects; we only override
302*cda5da8dSAndroid Build Coastguard Worker# _m4_list_cmp_raw, where we can safely expand lists multiple times.
303*cda5da8dSAndroid Build Coastguard Worker# First, insert padding so that both lists are the same length; the
304*cda5da8dSAndroid Build Coastguard Worker# trailing +0 is necessary to handle a missing list.  Next, create a
305*cda5da8dSAndroid Build Coastguard Worker# temporary macro to perform pairwise comparisons until an inequality
306*cda5da8dSAndroid Build Coastguard Worker# is found.  For example, m4_list_cmp([1], [1,2]) creates _m4_cmp as
307*cda5da8dSAndroid Build Coastguard Worker#   m4_if(m4_eval([($1) != ($3)]), [1], [m4_cmp([$1], [$3])],
308*cda5da8dSAndroid Build Coastguard Worker#         m4_eval([($2) != ($4)]), [1], [m4_cmp([$2], [$4])],
309*cda5da8dSAndroid Build Coastguard Worker#         [0]_m4_popdef([_m4_cmp]))
310*cda5da8dSAndroid Build Coastguard Worker# then calls _m4_cmp([1+0], [0*2], [1], [2+0])
311*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_list_cmp_raw],
312*cda5da8dSAndroid Build Coastguard Worker[m4_if([$1], [$2], 0,
313*cda5da8dSAndroid Build Coastguard Worker       [_m4_list_cmp($1+0_m4_list_pad(m4_count($1), m4_count($2)),
314*cda5da8dSAndroid Build Coastguard Worker		     $2+0_m4_list_pad(m4_count($2), m4_count($1)))])])
315*cda5da8dSAndroid Build Coastguard Worker
316*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_list_pad],
317*cda5da8dSAndroid Build Coastguard Worker[m4_if(m4_eval($1 < $2), [1],
318*cda5da8dSAndroid Build Coastguard Worker       [_m4_for(m4_incr([$1]), [$2], [1], [,0*])])])
319*cda5da8dSAndroid Build Coastguard Worker
320*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_list_cmp],
321*cda5da8dSAndroid Build Coastguard Worker[m4_pushdef([_m4_cmp], [m4_if(]_m4_for(
322*cda5da8dSAndroid Build Coastguard Worker   [1], m4_eval([$# >> 1]), [1], [$0_(], [,]m4_eval([$# >> 1])[)])[
323*cda5da8dSAndroid Build Coastguard Worker      [0]_m4_popdef([_m4_cmp]))])_m4_cmp($@)])
324*cda5da8dSAndroid Build Coastguard Worker
325*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_list_cmp_],
326*cda5da8dSAndroid Build Coastguard Worker[$0_([$1], m4_eval([$1 + $2]))])
327*cda5da8dSAndroid Build Coastguard Worker
328*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_list_cmp__],
329*cda5da8dSAndroid Build Coastguard Worker[[m4_eval([($$1) != ($$2)]), [1], [m4_cmp([$$1], [$$2])],
330*cda5da8dSAndroid Build Coastguard Worker]])
331*cda5da8dSAndroid Build Coastguard Worker
332*cda5da8dSAndroid Build Coastguard Worker# m4_max(EXPR, ...)
333*cda5da8dSAndroid Build Coastguard Worker# m4_min(EXPR, ...)
334*cda5da8dSAndroid Build Coastguard Worker# -----------------
335*cda5da8dSAndroid Build Coastguard Worker# Return the decimal value of the maximum (or minimum) in a series of
336*cda5da8dSAndroid Build Coastguard Worker# integer expressions.
337*cda5da8dSAndroid Build Coastguard Worker#
338*cda5da8dSAndroid Build Coastguard Worker# _m4_foreach to the rescue; we only need to replace _m4_minmax.  Here,
339*cda5da8dSAndroid Build Coastguard Worker# we need a temporary macro to track the best answer so far, so that
340*cda5da8dSAndroid Build Coastguard Worker# the foreach expression is tractable.
341*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_minmax],
342*cda5da8dSAndroid Build Coastguard Worker[m4_pushdef([_m4_best], m4_eval([$2]))_m4_foreach(
343*cda5da8dSAndroid Build Coastguard Worker  [m4_define([_m4_best], $1(_m4_best,], [))], m4_shift($@))]dnl
344*cda5da8dSAndroid Build Coastguard Worker[_m4_best[]_m4_popdef([_m4_best])])
345*cda5da8dSAndroid Build Coastguard Worker
346*cda5da8dSAndroid Build Coastguard Worker# m4_set_add_all(SET, VALUE...)
347*cda5da8dSAndroid Build Coastguard Worker# -----------------------------
348*cda5da8dSAndroid Build Coastguard Worker# Add each VALUE into SET.  This is O(n) in the number of VALUEs, and
349*cda5da8dSAndroid Build Coastguard Worker# can be faster than calling m4_set_add for each VALUE.
350*cda5da8dSAndroid Build Coastguard Worker#
351*cda5da8dSAndroid Build Coastguard Worker# _m4_foreach to the rescue.  If no deletions have occurred, then
352*cda5da8dSAndroid Build Coastguard Worker# avoid the speed penalty of m4_set_add.
353*cda5da8dSAndroid Build Coastguard Workerm4_define([m4_set_add_all],
354*cda5da8dSAndroid Build Coastguard Worker[m4_if([$#], [0], [], [$#], [1], [],
355*cda5da8dSAndroid Build Coastguard Worker       [m4_define([_m4_set_size($1)], m4_eval(m4_set_size([$1])
356*cda5da8dSAndroid Build Coastguard Worker	  + m4_len(_m4_foreach(m4_ifdef([_m4_set_cleanup($1)],
357*cda5da8dSAndroid Build Coastguard Worker  [[m4_set_add]], [[_$0]])[([$1],], [)], $@))))])])
358*cda5da8dSAndroid Build Coastguard Worker
359*cda5da8dSAndroid Build Coastguard Workerm4_define([_m4_set_add_all],
360*cda5da8dSAndroid Build Coastguard Worker[m4_ifdef([_m4_set([$1],$2)], [],
361*cda5da8dSAndroid Build Coastguard Worker	  [m4_define([_m4_set([$1],$2)],
362*cda5da8dSAndroid Build Coastguard Worker		     [1])m4_pushdef([_m4_set([$1])], [$2])-])])
363