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