From: Mark Wooding Date: Wed, 5 Jul 2017 20:38:41 +0000 (+0100) Subject: configure.ac: Abstract out common pattern in CPU/ABI variable defs. X-Git-Tag: 2.4.2~42 X-Git-Url: https://git.distorted.org.uk/~mdw/catacomb/commitdiff_plain/58a125f05ea827273d1804e0fb94935a00c7f15b configure.ac: Abstract out common pattern in CPU/ABI variable defs. The new combined macro is really ugly, but it's probably better than two copies of the same thing. No functional change. --- diff --git a/configure.ac b/configure.ac index bd2c3b5c..32a80e01 100644 --- a/configure.ac +++ b/configure.ac @@ -120,35 +120,27 @@ else esac fi -dnl Figure out the current CPU. -catacomb_CPU_FAMILIES([catacomb_CLEAR_FLAGS]) -case $CPUFAM in - m4_define([catacomb_DEFINE_CPU], - [m4_ifdef([catacomb_seen_cpu/$2], [], - [$2) - AC_DEFINE([CPUFAM_]m4_translit([$2], [a-z], [A-Z]), [1], - [Define if host CPU family is \`$2\'.]) - ;;m4_define([catacomb_seen_cpu/$2], [t])])]) - catacomb_CPU_FAMILIES([catacomb_DEFINE_CPU]) +dnl A hairy macro used to set the `CPUFAM_...' and `ABI_...' variables. We +dnl basically need to do the same thing for the family and ABI, so it's worth +dnl some effort to hide the ugliness. +m4_define([catacomb_DEFINE_CPU_OR_ABI], +[case $$1 in + m4_define([_def], + [m4_ifdef([catacomb_seen_$3/$$2], [], + [$$2) + AC_DEFINE([$4]m4_translit([$$2], [a-z], [A-Z]), [1], [$5]) + ;;m4_define([catacomb_seen_$3/$$2], [t])])]) + catacomb_CPU_FAMILIES([_def]) nil) ;; - *) AC_MSG_ERROR([BUG: unexpected cpufam \`$CPUFAM']) ;; -esac -AC_SUBST([CPUFAM]) + *) AC_MSG_ERROR([BUG: unexpected $1 \`$1']) ;; +esac]) -dnl Figure out the current ABI. +dnl Figure out the target CPU family and ABI. catacomb_CPU_FAMILIES([catacomb_CLEAR_FLAGS]) -case $ABI in - m4_define([catacomb_DEFINE_ABI], - [m4_ifdef([catacomb_seen_abi/$3], [], - [$3) - AC_DEFINE([ABI_]m4_translit([$3], [a-z], [A-Z]), [1], - [Define if host ABI variant is \`$3\'.]) - ;;m4_define([catacomb_seen_abi/$3], [t])])]) - catacomb_CPU_FAMILIES([catacomb_DEFINE_ABI]) - nil) ;; - *) AC_MSG_ERROR([BUG: unexpected ABI \`$ABI']) ;; -esac -AC_SUBST([ABI]) +catacomb_DEFINE_CPU_OR_ABI([CPUFAM], [2], [cpu], + [CPUFAM_], [Define if target CPU is \`$][2\'.]) +catacomb_DEFINE_CPU_OR_ABI([ABI], [3], [abi], + [ABI_], [Define if target ABI is \`$][3\'.]) dnl Establish Automake conditions for things. catacomb_CPU_FAMILIES([catacomb_CLEAR_FLAGS])