diff options
author | Reuben Thomas <rrt@sc3d.org> | 2009-08-06 22:39:54 +0100 |
---|---|---|
committer | Reuben Thomas <rrt@sc3d.org> | 2009-08-06 22:39:54 +0100 |
commit | 3ea011f8cd6c4c47bdd8e9779169efe2ad05caa6 (patch) | |
tree | b985d888c9fc54bb8bbf7a7b7b6c3178fc58bb11 /m4/ax_create_target_h.m4 | |
parent | 2ff01bdb018a1a1bc9e5800314d70e06972192cc (diff) | |
download | autoconf-archive-3ea011f8cd6c4c47bdd8e9779169efe2ad05caa6.tar.gz |
Rename AC_ prefixes to AX_ (only in names of aa macros!).
Diffstat (limited to 'm4/ax_create_target_h.m4')
-rw-r--r-- | m4/ax_create_target_h.m4 | 526 |
1 files changed, 526 insertions, 0 deletions
diff --git a/m4/ax_create_target_h.m4 b/m4/ax_create_target_h.m4 new file mode 100644 index 0000000..38e8935 --- /dev/null +++ b/m4/ax_create_target_h.m4 @@ -0,0 +1,526 @@ +# =========================================================================== +# http://www.nongnu.org/autoconf-archive/ax_create_target_h.html +# =========================================================================== +# +# SYNOPSIS +# +# AX_CREATE_TARGET_H [(HEADER-FILE [,PREFIX)] +# +# DESCRIPTION +# +# Create the header-file and let it contain '#defines' for the target +# platform. This macro is used for libraries that have platform-specific +# quirks. Instead of inventing a target-specific target.h.in files, just +# let it create a header file from the definitions of AC_CANONICAL_SYSTEM +# and put only ifdef's in the installed header-files. +# +# if the HEADER-FILE is absent, [target.h] is used. +# if the PREFIX is absent, [TARGET] is used. +# the prefix can be the packagename. (y:a-z-:A-Z_:) +# +# The defines look like... +# +# #ifndef TARGET_CPU_M68K +# #define TARGET_CPU_M68K "m68k" +# #endif +# +# #ifndef TARGET_OS_LINUX +# #define TARGET_OS_LINUX "linux-gnu" +# #endif +# +# #ifndef TARGET_OS_TYPE /* the string itself */ +# #define TARGET_OS_TYPE "linux-gnu" +# #endif +# +# Detail: in the case of hppa1.1, the three idents "hppa1_1" "hppa1" and +# "hppa" are derived, for an m68k it just two, "m68k" and "m". +# +# The CREATE_TARGET_H__ variant is almost the same function, but +# everything is lowercased instead of uppercased, and there is a "__" in +# front of each prefix, so it looks like... +# +# #ifndef __target_os_linux +# #define __target_os_linux "linux-gnulibc2" +# #endif +# +# #ifndef __target_os__ /* the string itself */ +# #define __target_os__ "linux-gnulibc2" +# #endif +# +# #ifndef __target_cpu_i586 +# #define __target_cpu_i586 "i586" +# #endif +# +# #ifndef __target_arch_i386 +# #define __target_arch_i386 "i386" +# #endif +# +# #ifndef __target_arch__ /* cpu family arch */ +# #define __target_arch__ "i386" +# #endif +# +# Other differences: the default string-define is "__" instead of "_TYPE". +# +# Personally, I prefer the second variant (which had been the first in the +# devprocess of this file but I assume people will often fallback to the +# primary variant presented herein). +# +# NOTE: CREATE_TARGET_H does also fill HOST_OS-defines Functionality has +# been split over functions called CREATE_TARGET_H_UPPER, +# CREATE_TARGET_H_LOWER, CREATE_TARGET_HOST_UPPER, and +# CREATE_TARGET_HOST_LOWER. +# +# CREATE_TARGET_H uses CREATE_TARGET_H_UPPER CREATE_TARGET_HOST_UPPER +# CREATE_TARGET_H_ uses CREATE_TARGET_H_LOWER CREATE_TARGET_HOST_LOWER +# +# There is now a CREATE_PREFIX_TARGET_H in this file as a shorthand for +# PREFIX_CONFIG_H from a target.h file, however w/o the target.h ever +# created (the prefix is a bit different, since we add an extra -target- +# and -host-). +# +# LICENSE +# +# Copyright (c) 2008 Guido U. Draheim <guidod@gmx.de> +# +# This program is free software; you can redistribute it and/or modify it +# under the terms of the GNU General Public License as published by the +# Free Software Foundation; either version 2 of the License, or (at your +# option) any later version. +# +# This program is distributed in the hope that it will be useful, but +# WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General +# Public License for more details. +# +# You should have received a copy of the GNU General Public License along +# with this program. If not, see <http://www.gnu.org/licenses/>. +# +# As a special exception, the respective Autoconf Macro's copyright owner +# gives unlimited permission to copy, distribute and modify the configure +# scripts that are the output of Autoconf when processing the Macro. You +# need not follow the terms of the GNU General Public License when using +# or distributing such scripts, even though portions of the text of the +# Macro appear in them. The GNU General Public License (GPL) does govern +# all other use of the material that constitutes the Autoconf Macro. +# +# This special exception to the GPL applies to versions of the Autoconf +# Macro released by the Autoconf Archive. When you make and distribute a +# modified version of the Autoconf Macro, you may extend this special +# exception to the GPL to apply to your modified version as well. + +AC_DEFUN([AX_CREATE_TARGET_H], +[AC_REQUIRE([AC_CANONICAL_CPU_ARCH]) +AX_CREATE_TARGET_H_UPPER($1,$2) +AX_CREATE_TARGET_HOST_UPPER($1,$2) +]) + +AC_DEFUN([AC_CREATE_TARGET_OS_H], +[AC_REQUIRE([AC_CANONICAL_CPU_ARCH]) +AX_CREATE_TARGET_H_LOWER($1,$2) +AX_CREATE_TARGET_HOST_LOWER($1,$2) +]) + +AC_DEFUN([AX_CREATE_TARGET_H__], +[AC_REQUIRE([AC_CANONICAL_CPU_ARCH]) +AX_CREATE_TARGET_H_LOWER($1,$2) +AX_CREATE_TARGET_HOST_LOWER($1,$2) +]) + +dnl [(OUT-FILE [, PREFIX])] defaults: PREFIX=$PACKAGE OUTFILE=$PREFIX-target.h +AC_DEFUN([AC_CREATE_PREFIX_TARGET_H],[dnl +ac_prefix_conf_PKG=`echo ifelse($2, , $PACKAGE, $2)` +ac_prefix_conf_OUT=`echo ifelse($1, , $ac_prefix_conf_PKG-target.h, $1)` +ac_prefix_conf_PRE=`echo $ac_prefix_conf_PKG-target | sed -e 'y:abcdefghijklmnopqrstuvwxyz-:ABCDEFGHIJKLMNOPQRSTUVWXYZ_:'` +AX_CREATE_TARGET_H_UPPER($ac_prefix_conf_PRE,$ac_perfix_conf_OUT) +ac_prefix_conf_PRE=`echo __$ac_prefix_conf_PKG-host | sed -e 'y:abcdefghijklmnopqrstuvwxyz-:ABCDEFGHIJKLMNOPQRSTUVWXYZ_:'` +AX_CREATE_TARGET_HOST_UPPER($ac_prefix_conf_PRE,$ac_perfix_conf_OUT) +]) + +dnl [(OUT-FILE[, PREFIX])] defaults: PREFIX=$PACKAGE OUTFILE=$PREFIX-target.h +AC_DEFUN([AC_CREATE_PREFIX_TARGET_H_],[dnl +ac_prefix_conf_PKG=`echo ifelse($2, , $PACKAGE, $2)` +ac_prefix_conf_OUT=`echo ifelse($1, , $ac_prefix_conf_PKG-target.h, $1)` +ac_prefix_conf_PRE=`echo __$ac_prefix_conf_PKG-target | sed -e 'y:ABCDEFGHIJKLMNOPQRSTUVWXYZ-:abcdefghijklmnopqrstuvwxyz_:'` +AX_CREATE_TARGET_H_LOWER($ac_prefix_conf_PRE,$ac_perfix_conf_OUT) +ac_prefix_conf_PRE=`echo __$ac_prefix_conf_PKG-host | sed -e 'y:ABCDEFGHIJKLMNOPQRSTUVWXYZ-:abcdefghijklmnopqrstuvwxyz_:'` +AX_CREATE_TARGET_HOST_LOWER($ac_prefix_conf_PRE,$ac_perfix_conf_OUT) +]) + +AC_DEFUN([AX_CREATE_TARGET_H_FILE],[dnl +ac_need_target_h_file_new=true +]) + +AC_DEFUN([AX_CREATE_TARGET_H_UPPER], +[AC_REQUIRE([AC_CANONICAL_CPU_ARCH]) +AC_REQUIRE([AX_CREATE_TARGET_H_FILE]) +changequote({, })dnl +ac_need_target_h_file=`echo ifelse($1, , target.h, $1)` +ac_need_target_h_prefix=`echo ifelse($2, , target, $2) | sed -e 'y:abcdefghijklmnopqrstuvwxyz-:ABCDEFGHIJKLMNOPQRSTUVWXYZ_:' -e 's:[^A-Z0-9_]::g'` +# +target_os0=`echo "$target_os" | sed -e 'y:abcdefghijklmnopqrstuvwxyz.-:ABCDEFGHIJKLMNOPQRSTUVWXYZ__:' -e 's:[^A-Z0-9_]::g'` +target_os1=`echo "$target_os0" | sed -e 's:\([^0-9]*\).*:\1:' ` +target_os2=`echo "$target_os0" | sed -e 's:\([^_]*\).*:\1:' ` +target_os3=`echo "$target_os2" | sed -e 's:\([^0-9]*\).*:\1:' ` +# +target_cpu0=`echo "$target_cpu" | sed -e 'y:abcdefghijklmnopqrstuvwxyz.-:ABCDEFGHIJKLMNOPQRSTUVWXYZ__:' -e 's:[^A-Z0-9_]::g'` +target_cpu1=`echo "$target_cpu0" | sed -e 's:\([^0-9]*\).*:\1:' ` +target_cpu2=`echo "$target_cpu0" | sed -e 's:\([^_]*\).*:\1:' ` +target_cpu3=`echo "$target_cpu2" | sed -e 's:\([^0-9]*\).*:\1:' ` +# +target_cpu_arch0=`echo "$target_cpu_arch" | sed -e 'y:abcdefghijklmnopqrstuvwxyz:ABCDEFGHIJKLMNOPQRSTUVWXYZ:'` +# +changequote([, ])dnl +# +if $ac_need_target_h_file_new ; then +AC_MSG_RESULT(creating $ac_need_target_h_file - canonical system defines) +echo /'*' automatically generated by $PACKAGE configure '*'/ >$ac_need_target_h_file +echo /'*' on `date` '*'/ >>$ac_need_target_h_file +ac_need_target_h_file_new=false +fi +echo /'*' target uppercase defines '*'/ >>$ac_need_target_h_file +dnl +old1="" +old2="" +for i in $target_os0 $target_os1 $target_os2 $target_os3 "TYPE" +do + if test "$old1" != "$i"; then + if test "$old2" != "$i"; then + echo " " >>$ac_need_target_h_file + echo "#ifndef "$ac_need_target_h_prefix"_OS_"$i >>$ac_need_target_h_file + echo "#define "$ac_need_target_h_prefix"_OS_"$i '"'"$target_os"'"' >>$ac_need_target_h_file + echo "#endif" >>$ac_need_target_h_file + fi + fi + old2="$old1" + old1="$i" +done +# +old1="" +old2="" +for i in $target_cpu0 $target_cpu1 $target_cpu2 $target_cpu3 "TYPE" +do + if test "$old1" != "$i"; then + if test "$old2" != "$i"; then + echo " " >>$ac_need_target_h_file + echo "#ifndef "$ac_need_target_h_prefix"_CPU_"$i >>$ac_need_target_h_file + echo "#define "$ac_need_target_h_prefix"_CPU_"$i '"'"$target_cpu"'"' >>$ac_need_target_h_file + echo "#endif" >>$ac_need_target_h_file + fi + fi + old2="$old1" + old1="$i" +done +# +old1="" +old2="" +for i in $target_cpu_arch0 "TYPE" +do + if test "$old1" != "$i"; then + if test "$old2" != "$i"; then + echo " " >>$ac_need_target_h_file + echo "#ifndef "$ac_need_target_h_prefix"_ARCH_"$i >>$ac_need_target_h_file + echo "#define "$ac_need_target_h_prefix"_ARCH_"$i '"'"$target_cpu_arch"'"' >>$ac_need_target_h_file + echo "#endif" >>$ac_need_target_h_file + fi + fi + old2="$old1" + old1="$i" +done +]) + +dnl +dnl ... the lowercase variant ... +dnl +AC_DEFUN([AX_CREATE_TARGET_H_LOWER], +[AC_REQUIRE([AC_CANONICAL_CPU_ARCH]) +AC_REQUIRE([AX_CREATE_TARGET_H_FILE]) +changequote({, })dnl +ac_need_target_h_file=`echo ifelse($1, , target-os.h, $1)` +ac_need_target_h_prefix=`echo ifelse($2, , target, $2) | sed -e 'y:ABCDEFGHIJKLMNOPQRSTUVWXYZ-:abcdefghijklmnopqrstuvwxyz_:' -e 's:[^a-z0-9_]::g'` +# +target_os0=`echo "$target_os" | sed -e 'y:ABCDEFGHIJKLMNOPQRSTUVWXYZ.-:abcdefghijklmnopqrstuvwxyz__:' -e 's:[^a-z0-9_]::g'` +target_os1=`echo "$target_os0" | sed -e 's:\([^0-9]*\).*:\1:' ` +target_os2=`echo "$target_os0" | sed -e 's:\([^_]*\).*:\1:' ` +target_os3=`echo "$target_os2" | sed -e 's:\([^0-9]*\).*:\1:' ` +# +target_cpu0=`echo "$target_cpu" | sed -e 'y:ABCDEFGHIJKLMNOPQRSTUVWXYZ.-:abcdefghijklmnopqrstuvwxyz__:' -e 's:[^a-z0-9_]::g'` +target_cpu1=`echo "$target_cpu0" | sed -e 's:\([^0-9]*\).*:\1:' ` +target_cpu2=`echo "$target_cpu0" | sed -e 's:\([^_]*\).*:\1:' ` +target_cpu3=`echo "$target_cpu2" | sed -e 's:\([^0-9]*\).*:\1:' ` +# +target_cpu_arch0=`echo "$target_cpu_arch" | sed -e 'y:ABCDEFGHIJKLMNOPQRSTUVWXYZ:abcdefghijklmnopqrstuvwxyz:'` +# +changequote([, ])dnl +# +if $ac_need_target_h_file_new ; then +AC_MSG_RESULT(creating $ac_need_target_h_file - canonical system defines) +echo /'*' automatically generated by $PACKAGE configure '*'/ >$ac_need_target_h_file +echo /'*' on `date` '*'/ >>$ac_need_target_h_file +ac_need_target_h_file_new=false +fi +echo /'*' target lowercase defines '*'/ >>$ac_need_target_h_file +dnl +old1="" +old2="" +for i in $target_os0 $target_os1 $target_os2 $target_os3 "_"; +do + if test "$old1" != "$i"; then + if test "$old2" != "$i"; then + echo " " >>$ac_need_target_h_file + echo "#ifndef __"$ac_need_target_h_prefix"_os_"$i >>$ac_need_target_h_file + echo "#define __"$ac_need_target_h_prefix"_os_"$i '"'"$target_os"'"' >>$ac_need_target_h_file + echo "#endif" >>$ac_need_target_h_file + fi + fi + old2="$old1" + old1="$i" +done +# +old1="" +old2="" +for i in $target_cpu0 $target_cpu1 $target_cpu2 $target_cpu3 "_" +do + if test "$old1" != "$i"; then + if test "$old2" != "$i"; then + echo " " >>$ac_need_target_h_file + echo "#ifndef __"$ac_need_target_h_prefix"_cpu_"$i >>$ac_need_target_h_file + echo "#define __"$ac_need_target_h_prefix"_cpu_"$i '"'"$target_cpu"'"' >>$ac_need_target_h_file + echo "#endif" >>$ac_need_target_h_file + fi + fi + old2="$old1" + old1="$i" +done +# +old1="" +old2="" +for i in $target_cpu_arch0 "_" +do + if test "$old1" != "$i"; then + if test "$old2" != "$i"; then + echo " " >>$ac_need_target_h_file + echo "#ifndef __"$ac_need_target_h_prefix"_arch_"$i >>$ac_need_target_h_file + echo "#define __"$ac_need_target_h_prefix"_arch_"$i '"'"$target_cpu_arch"'"' >>$ac_need_target_h_file + echo "#endif" >>$ac_need_target_h_file + fi + fi + old2="$old1" + old1="$i" +done +]) + +dnl ------------------------------------------------------------------- +dnl +dnl ... the uppercase variant for the host ... +dnl +AC_DEFUN([AX_CREATE_TARGET_HOST_UPPER], +[AC_REQUIRE([AC_CANONICAL_CPU_ARCH]) +AC_REQUIRE([AX_CREATE_TARGET_H_FILE]) +changequote({, })dnl +ac_need_target_h_file=`echo ifelse($1, , target.h, $1)` +ac_need_target_h_prefix=`echo ifelse($2, , host, $2) | sed -e 'y:abcdefghijklmnopqrstuvwxyz-:ABCDEFGHIJKLMNOPQRSTUVWXYZ_:' -e 's:[^A-Z0-9_]::g'` +# +host_os0=`echo "$host_os" | sed -e 'y:abcdefghijklmnopqrstuvwxyz.-:ABCDEFGHIJKLMNOPQRSTUVWXYZ__:' -e 's:[^A-Z0-9_]::g'` +host_os1=`echo "$host_os0" | sed -e 's:\([^0-9]*\).*:\1:' ` +host_os2=`echo "$host_os0" | sed -e 's:\([^_]*\).*:\1:' ` +host_os3=`echo "$host_os2" | sed -e 's:\([^0-9]*\).*:\1:' ` +# +host_cpu0=`echo "$host_cpu" | sed -e 'y:abcdefghijklmnopqrstuvwxyz.-:ABCDEFGHIJKLMNOPQRSTUVWXYZ__:' -e 's:[^A-Z0-9]::g'` +host_cpu1=`echo "$host_cpu0" | sed -e 's:\([^0-9]*\).*:\1:' ` +host_cpu2=`echo "$host_cpu0" | sed -e 's:\([^_]*\).*:\1:' ` +host_cpu3=`echo "$host_cpu2" | sed -e 's:\([^0-9]*\).*:\1:' ` +# +host_cpu_arch0=`echo "$host_cpu_arch" | sed -e 'y:abcdefghijklmnopqrstuvwxyz:ABCDEFGHIJKLMNOPQRSTUVWXYZ:'` +# +changequote([, ])dnl +# +if $ac_need_target_h_file_new ; then +AC_MSG_RESULT(creating $ac_need_target_h_file - canonical system defines) +echo /'*' automatically generated by $PACKAGE configure '*'/ >$ac_need_target_h_file +echo /'*' on `date` '*'/ >>$ac_need_target_h_file +ac_need_target_h_file_new=false +fi +echo /'*' host uppercase defines '*'/ >>$ac_need_target_h_file +dnl +old1="" +old2="" +for i in $host_os0 $host_os1 $host_os2 $host_os3 "TYPE" +do + if test "$old1" != "$i"; then + if test "$old2" != "$i"; then + echo " " >>$ac_need_target_h_file + echo "#ifndef "$ac_need_target_h_prefix"_OS_"$i >>$ac_need_target_h_file + echo "#define "$ac_need_target_h_prefix"_OS_"$i '"'"$host_os"'"' >>$ac_need_target_h_file + echo "#endif" >>$ac_need_target_h_file + fi + fi + old2="$old1" + old1="$i" +done +# +old1="" +old2="" +for i in $host_cpu0 $host_cpu1 $host_cpu2 $host_cpu3 "TYPE" +do + if test "$old1" != "$i"; then + if test "$old2" != "$i"; then + echo " " >>$ac_need_target_h_file + echo "#ifndef "$ac_need_target_h_prefix"_CPU_"$i >>$ac_need_target_h_file + echo "#define "$ac_need_target_h_prefix"_CPU_"$i '"'"$host_cpu"'"' >>$ac_need_target_h_file + echo "#endif" >>$ac_need_target_h_file + fi + fi + old2="$old1" + old1="$i" +done +# +old1="" +old2="" +for i in $host_cpu_arch0 "TYPE" +do + if test "$old1" != "$i"; then + if test "$old2" != "$i"; then + echo " " >>$ac_need_target_h_file + echo "#ifndef "$ac_need_target_h_prefix"_ARCH_"$i >>$ac_need_target_h_file + echo "#define "$ac_need_target_h_prefix"_ARCH_"$i '"'"$host_cpu_arch"'"' >>$ac_need_target_h_file + echo "#endif" >>$ac_need_target_h_file + fi + fi + old2="$old1" + old1="$i" +done +]) + +dnl --------------------------------------------------------------------- +dnl +dnl ... the lowercase variant for the host ... +dnl +AC_DEFUN([AX_CREATE_TARGET_HOST_LOWER], +[AC_REQUIRE([AC_CANONICAL_CPU_ARCH]) +AC_REQUIRE([AX_CREATE_TARGET_H_FILE]) +changequote({, })dnl +ac_need_target_h_file=`echo ifelse($1, , target.h, $1)` +ac_need_target_h_prefix=`echo ifelse($2, , host, $2) | sed -e 'y:ABCDEFGHIJKLMNOPQRSTUVWXYZ-:abcdefghijklmnopqrstuvwxyz_:' -e 's:[^a-z0-9_]::g'` +# +host_os0=`echo "$host_os" | sed -e 'y:ABCDEFGHIJKLMNOPQRSTUVWXYZ.-:abcdefghijklmnopqrstuvwxyz__:' -e 's:[^a-z0-9_]::g'` +host_os1=`echo "$host_os0" | sed -e 's:\([^0-9]*\).*:\1:' ` +host_os2=`echo "$host_os0" | sed -e 's:\([^_]*\).*:\1:' ` +host_os3=`echo "$host_os2" | sed -e 's:\([^0-9]*\).*:\1:' ` +# +host_cpu0=`echo "$host_cpu" | sed -e 'y:ABCDEFGHIJKLMNOPQRSTUVWXYZ.-:abcdefghijklmnopqrstuvwxyz__:' -e 's:[^a-z0-9_]::g'` +host_cpu1=`echo "$host_cpu0" | sed -e 's:\([^0-9]*\).*:\1:' ` +host_cpu2=`echo "$host_cpu0" | sed -e 's:\([^_]*\).*:\1:' ` +host_cpu3=`echo "$host_cpu2" | sed -e 's:\([^0-9]*\).*:\1:' ` +# +host_cpu_arch0=`echo "$host_cpu_arch" | sed -e 'y:ABCDEFGHIJKLMNOPQRSTUVWXYZ:abcdefghijklmnopqrstuvwxyz:'` +# +changequote([, ])dnl +# +if $ac_need_target_h_file_new ; then +AC_MSG_RESULT(creating $ac_need_target_h_file - canonical system defines) +echo /'*' automatically generated by $PACKAGE configure '*'/ >$ac_need_target_h_file +echo /'*' on `date` '*'/ >>$ac_need_target_h_file +ac_need_target_h_file_new=false +fi +echo /'*' host lowercase defines '*'/ >>$ac_need_target_h_file +dnl +old1="" +old2="" +for i in $host_os0 $host_os1 $host_os2 $host_os3 "_"; +do + if test "$old1" != "$i"; then + if test "$old2" != "$i"; then + echo " " >>$ac_need_target_h_file + echo "#ifndef __"$ac_need_target_h_prefix"_os_"$i >>$ac_need_target_h_file + echo "#define __"$ac_need_target_h_prefix"_os_"$i '"'"$host_os"'"' >>$ac_need_target_h_file + echo "#endif" >>$ac_need_target_h_file + fi + fi + old2="$old1" + old1="$i" +done +# +old1="" +old2="" +for i in $host_cpu0 $host_cpu1 $host_cpu2 $host_cpu3 "_" +do + if test "$old1" != "$i"; then + if test "$old2" != "$i"; then + echo " " >>$ac_need_target_h_file + echo "#ifndef __"$ac_need_target_h_prefix"_cpu_"$i >>$ac_need_target_h_file + echo "#define __"$ac_need_target_h_prefix"_cpu_"$i '"'"$host_cpu"'"' >>$ac_need_target_h_file + echo "#endif" >>$ac_need_target_h_file + fi + fi + old2="$old1" + old1="$i" +done +# +old1="" +old2="" +for i in $host_cpu_arch0 "_" +do + if test "$old1" != "$i"; then + if test "$old2" != "$i"; then + echo " " >>$ac_need_target_h_file + echo "#ifndef __"$ac_need_target_h_prefix"_arch_"$i >>$ac_need_target_h_file + echo "#define __"$ac_need_target_h_prefix"_arch_"$i '"'"$host_cpu_arch"'"' >>$ac_need_target_h_file + echo "#endif" >>$ac_need_target_h_file + fi + fi + old2="$old1" + old1="$i" +done +]) + +dnl ------------------------------------------------------------------- + +dnl +dnl the instruction set architecture (ISA) has evolved for a small set +dnl of cpu types. So they often have specific names, e.g. sparclite, +dnl yet they share quite a few similarities. This macro will set the +dnl shell-var $target_cpu_arch to the basic type. Note that these +dnl names are often in conflict with their original 32-bit type name +dnl of these processors, just use them for directory-handling or add +dnl a prefix/suffix to distinguish them from $target_cpu +dnl +dnl this macros has been invented since config.guess is sometimes +dnl too specific about the cpu-type. I chose the names along the lines +dnl of linux/arch/ which is modelled after widespread arch-naming, IMHO. +dnl +AC_DEFUN([AC_CANONICAL_CPU_ARCH], +[AC_REQUIRE([AC_CANONICAL_SYSTEM]) +target_cpu_arch="unknown" +case $target_cpu in + i386*|i486*|i586*|i686*|i786*) target_cpu_arch=i386 ;; + power*) target_cpu_arch=ppc ;; + arm*) target_cpu_arch=arm ;; + sparc64*) target_cpu_arch=sparc64 ;; + sparc*) target_cpu_arch=sparc ;; + mips64*) target_cpu_arch=mips64 ;; + mips*) target_cpu_arch=mips ;; + alpha*) target_cpu_arch=alpha ;; + hppa1*) target_cpu_arch=hppa1 ;; + hppa2*) target_cpu_arch=hppa2 ;; + arm*) target_cpu_arch=arm ;; + m68???|mcf54??) target_cpu_arch=m68k ;; + *) target_cpu_arch="$target_cpu" ;; +esac + +host_cpu_arch="unknown" +case $host_cpu in + i386*|i486*|i586*|i686*|i786*) host_cpu_arch=i386 ;; + power*) host_cpu_arch=ppc ;; + arm*) host_cpu_arch=arm ;; + sparc64*) host_cpu_arch=sparc64 ;; + sparc*) host_cpu_arch=sparc ;; + mips64*) host_cpu_arch=mips64 ;; + mips*) host_cpu_arch=mips ;; + alpha*) host_cpu_arch=alpha ;; + hppa1*) host_cpu_arch=hppa1 ;; + hppa2*) host_cpu_arch=hppa2 ;; + arm*) host_cpu_arch=arm ;; + m68???|mcf54??) host_cpu_arch=m68k ;; + *) host_cpu_arch="$target_cpu" ;; +esac +]) |