mirror of https://github.com/ecmwf/eccodes.git
cleanup old unused code. Made json bufr_dump default
This commit is contained in:
parent
a622e452c3
commit
65cef10467
|
@ -1,14 +1,12 @@
|
||||||
#! /bin/sh
|
#! /bin/sh
|
||||||
# Attempt to guess a canonical system name.
|
# Attempt to guess a canonical system name.
|
||||||
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
|
# Copyright 1992-2013 Free Software Foundation, Inc.
|
||||||
# 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
|
|
||||||
# Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
timestamp='2009-11-20'
|
timestamp='2013-06-10'
|
||||||
|
|
||||||
# This file is free software; you can redistribute it and/or modify it
|
# This file is free software; you can redistribute it and/or modify it
|
||||||
# under the terms of the GNU General Public License as published by
|
# under the terms of the GNU General Public License as published by
|
||||||
# the Free Software Foundation; either version 2 of the License, or
|
# the Free Software Foundation; either version 3 of the License, or
|
||||||
# (at your option) any later version.
|
# (at your option) any later version.
|
||||||
#
|
#
|
||||||
# This program is distributed in the hope that it will be useful, but
|
# This program is distributed in the hope that it will be useful, but
|
||||||
|
@ -17,26 +15,22 @@ timestamp='2009-11-20'
|
||||||
# General Public License for more details.
|
# General Public License for more details.
|
||||||
#
|
#
|
||||||
# You should have received a copy of the GNU General Public License
|
# You should have received a copy of the GNU General Public License
|
||||||
# along with this program; if not, write to the Free Software
|
# along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA
|
|
||||||
# 02110-1301, USA.
|
|
||||||
#
|
#
|
||||||
# As a special exception to the GNU General Public License, if you
|
# As a special exception to the GNU General Public License, if you
|
||||||
# distribute this file as part of a program that contains a
|
# distribute this file as part of a program that contains a
|
||||||
# configuration script generated by Autoconf, you may include it under
|
# configuration script generated by Autoconf, you may include it under
|
||||||
# the same distribution terms that you use for the rest of that program.
|
# the same distribution terms that you use for the rest of that
|
||||||
|
# program. This Exception is an additional permission under section 7
|
||||||
|
# of the GNU General Public License, version 3 ("GPLv3").
|
||||||
# Originally written by Per Bothner. Please send patches (context
|
|
||||||
# diff format) to <config-patches@gnu.org> and include a ChangeLog
|
|
||||||
# entry.
|
|
||||||
#
|
#
|
||||||
# This script attempts to guess a canonical system name similar to
|
# Originally written by Per Bothner.
|
||||||
# config.sub. If it succeeds, it prints the system name on stdout, and
|
|
||||||
# exits with 0. Otherwise, it exits with 1.
|
|
||||||
#
|
#
|
||||||
# You can get the latest version of this script from:
|
# You can get the latest version of this script from:
|
||||||
# http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess;hb=HEAD
|
# http://git.savannah.gnu.org/gitweb/?p=config.git;a=blob_plain;f=config.guess;hb=HEAD
|
||||||
|
#
|
||||||
|
# Please send patches with a ChangeLog entry to config-patches@gnu.org.
|
||||||
|
|
||||||
|
|
||||||
me=`echo "$0" | sed -e 's,.*/,,'`
|
me=`echo "$0" | sed -e 's,.*/,,'`
|
||||||
|
|
||||||
|
@ -56,8 +50,7 @@ version="\
|
||||||
GNU config.guess ($timestamp)
|
GNU config.guess ($timestamp)
|
||||||
|
|
||||||
Originally written by Per Bothner.
|
Originally written by Per Bothner.
|
||||||
Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001,
|
Copyright 1992-2013 Free Software Foundation, Inc.
|
||||||
2002, 2003, 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This is free software; see the source for copying conditions. There is NO
|
This is free software; see the source for copying conditions. There is NO
|
||||||
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
|
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
|
||||||
|
@ -139,6 +132,27 @@ UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown
|
||||||
UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown
|
UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown
|
||||||
UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown
|
UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown
|
||||||
|
|
||||||
|
case "${UNAME_SYSTEM}" in
|
||||||
|
Linux|GNU|GNU/*)
|
||||||
|
# If the system lacks a compiler, then just pick glibc.
|
||||||
|
# We could probably try harder.
|
||||||
|
LIBC=gnu
|
||||||
|
|
||||||
|
eval $set_cc_for_build
|
||||||
|
cat <<-EOF > $dummy.c
|
||||||
|
#include <features.h>
|
||||||
|
#if defined(__UCLIBC__)
|
||||||
|
LIBC=uclibc
|
||||||
|
#elif defined(__dietlibc__)
|
||||||
|
LIBC=dietlibc
|
||||||
|
#else
|
||||||
|
LIBC=gnu
|
||||||
|
#endif
|
||||||
|
EOF
|
||||||
|
eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^LIBC'`
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
case "${UNAME_MACHINE}" in
|
case "${UNAME_MACHINE}" in
|
||||||
i?86)
|
i?86)
|
||||||
test -z "$VENDOR" && VENDOR=pc
|
test -z "$VENDOR" && VENDOR=pc
|
||||||
|
@ -154,7 +168,7 @@ test -f /etc/SuSE-release -o -f /.buildenv && VENDOR=suse
|
||||||
case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
|
case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
|
||||||
*:NetBSD:*:*)
|
*:NetBSD:*:*)
|
||||||
# NetBSD (nbsd) targets should (where applicable) match one or
|
# NetBSD (nbsd) targets should (where applicable) match one or
|
||||||
# more of the tupples: *-*-netbsdelf*, *-*-netbsdaout*,
|
# more of the tuples: *-*-netbsdelf*, *-*-netbsdaout*,
|
||||||
# *-*-netbsdecoff* and *-*-netbsd*. For targets that recently
|
# *-*-netbsdecoff* and *-*-netbsd*. For targets that recently
|
||||||
# switched to ELF, *-*-netbsd* would select the old
|
# switched to ELF, *-*-netbsd* would select the old
|
||||||
# object file format. This provides both forward
|
# object file format. This provides both forward
|
||||||
|
@ -211,6 +225,10 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
|
||||||
# CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used.
|
# CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used.
|
||||||
echo "${machine}-${os}${release}"
|
echo "${machine}-${os}${release}"
|
||||||
exit ;;
|
exit ;;
|
||||||
|
*:Bitrig:*:*)
|
||||||
|
UNAME_MACHINE_ARCH=`arch | sed 's/Bitrig.//'`
|
||||||
|
echo ${UNAME_MACHINE_ARCH}-${VENDOR}-bitrig${UNAME_RELEASE}
|
||||||
|
exit ;;
|
||||||
*:OpenBSD:*:*)
|
*:OpenBSD:*:*)
|
||||||
UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'`
|
UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'`
|
||||||
echo ${UNAME_MACHINE_ARCH}-${VENDOR}-openbsd${UNAME_RELEASE}
|
echo ${UNAME_MACHINE_ARCH}-${VENDOR}-openbsd${UNAME_RELEASE}
|
||||||
|
@ -279,7 +297,10 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
|
||||||
# A Xn.n version is an unreleased experimental baselevel.
|
# A Xn.n version is an unreleased experimental baselevel.
|
||||||
# 1.2 uses "1.2" for uname -r.
|
# 1.2 uses "1.2" for uname -r.
|
||||||
echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
|
echo ${UNAME_MACHINE}-dec-osf`echo ${UNAME_RELEASE} | sed -e 's/^[PVTX]//' | tr 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' 'abcdefghijklmnopqrstuvwxyz'`
|
||||||
exit ;;
|
# Reset EXIT trap before exiting to avoid spurious non-zero exit code.
|
||||||
|
exitcode=$?
|
||||||
|
trap '' 0
|
||||||
|
exit $exitcode ;;
|
||||||
Alpha\ *:Windows_NT*:*)
|
Alpha\ *:Windows_NT*:*)
|
||||||
# How do we know it's Interix rather than the generic POSIX subsystem?
|
# How do we know it's Interix rather than the generic POSIX subsystem?
|
||||||
# Should we change UNAME_MACHINE based on the output of uname instead
|
# Should we change UNAME_MACHINE based on the output of uname instead
|
||||||
|
@ -310,7 +331,7 @@ case "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" in
|
||||||
arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*)
|
arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*)
|
||||||
echo arm-acorn-riscix${UNAME_RELEASE}
|
echo arm-acorn-riscix${UNAME_RELEASE}
|
||||||
exit ;;
|
exit ;;
|
||||||
arm:riscos:*:*|arm:RISCOS:*:*)
|
arm*:riscos:*:*|arm*:RISCOS:*:*)
|
||||||
echo arm-${VENDOR}-riscos
|
echo arm-${VENDOR}-riscos
|
||||||
exit ;;
|
exit ;;
|
||||||
SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*)
|
SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*)
|
||||||
|
@ -561,7 +582,7 @@ EOF
|
||||||
echo rs6000-ibm-aix3.2
|
echo rs6000-ibm-aix3.2
|
||||||
fi
|
fi
|
||||||
exit ;;
|
exit ;;
|
||||||
*:AIX:*:[456])
|
*:AIX:*:[4567])
|
||||||
IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'`
|
IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'`
|
||||||
if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then
|
if /usr/sbin/lsattr -El ${IBM_CPU_ID} | grep ' POWER' >/dev/null 2>&1; then
|
||||||
IBM_ARCH=rs6000
|
IBM_ARCH=rs6000
|
||||||
|
@ -798,21 +819,26 @@ EOF
|
||||||
echo ${UNAME_MACHINE}-${VENDOR}-bsdi${UNAME_RELEASE}
|
echo ${UNAME_MACHINE}-${VENDOR}-bsdi${UNAME_RELEASE}
|
||||||
exit ;;
|
exit ;;
|
||||||
*:FreeBSD:*:*)
|
*:FreeBSD:*:*)
|
||||||
case ${UNAME_MACHINE} in
|
UNAME_PROCESSOR=`/usr/bin/uname -p`
|
||||||
pc98)
|
case ${UNAME_PROCESSOR} in
|
||||||
echo i386-${VENDOR}-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;;
|
|
||||||
amd64)
|
amd64)
|
||||||
echo x86_64-${VENDOR}-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;;
|
echo x86_64-${VENDOR}-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;;
|
||||||
*)
|
*)
|
||||||
echo ${UNAME_MACHINE}-${VENDOR}-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;;
|
echo ${UNAME_PROCESSOR}-${VENDOR}-freebsd`echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'` ;;
|
||||||
esac
|
esac
|
||||||
exit ;;
|
exit ;;
|
||||||
i*:CYGWIN*:*)
|
i*:CYGWIN*:*)
|
||||||
echo ${UNAME_MACHINE}-pc-cygwin
|
echo ${UNAME_MACHINE}-pc-cygwin
|
||||||
exit ;;
|
exit ;;
|
||||||
|
*:MINGW64*:*)
|
||||||
|
echo ${UNAME_MACHINE}-pc-mingw64
|
||||||
|
exit ;;
|
||||||
*:MINGW*:*)
|
*:MINGW*:*)
|
||||||
echo ${UNAME_MACHINE}-pc-mingw32
|
echo ${UNAME_MACHINE}-pc-mingw32
|
||||||
exit ;;
|
exit ;;
|
||||||
|
i*:MSYS*:*)
|
||||||
|
echo ${UNAME_MACHINE}-pc-msys
|
||||||
|
exit ;;
|
||||||
i*:windows32*:*)
|
i*:windows32*:*)
|
||||||
# uname -m includes "-pc" on this system.
|
# uname -m includes "-pc" on this system.
|
||||||
echo ${UNAME_MACHINE}-mingw32
|
echo ${UNAME_MACHINE}-mingw32
|
||||||
|
@ -858,15 +884,22 @@ EOF
|
||||||
exit ;;
|
exit ;;
|
||||||
*:GNU:*:*)
|
*:GNU:*:*)
|
||||||
# the GNU system
|
# the GNU system
|
||||||
echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-${VENDOR}-gnu`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'`
|
echo `echo ${UNAME_MACHINE}|sed -e 's,[-/].*$,,'`-${VENDOR}-${LIBC}`echo ${UNAME_RELEASE}|sed -e 's,/.*$,,'`
|
||||||
exit ;;
|
exit ;;
|
||||||
*:GNU/*:*:*)
|
*:GNU/*:*:*)
|
||||||
# other systems with GNU libc and userland
|
# other systems with GNU libc and userland
|
||||||
echo ${UNAME_MACHINE}-${VENDOR}-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr '[A-Z]' '[a-z]'``echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`-gnu
|
echo ${UNAME_MACHINE}-${VENDOR}-`echo ${UNAME_SYSTEM} | sed 's,^[^/]*/,,' | tr '[A-Z]' '[a-z]'``echo ${UNAME_RELEASE}|sed -e 's/[-(].*//'`-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
i*86:Minix:*:*)
|
i*86:Minix:*:*)
|
||||||
echo ${UNAME_MACHINE}-pc-minix
|
echo ${UNAME_MACHINE}-pc-minix
|
||||||
exit ;;
|
exit ;;
|
||||||
|
aarch64:Linux:*:*)
|
||||||
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
|
exit ;;
|
||||||
|
aarch64_be:Linux:*:*)
|
||||||
|
UNAME_MACHINE=aarch64_be
|
||||||
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
|
exit ;;
|
||||||
alpha:Linux:*:*)
|
alpha:Linux:*:*)
|
||||||
case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in
|
case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' < /proc/cpuinfo` in
|
||||||
EV5) UNAME_MACHINE=alphaev5 ;;
|
EV5) UNAME_MACHINE=alphaev5 ;;
|
||||||
|
@ -878,50 +911,54 @@ EOF
|
||||||
EV68*) UNAME_MACHINE=alphaev68 ;;
|
EV68*) UNAME_MACHINE=alphaev68 ;;
|
||||||
esac
|
esac
|
||||||
objdump --private-headers /bin/sh | grep -q ld.so.1
|
objdump --private-headers /bin/sh | grep -q ld.so.1
|
||||||
if test "$?" = 0 ; then LIBC="libc1" ; else LIBC="" ; fi
|
if test "$?" = 0 ; then LIBC="gnulibc1" ; fi
|
||||||
echo ${UNAME_MACHINE}-${VENDOR}-linux-gnu${LIBC}
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
|
exit ;;
|
||||||
|
arc:Linux:*:* | arceb:Linux:*:*)
|
||||||
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
arm*:Linux:*:*)
|
arm*:Linux:*:*)
|
||||||
eval $set_cc_for_build
|
eval $set_cc_for_build
|
||||||
if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \
|
if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \
|
||||||
| grep -q __ARM_EABI__
|
| grep -q __ARM_EABI__
|
||||||
then
|
then
|
||||||
echo ${UNAME_MACHINE}-${VENDOR}-linux-gnu
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
else
|
else
|
||||||
echo ${UNAME_MACHINE}-${VENDOR}-linux-gnueabi
|
if echo __ARM_PCS_VFP | $CC_FOR_BUILD -E - 2>/dev/null \
|
||||||
|
| grep -q __ARM_PCS_VFP
|
||||||
|
then
|
||||||
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}eabi
|
||||||
|
else
|
||||||
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}eabihf
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
exit ;;
|
exit ;;
|
||||||
avr32*:Linux:*:*)
|
avr32*:Linux:*:*)
|
||||||
echo ${UNAME_MACHINE}-${VENDOR}-linux-gnu
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
cris:Linux:*:*)
|
cris:Linux:*:*)
|
||||||
echo cris-axis-linux-gnu
|
echo ${UNAME_MACHINE}-axis-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
crisv32:Linux:*:*)
|
crisv32:Linux:*:*)
|
||||||
echo crisv32-axis-linux-gnu
|
echo ${UNAME_MACHINE}-axis-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
frv:Linux:*:*)
|
frv:Linux:*:*)
|
||||||
echo frv-${VENDOR}-linux-gnu
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
|
exit ;;
|
||||||
|
hexagon:Linux:*:*)
|
||||||
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
i*86:Linux:*:*)
|
i*86:Linux:*:*)
|
||||||
LIBC=gnu
|
echo ${UNAME_MACHINE}-pc-linux-${LIBC}
|
||||||
eval $set_cc_for_build
|
|
||||||
sed 's/^ //' << EOF >$dummy.c
|
|
||||||
#ifdef __dietlibc__
|
|
||||||
LIBC=dietlibc
|
|
||||||
#endif
|
|
||||||
EOF
|
|
||||||
eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^LIBC'`
|
|
||||||
echo "${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}"
|
|
||||||
exit ;;
|
exit ;;
|
||||||
ia64:Linux:*:*)
|
ia64:Linux:*:*)
|
||||||
echo ${UNAME_MACHINE}-${VENDOR}-linux-gnu
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
m32r*:Linux:*:*)
|
m32r*:Linux:*:*)
|
||||||
echo ${UNAME_MACHINE}-${VENDOR}-linux-gnu
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
m68*:Linux:*:*)
|
m68*:Linux:*:*)
|
||||||
echo ${UNAME_MACHINE}-${VENDOR}-linux-gnu
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
mips:Linux:*:* | mips64:Linux:*:*)
|
mips:Linux:*:* | mips64:Linux:*:*)
|
||||||
eval $set_cc_for_build
|
eval $set_cc_for_build
|
||||||
|
@ -940,51 +977,63 @@ EOF
|
||||||
#endif
|
#endif
|
||||||
EOF
|
EOF
|
||||||
eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^CPU'`
|
eval `$CC_FOR_BUILD -E $dummy.c 2>/dev/null | grep '^CPU'`
|
||||||
test x"${CPU}" != x && { echo "${CPU}-${VENDOR}-linux-gnu"; exit; }
|
test x"${CPU}" != x && { echo "${CPU}-${VENDOR}-linux-${LIBC}"; exit; }
|
||||||
;;
|
;;
|
||||||
|
or1k:Linux:*:*)
|
||||||
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
|
exit ;;
|
||||||
or32:Linux:*:*)
|
or32:Linux:*:*)
|
||||||
echo or32-${VENDOR}-linux-gnu
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
padre:Linux:*:*)
|
padre:Linux:*:*)
|
||||||
echo sparc-${VENDOR}-linux-gnu
|
echo sparc-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
parisc64:Linux:*:* | hppa64:Linux:*:*)
|
parisc64:Linux:*:* | hppa64:Linux:*:*)
|
||||||
echo hppa64-${VENDOR}-linux-gnu
|
echo hppa64-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
parisc:Linux:*:* | hppa:Linux:*:*)
|
parisc:Linux:*:* | hppa:Linux:*:*)
|
||||||
# Look for CPU level
|
# Look for CPU level
|
||||||
case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in
|
case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in
|
||||||
PA7*) echo hppa1.1-${VENDOR}-linux-gnu ;;
|
PA7*) echo hppa1.1-${VENDOR}-linux-${LIBC} ;;
|
||||||
PA8*) echo hppa2.0-${VENDOR}-linux-gnu ;;
|
PA8*) echo hppa2.0-${VENDOR}-linux-${LIBC} ;;
|
||||||
*) echo hppa-${VENDOR}-linux-gnu ;;
|
*) echo hppa-${VENDOR}-linux-${LIBC} ;;
|
||||||
esac
|
esac
|
||||||
exit ;;
|
exit ;;
|
||||||
ppc64:Linux:*:*)
|
ppc64:Linux:*:*)
|
||||||
echo powerpc64-${VENDOR}-linux-gnu
|
echo powerpc64-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
ppc:Linux:*:*)
|
ppc:Linux:*:*)
|
||||||
echo powerpc-${VENDOR}-linux-gnu
|
echo powerpc-${VENDOR}-linux-${LIBC}
|
||||||
|
exit ;;
|
||||||
|
ppc64le:Linux:*:*)
|
||||||
|
echo powerpc64le-${VENDOR}-linux-${LIBC}
|
||||||
|
exit ;;
|
||||||
|
ppcle:Linux:*:*)
|
||||||
|
echo powerpcle-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
s390:Linux:*:* | s390x:Linux:*:*)
|
s390:Linux:*:* | s390x:Linux:*:*)
|
||||||
echo ${UNAME_MACHINE}-ibm-linux
|
echo ${UNAME_MACHINE}-ibm-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
sh64*:Linux:*:*)
|
sh64*:Linux:*:*)
|
||||||
echo ${UNAME_MACHINE}-${VENDOR}-linux-gnu
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
sh*:Linux:*:*)
|
sh*:Linux:*:*)
|
||||||
echo ${UNAME_MACHINE}-${VENDOR}-linux-gnu
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
sparc:Linux:*:* | sparc64:Linux:*:*)
|
sparc:Linux:*:* | sparc64:Linux:*:*)
|
||||||
echo ${UNAME_MACHINE}-${VENDOR}-linux-gnu
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
|
exit ;;
|
||||||
|
tile*:Linux:*:*)
|
||||||
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
vax:Linux:*:*)
|
vax:Linux:*:*)
|
||||||
echo ${UNAME_MACHINE}-dec-linux-gnu
|
echo ${UNAME_MACHINE}-dec-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
x86_64:Linux:*:*)
|
x86_64:Linux:*:*)
|
||||||
echo x86_64-${VENDOR}-linux-gnu
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
xtensa*:Linux:*:*)
|
xtensa*:Linux:*:*)
|
||||||
echo ${UNAME_MACHINE}-${VENDOR}-linux-gnu
|
echo ${UNAME_MACHINE}-${VENDOR}-linux-${LIBC}
|
||||||
exit ;;
|
exit ;;
|
||||||
i*86:DYNIX/ptx:4*:*)
|
i*86:DYNIX/ptx:4*:*)
|
||||||
# ptx 4.0 does uname -s correctly, with DYNIX/ptx in there.
|
# ptx 4.0 does uname -s correctly, with DYNIX/ptx in there.
|
||||||
|
@ -1015,7 +1064,7 @@ EOF
|
||||||
echo ${UNAME_MACHINE}-pc-syllable
|
echo ${UNAME_MACHINE}-pc-syllable
|
||||||
exit ;;
|
exit ;;
|
||||||
i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.[02]*:*)
|
i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.[02]*:*)
|
||||||
echo i386-${VENDOR}-lynxos${UNAME_RELEASE}
|
echo i386-${VENODR}-lynxos${UNAME_RELEASE}
|
||||||
exit ;;
|
exit ;;
|
||||||
i*86:*DOS:*:*)
|
i*86:*DOS:*:*)
|
||||||
echo ${UNAME_MACHINE}-pc-msdosdjgpp
|
echo ${UNAME_MACHINE}-pc-msdosdjgpp
|
||||||
|
@ -1074,7 +1123,7 @@ EOF
|
||||||
if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then
|
if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then
|
||||||
echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4
|
echo i860-stardent-sysv${UNAME_RELEASE} # Stardent Vistra i860-SVR4
|
||||||
else # Add other i860-SVR4 vendors below as they are discovered.
|
else # Add other i860-SVR4 vendors below as they are discovered.
|
||||||
echo i860-${VENDOR}-sysv${UNAME_RELEASE} # Unknown i860-SVR4
|
echo i860-${VENODR}-sysv${UNAME_RELEASE} # Unknown i860-SVR4
|
||||||
fi
|
fi
|
||||||
exit ;;
|
exit ;;
|
||||||
mini*:CTIX:SYS*5:*)
|
mini*:CTIX:SYS*5:*)
|
||||||
|
@ -1188,6 +1237,9 @@ EOF
|
||||||
BePC:Haiku:*:*) # Haiku running on Intel PC compatible.
|
BePC:Haiku:*:*) # Haiku running on Intel PC compatible.
|
||||||
echo i586-pc-haiku
|
echo i586-pc-haiku
|
||||||
exit ;;
|
exit ;;
|
||||||
|
x86_64:Haiku:*:*)
|
||||||
|
echo x86_64-${VENDOR}-haiku
|
||||||
|
exit ;;
|
||||||
SX-4:SUPER-UX:*:*)
|
SX-4:SUPER-UX:*:*)
|
||||||
echo sx4-nec-superux${UNAME_RELEASE}
|
echo sx4-nec-superux${UNAME_RELEASE}
|
||||||
exit ;;
|
exit ;;
|
||||||
|
@ -1214,19 +1266,21 @@ EOF
|
||||||
exit ;;
|
exit ;;
|
||||||
*:Darwin:*:*)
|
*:Darwin:*:*)
|
||||||
UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown
|
UNAME_PROCESSOR=`uname -p` || UNAME_PROCESSOR=unknown
|
||||||
case $UNAME_PROCESSOR in
|
|
||||||
i386)
|
|
||||||
eval $set_cc_for_build
|
eval $set_cc_for_build
|
||||||
|
if test "$UNAME_PROCESSOR" = unknown ; then
|
||||||
|
UNAME_PROCESSOR=powerpc
|
||||||
|
fi
|
||||||
if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then
|
if [ "$CC_FOR_BUILD" != 'no_compiler_found' ]; then
|
||||||
if (echo '#ifdef __LP64__'; echo IS_64BIT_ARCH; echo '#endif') | \
|
if (echo '#ifdef __LP64__'; echo IS_64BIT_ARCH; echo '#endif') | \
|
||||||
(CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \
|
(CCOPTS= $CC_FOR_BUILD -E - 2>/dev/null) | \
|
||||||
grep IS_64BIT_ARCH >/dev/null
|
grep IS_64BIT_ARCH >/dev/null
|
||||||
then
|
then
|
||||||
UNAME_PROCESSOR="x86_64"
|
case $UNAME_PROCESSOR in
|
||||||
fi
|
i386) UNAME_PROCESSOR=x86_64 ;;
|
||||||
fi ;;
|
powerpc) UNAME_PROCESSOR=powerpc64 ;;
|
||||||
unknown) UNAME_PROCESSOR=powerpc ;;
|
|
||||||
esac
|
esac
|
||||||
|
fi
|
||||||
|
fi
|
||||||
echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE}
|
echo ${UNAME_PROCESSOR}-apple-darwin${UNAME_RELEASE}
|
||||||
exit ;;
|
exit ;;
|
||||||
*:procnto*:*:* | *:QNX:[0123456789]*:*)
|
*:procnto*:*:* | *:QNX:[0123456789]*:*)
|
||||||
|
@ -1240,7 +1294,10 @@ EOF
|
||||||
*:QNX:*:4*)
|
*:QNX:*:4*)
|
||||||
echo i386-pc-qnx
|
echo i386-pc-qnx
|
||||||
exit ;;
|
exit ;;
|
||||||
NSE-?:NONSTOP_KERNEL:*:*)
|
NEO-?:NONSTOP_KERNEL:*:*)
|
||||||
|
echo neo-tandem-nsk${UNAME_RELEASE}
|
||||||
|
exit ;;
|
||||||
|
NSE-*:NONSTOP_KERNEL:*:*)
|
||||||
echo nse-tandem-nsk${UNAME_RELEASE}
|
echo nse-tandem-nsk${UNAME_RELEASE}
|
||||||
exit ;;
|
exit ;;
|
||||||
NSR-?:NONSTOP_KERNEL:*:*)
|
NSR-?:NONSTOP_KERNEL:*:*)
|
||||||
|
@ -1309,11 +1366,11 @@ EOF
|
||||||
i*86:AROS:*:*)
|
i*86:AROS:*:*)
|
||||||
echo ${UNAME_MACHINE}-pc-aros
|
echo ${UNAME_MACHINE}-pc-aros
|
||||||
exit ;;
|
exit ;;
|
||||||
|
x86_64:VMkernel:*:*)
|
||||||
|
echo ${UNAME_MACHINE}-${VENDOR}-esx
|
||||||
|
exit ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
#echo '(No uname command or uname output not recognized.)' 1>&2
|
|
||||||
#echo "${UNAME_MACHINE}:${UNAME_SYSTEM}:${UNAME_RELEASE}:${UNAME_VERSION}" 1>&2
|
|
||||||
|
|
||||||
eval $set_cc_for_build
|
eval $set_cc_for_build
|
||||||
cat >$dummy.c <<EOF
|
cat >$dummy.c <<EOF
|
||||||
#ifdef _SEQUENT_
|
#ifdef _SEQUENT_
|
||||||
|
|
|
@ -1,38 +1,31 @@
|
||||||
#! /bin/sh
|
#! /bin/sh
|
||||||
# Configuration validation subroutine script.
|
# Configuration validation subroutine script.
|
||||||
# Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999,
|
# Copyright 1992-2013 Free Software Foundation, Inc.
|
||||||
# 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009
|
|
||||||
# Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
timestamp='2009-11-20'
|
timestamp='2013-04-24'
|
||||||
|
|
||||||
# This file is (in principle) common to ALL GNU software.
|
# This file is free software; you can redistribute it and/or modify it
|
||||||
# The presence of a machine in this file suggests that SOME GNU software
|
# under the terms of the GNU General Public License as published by
|
||||||
# can handle that machine. It does not imply ALL GNU software can.
|
# the Free Software Foundation; either version 3 of the License, or
|
||||||
#
|
|
||||||
# This file 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.
|
# (at your option) any later version.
|
||||||
#
|
#
|
||||||
# This program is distributed in the hope that it will be useful,
|
# This program is distributed in the hope that it will be useful, but
|
||||||
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
# WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
# GNU General Public License for more details.
|
# General Public License for more details.
|
||||||
#
|
#
|
||||||
# You should have received a copy of the GNU General Public License
|
# You should have received a copy of the GNU General Public License
|
||||||
# along with this program; if not, write to the Free Software
|
# along with this program; if not, see <http://www.gnu.org/licenses/>.
|
||||||
# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston, MA
|
|
||||||
# 02110-1301, USA.
|
|
||||||
#
|
#
|
||||||
# As a special exception to the GNU General Public License, if you
|
# As a special exception to the GNU General Public License, if you
|
||||||
# distribute this file as part of a program that contains a
|
# distribute this file as part of a program that contains a
|
||||||
# configuration script generated by Autoconf, you may include it under
|
# configuration script generated by Autoconf, you may include it under
|
||||||
# the same distribution terms that you use for the rest of that program.
|
# the same distribution terms that you use for the rest of that
|
||||||
|
# program. This Exception is an additional permission under section 7
|
||||||
|
# of the GNU General Public License, version 3 ("GPLv3").
|
||||||
|
|
||||||
|
|
||||||
# Please send patches to <config-patches@gnu.org>. Submit a context
|
# Please send patches with a ChangeLog entry to config-patches@gnu.org.
|
||||||
# diff and a properly formatted GNU ChangeLog entry.
|
|
||||||
#
|
#
|
||||||
# Configuration subroutine to validate and canonicalize a configuration type.
|
# Configuration subroutine to validate and canonicalize a configuration type.
|
||||||
# Supply the specified configuration type as an argument.
|
# Supply the specified configuration type as an argument.
|
||||||
|
@ -75,8 +68,7 @@ Report bugs and patches to <config-patches@gnu.org>."
|
||||||
version="\
|
version="\
|
||||||
GNU config.sub ($timestamp)
|
GNU config.sub ($timestamp)
|
||||||
|
|
||||||
Copyright (C) 1992, 1993, 1994, 1995, 1996, 1997, 1998, 1999, 2000, 2001,
|
Copyright 1992-2013 Free Software Foundation, Inc.
|
||||||
2002, 2003, 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc.
|
|
||||||
|
|
||||||
This is free software; see the source for copying conditions. There is NO
|
This is free software; see the source for copying conditions. There is NO
|
||||||
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
|
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE."
|
||||||
|
@ -123,13 +115,18 @@ esac
|
||||||
# Here we must recognize all the valid KERNEL-OS combinations.
|
# Here we must recognize all the valid KERNEL-OS combinations.
|
||||||
maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
|
maybe_os=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\2/'`
|
||||||
case $maybe_os in
|
case $maybe_os in
|
||||||
nto-qnx* | linux-gnu* | linux-dietlibc | linux-newlib* | linux-uclibc* | \
|
nto-qnx* | linux-gnu* | linux-android* | linux-dietlibc | linux-newlib* | \
|
||||||
uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | knetbsd*-gnu* | netbsd*-gnu* | \
|
linux-musl* | linux-uclibc* | uclinux-uclibc* | uclinux-gnu* | kfreebsd*-gnu* | \
|
||||||
|
knetbsd*-gnu* | netbsd*-gnu* | \
|
||||||
kopensolaris*-gnu* | \
|
kopensolaris*-gnu* | \
|
||||||
storm-chaos* | os2-emx* | rtmk-nova*)
|
storm-chaos* | os2-emx* | rtmk-nova*)
|
||||||
os=-$maybe_os
|
os=-$maybe_os
|
||||||
basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`
|
basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`
|
||||||
;;
|
;;
|
||||||
|
android-linux)
|
||||||
|
os=-linux-android
|
||||||
|
basic_machine=`echo $1 | sed 's/^\(.*\)-\([^-]*-[^-]*\)$/\1/'`-unknown
|
||||||
|
;;
|
||||||
*)
|
*)
|
||||||
basic_machine=`echo $1 | sed 's/-[^-]*$//'`
|
basic_machine=`echo $1 | sed 's/-[^-]*$//'`
|
||||||
if [ $basic_machine != $1 ]
|
if [ $basic_machine != $1 ]
|
||||||
|
@ -152,7 +149,7 @@ case $os in
|
||||||
-convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\
|
-convergent* | -ncr* | -news | -32* | -3600* | -3100* | -hitachi* |\
|
||||||
-c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \
|
-c[123]* | -convex* | -sun | -crds | -omron* | -dg | -ultra | -tti* | \
|
||||||
-harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \
|
-harris | -dolphin | -highlevel | -gould | -cbm | -ns | -masscomp | \
|
||||||
-apple | -axis | -knuth | -cray | -microblaze)
|
-apple | -axis | -knuth | -cray | -microblaze*)
|
||||||
os=
|
os=
|
||||||
basic_machine=$1
|
basic_machine=$1
|
||||||
;;
|
;;
|
||||||
|
@ -221,6 +218,12 @@ case $os in
|
||||||
-isc*)
|
-isc*)
|
||||||
basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
|
basic_machine=`echo $1 | sed -e 's/86-.*/86-pc/'`
|
||||||
;;
|
;;
|
||||||
|
-lynx*178)
|
||||||
|
os=-lynxos178
|
||||||
|
;;
|
||||||
|
-lynx*5)
|
||||||
|
os=-lynxos5
|
||||||
|
;;
|
||||||
-lynx*)
|
-lynx*)
|
||||||
os=-lynxos
|
os=-lynxos
|
||||||
;;
|
;;
|
||||||
|
@ -245,20 +248,27 @@ case $basic_machine in
|
||||||
# Some are omitted here because they have special meanings below.
|
# Some are omitted here because they have special meanings below.
|
||||||
1750a | 580 \
|
1750a | 580 \
|
||||||
| a29k \
|
| a29k \
|
||||||
|
| aarch64 | aarch64_be \
|
||||||
| alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \
|
| alpha | alphaev[4-8] | alphaev56 | alphaev6[78] | alphapca5[67] \
|
||||||
| alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] | alpha64pca5[67] \
|
| alpha64 | alpha64ev[4-8] | alpha64ev56 | alpha64ev6[78] | alpha64pca5[67] \
|
||||||
| am33_2.0 \
|
| am33_2.0 \
|
||||||
| arc | arm | arm[bl]e | arme[lb] | armv[2345] | armv[345][lb] | avr | avr32 \
|
| arc | arceb \
|
||||||
|
| arm | arm[bl]e | arme[lb] | armv[2-8] | armv[3-8][lb] | armv7[arm] \
|
||||||
|
| avr | avr32 \
|
||||||
|
| be32 | be64 \
|
||||||
| bfin \
|
| bfin \
|
||||||
| c4x | clipper \
|
| c4x | clipper \
|
||||||
| d10v | d30v | dlx | dsp16xx \
|
| d10v | d30v | dlx | dsp16xx \
|
||||||
|
| epiphany \
|
||||||
| fido | fr30 | frv \
|
| fido | fr30 | frv \
|
||||||
| h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \
|
| h8300 | h8500 | hppa | hppa1.[01] | hppa2.0 | hppa2.0[nw] | hppa64 \
|
||||||
|
| hexagon \
|
||||||
| i370 | i860 | i960 | ia64 \
|
| i370 | i860 | i960 | ia64 \
|
||||||
| ip2k | iq2000 \
|
| ip2k | iq2000 \
|
||||||
|
| le32 | le64 \
|
||||||
| lm32 \
|
| lm32 \
|
||||||
| m32c | m32r | m32rle | m68000 | m68k | m88k \
|
| m32c | m32r | m32rle | m68000 | m68k | m88k \
|
||||||
| maxq | mb | microblaze | mcore | mep | metag \
|
| maxq | mb | microblaze | microblazeel | mcore | mep | metag \
|
||||||
| mips | mipsbe | mipseb | mipsel | mipsle \
|
| mips | mipsbe | mipseb | mipsel | mipsle \
|
||||||
| mips16 \
|
| mips16 \
|
||||||
| mips64 | mips64el \
|
| mips64 | mips64el \
|
||||||
|
@ -276,34 +286,45 @@ case $basic_machine in
|
||||||
| mipsisa64r2 | mipsisa64r2el \
|
| mipsisa64r2 | mipsisa64r2el \
|
||||||
| mipsisa64sb1 | mipsisa64sb1el \
|
| mipsisa64sb1 | mipsisa64sb1el \
|
||||||
| mipsisa64sr71k | mipsisa64sr71kel \
|
| mipsisa64sr71k | mipsisa64sr71kel \
|
||||||
|
| mipsr5900 | mipsr5900el \
|
||||||
| mipstx39 | mipstx39el \
|
| mipstx39 | mipstx39el \
|
||||||
| mn10200 | mn10300 \
|
| mn10200 | mn10300 \
|
||||||
| moxie \
|
| moxie \
|
||||||
| mt \
|
| mt \
|
||||||
| msp430 \
|
| msp430 \
|
||||||
| nios | nios2 \
|
| nds32 | nds32le | nds32be \
|
||||||
|
| nios | nios2 | nios2eb | nios2el \
|
||||||
| ns16k | ns32k \
|
| ns16k | ns32k \
|
||||||
| or32 \
|
| open8 \
|
||||||
|
| or1k | or32 \
|
||||||
| pdp10 | pdp11 | pj | pjl \
|
| pdp10 | pdp11 | pj | pjl \
|
||||||
| powerpc | powerpc64 | powerpc64le | powerpcle | ppcbe \
|
| powerpc | powerpc64 | powerpc64le | powerpcle \
|
||||||
| pyramid \
|
| pyramid \
|
||||||
| rx \
|
| rl78 | rx \
|
||||||
| score \
|
| score \
|
||||||
| sh | sh[1234] | sh[24]a | sh[24]aeb | sh[23]e | sh[34]eb | sheb | shbe | shle | sh[1234]le | sh3ele \
|
| sh | sh[1234] | sh[24]a | sh[24]aeb | sh[23]e | sh[34]eb | sheb | shbe | shle | sh[1234]le | sh3ele \
|
||||||
| sh64 | sh64le \
|
| sh64 | sh64le \
|
||||||
| sparc | sparc64 | sparc64b | sparc64v | sparc86x | sparclet | sparclite \
|
| sparc | sparc64 | sparc64b | sparc64v | sparc86x | sparclet | sparclite \
|
||||||
| sparcv8 | sparcv9 | sparcv9b | sparcv9v \
|
| sparcv8 | sparcv9 | sparcv9b | sparcv9v \
|
||||||
| spu | strongarm \
|
| spu \
|
||||||
| tahoe | thumb | tic4x | tic80 | tron \
|
| tahoe | tic4x | tic54x | tic55x | tic6x | tic80 | tron \
|
||||||
| ubicom32 \
|
| ubicom32 \
|
||||||
| v850 | v850e \
|
| v850 | v850e | v850e1 | v850e2 | v850es | v850e2v3 \
|
||||||
| we32k \
|
| we32k \
|
||||||
| x86 | xc16x | xscale | xscalee[bl] | xstormy16 | xtensa \
|
| x86 | xc16x | xstormy16 | xtensa \
|
||||||
| z8k | z80)
|
| z8k | z80)
|
||||||
basic_machine=$basic_machine-unknown
|
basic_machine=$basic_machine-unknown
|
||||||
;;
|
;;
|
||||||
m6811 | m68hc11 | m6812 | m68hc12 | picochip)
|
c54x)
|
||||||
# Motorola 68HC11/12.
|
basic_machine=tic54x-unknown
|
||||||
|
;;
|
||||||
|
c55x)
|
||||||
|
basic_machine=tic55x-unknown
|
||||||
|
;;
|
||||||
|
c6x)
|
||||||
|
basic_machine=tic6x-unknown
|
||||||
|
;;
|
||||||
|
m6811 | m68hc11 | m6812 | m68hc12 | m68hcs12x | picochip)
|
||||||
basic_machine=$basic_machine-unknown
|
basic_machine=$basic_machine-unknown
|
||||||
os=-none
|
os=-none
|
||||||
;;
|
;;
|
||||||
|
@ -313,6 +334,21 @@ case $basic_machine in
|
||||||
basic_machine=mt-unknown
|
basic_machine=mt-unknown
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
strongarm | thumb | xscale)
|
||||||
|
basic_machine=arm-unknown
|
||||||
|
;;
|
||||||
|
xgate)
|
||||||
|
basic_machine=$basic_machine-unknown
|
||||||
|
os=-none
|
||||||
|
;;
|
||||||
|
xscaleeb)
|
||||||
|
basic_machine=armeb-unknown
|
||||||
|
;;
|
||||||
|
|
||||||
|
xscaleel)
|
||||||
|
basic_machine=armel-unknown
|
||||||
|
;;
|
||||||
|
|
||||||
# We use `pc' rather than `unknown'
|
# We use `pc' rather than `unknown'
|
||||||
# because (1) that's what they normally are, and
|
# because (1) that's what they normally are, and
|
||||||
# (2) the word "unknown" tends to confuse beginning users.
|
# (2) the word "unknown" tends to confuse beginning users.
|
||||||
|
@ -327,25 +363,30 @@ case $basic_machine in
|
||||||
# Recognize the basic CPU types with company name.
|
# Recognize the basic CPU types with company name.
|
||||||
580-* \
|
580-* \
|
||||||
| a29k-* \
|
| a29k-* \
|
||||||
|
| aarch64-* | aarch64_be-* \
|
||||||
| alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \
|
| alpha-* | alphaev[4-8]-* | alphaev56-* | alphaev6[78]-* \
|
||||||
| alpha64-* | alpha64ev[4-8]-* | alpha64ev56-* | alpha64ev6[78]-* \
|
| alpha64-* | alpha64ev[4-8]-* | alpha64ev56-* | alpha64ev6[78]-* \
|
||||||
| alphapca5[67]-* | alpha64pca5[67]-* | arc-* \
|
| alphapca5[67]-* | alpha64pca5[67]-* | arc-* | arceb-* \
|
||||||
| arm-* | armbe-* | armle-* | armeb-* | armv*-* \
|
| arm-* | armbe-* | armle-* | armeb-* | armv*-* \
|
||||||
| avr-* | avr32-* \
|
| avr-* | avr32-* \
|
||||||
|
| be32-* | be64-* \
|
||||||
| bfin-* | bs2000-* \
|
| bfin-* | bs2000-* \
|
||||||
| c[123]* | c30-* | [cjt]90-* | c4x-* | c54x-* | c55x-* | c6x-* \
|
| c[123]* | c30-* | [cjt]90-* | c4x-* \
|
||||||
| clipper-* | craynv-* | cydra-* \
|
| clipper-* | craynv-* | cydra-* \
|
||||||
| d10v-* | d30v-* | dlx-* \
|
| d10v-* | d30v-* | dlx-* \
|
||||||
| elxsi-* \
|
| elxsi-* \
|
||||||
| f30[01]-* | f700-* | fido-* | fr30-* | frv-* | fx80-* \
|
| f30[01]-* | f700-* | fido-* | fr30-* | frv-* | fx80-* \
|
||||||
| h8300-* | h8500-* \
|
| h8300-* | h8500-* \
|
||||||
| hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \
|
| hppa-* | hppa1.[01]-* | hppa2.0-* | hppa2.0[nw]-* | hppa64-* \
|
||||||
|
| hexagon-* \
|
||||||
| i*86-* | i860-* | i960-* | ia64-* \
|
| i*86-* | i860-* | i960-* | ia64-* \
|
||||||
| ip2k-* | iq2000-* \
|
| ip2k-* | iq2000-* \
|
||||||
|
| le32-* | le64-* \
|
||||||
| lm32-* \
|
| lm32-* \
|
||||||
| m32c-* | m32r-* | m32rle-* \
|
| m32c-* | m32r-* | m32rle-* \
|
||||||
| m68000-* | m680[012346]0-* | m68360-* | m683?2-* | m68k-* \
|
| m68000-* | m680[012346]0-* | m68360-* | m683?2-* | m68k-* \
|
||||||
| m88110-* | m88k-* | maxq-* | mcore-* | metag-* | microblaze-* \
|
| m88110-* | m88k-* | maxq-* | mcore-* | metag-* \
|
||||||
|
| microblaze-* | microblazeel-* \
|
||||||
| mips-* | mipsbe-* | mipseb-* | mipsel-* | mipsle-* \
|
| mips-* | mipsbe-* | mipseb-* | mipsel-* | mipsle-* \
|
||||||
| mips16-* \
|
| mips16-* \
|
||||||
| mips64-* | mips64el-* \
|
| mips64-* | mips64el-* \
|
||||||
|
@ -363,29 +404,34 @@ case $basic_machine in
|
||||||
| mipsisa64r2-* | mipsisa64r2el-* \
|
| mipsisa64r2-* | mipsisa64r2el-* \
|
||||||
| mipsisa64sb1-* | mipsisa64sb1el-* \
|
| mipsisa64sb1-* | mipsisa64sb1el-* \
|
||||||
| mipsisa64sr71k-* | mipsisa64sr71kel-* \
|
| mipsisa64sr71k-* | mipsisa64sr71kel-* \
|
||||||
|
| mipsr5900-* | mipsr5900el-* \
|
||||||
| mipstx39-* | mipstx39el-* \
|
| mipstx39-* | mipstx39el-* \
|
||||||
| mmix-* \
|
| mmix-* \
|
||||||
| mt-* \
|
| mt-* \
|
||||||
| msp430-* \
|
| msp430-* \
|
||||||
| nios-* | nios2-* \
|
| nds32-* | nds32le-* | nds32be-* \
|
||||||
|
| nios-* | nios2-* | nios2eb-* | nios2el-* \
|
||||||
| none-* | np1-* | ns16k-* | ns32k-* \
|
| none-* | np1-* | ns16k-* | ns32k-* \
|
||||||
|
| open8-* \
|
||||||
| orion-* \
|
| orion-* \
|
||||||
| pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \
|
| pdp10-* | pdp11-* | pj-* | pjl-* | pn-* | power-* \
|
||||||
| powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* | ppcbe-* \
|
| powerpc-* | powerpc64-* | powerpc64le-* | powerpcle-* \
|
||||||
| pyramid-* \
|
| pyramid-* \
|
||||||
| romp-* | rs6000-* | rx-* \
|
| rl78-* | romp-* | rs6000-* | rx-* \
|
||||||
| sh-* | sh[1234]-* | sh[24]a-* | sh[24]aeb-* | sh[23]e-* | sh[34]eb-* | sheb-* | shbe-* \
|
| sh-* | sh[1234]-* | sh[24]a-* | sh[24]aeb-* | sh[23]e-* | sh[34]eb-* | sheb-* | shbe-* \
|
||||||
| shle-* | sh[1234]le-* | sh3ele-* | sh64-* | sh64le-* \
|
| shle-* | sh[1234]le-* | sh3ele-* | sh64-* | sh64le-* \
|
||||||
| sparc-* | sparc64-* | sparc64b-* | sparc64v-* | sparc86x-* | sparclet-* \
|
| sparc-* | sparc64-* | sparc64b-* | sparc64v-* | sparc86x-* | sparclet-* \
|
||||||
| sparclite-* \
|
| sparclite-* \
|
||||||
| sparcv8-* | sparcv9-* | sparcv9b-* | sparcv9v-* | strongarm-* | sv1-* | sx?-* \
|
| sparcv8-* | sparcv9-* | sparcv9b-* | sparcv9v-* | sv1-* | sx?-* \
|
||||||
| tahoe-* | thumb-* \
|
| tahoe-* \
|
||||||
| tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* | tile-* \
|
| tic30-* | tic4x-* | tic54x-* | tic55x-* | tic6x-* | tic80-* \
|
||||||
|
| tile*-* \
|
||||||
| tron-* \
|
| tron-* \
|
||||||
| ubicom32-* \
|
| ubicom32-* \
|
||||||
| v850-* | v850e-* | vax-* \
|
| v850-* | v850e-* | v850e1-* | v850es-* | v850e2-* | v850e2v3-* \
|
||||||
|
| vax-* \
|
||||||
| we32k-* \
|
| we32k-* \
|
||||||
| x86-* | x86_64-* | xc16x-* | xps100-* | xscale-* | xscalee[bl]-* \
|
| x86-* | x86_64-* | xc16x-* | xps100-* \
|
||||||
| xstormy16-* | xtensa*-* \
|
| xstormy16-* | xtensa*-* \
|
||||||
| ymp-* \
|
| ymp-* \
|
||||||
| z8k-* | z80-*)
|
| z8k-* | z80-*)
|
||||||
|
@ -480,6 +526,15 @@ case $basic_machine in
|
||||||
basic_machine=powerpc-ibm
|
basic_machine=powerpc-ibm
|
||||||
os=-cnk
|
os=-cnk
|
||||||
;;
|
;;
|
||||||
|
c54x-*)
|
||||||
|
basic_machine=tic54x-`echo $basic_machine | sed 's/^[^-]*-//'`
|
||||||
|
;;
|
||||||
|
c55x-*)
|
||||||
|
basic_machine=tic55x-`echo $basic_machine | sed 's/^[^-]*-//'`
|
||||||
|
;;
|
||||||
|
c6x-*)
|
||||||
|
basic_machine=tic6x-`echo $basic_machine | sed 's/^[^-]*-//'`
|
||||||
|
;;
|
||||||
c90)
|
c90)
|
||||||
basic_machine=c90-cray
|
basic_machine=c90-cray
|
||||||
os=-unicos
|
os=-unicos
|
||||||
|
@ -516,7 +571,7 @@ case $basic_machine in
|
||||||
basic_machine=craynv-cray
|
basic_machine=craynv-cray
|
||||||
os=-unicosmp
|
os=-unicosmp
|
||||||
;;
|
;;
|
||||||
cr16)
|
cr16 | cr16-*)
|
||||||
basic_machine=cr16-unknown
|
basic_machine=cr16-unknown
|
||||||
os=-elf
|
os=-elf
|
||||||
;;
|
;;
|
||||||
|
@ -674,7 +729,6 @@ case $basic_machine in
|
||||||
i370-ibm* | ibm*)
|
i370-ibm* | ibm*)
|
||||||
basic_machine=i370-ibm
|
basic_machine=i370-ibm
|
||||||
;;
|
;;
|
||||||
# I'm not sure what "Sysv32" means. Should this be sysv3.2?
|
|
||||||
i*86v32)
|
i*86v32)
|
||||||
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
basic_machine=`echo $1 | sed -e 's/86.*/86-pc/'`
|
||||||
os=-sysv32
|
os=-sysv32
|
||||||
|
@ -732,9 +786,13 @@ case $basic_machine in
|
||||||
basic_machine=ns32k-utek
|
basic_machine=ns32k-utek
|
||||||
os=-sysv
|
os=-sysv
|
||||||
;;
|
;;
|
||||||
microblaze)
|
microblaze*)
|
||||||
basic_machine=microblaze-xilinx
|
basic_machine=microblaze-xilinx
|
||||||
;;
|
;;
|
||||||
|
mingw64)
|
||||||
|
basic_machine=x86_64-pc
|
||||||
|
os=-mingw64
|
||||||
|
;;
|
||||||
mingw32)
|
mingw32)
|
||||||
basic_machine=i386-pc
|
basic_machine=i386-pc
|
||||||
os=-mingw32
|
os=-mingw32
|
||||||
|
@ -771,10 +829,18 @@ case $basic_machine in
|
||||||
ms1-*)
|
ms1-*)
|
||||||
basic_machine=`echo $basic_machine | sed -e 's/ms1-/mt-/'`
|
basic_machine=`echo $basic_machine | sed -e 's/ms1-/mt-/'`
|
||||||
;;
|
;;
|
||||||
|
msys)
|
||||||
|
basic_machine=i386-pc
|
||||||
|
os=-msys
|
||||||
|
;;
|
||||||
mvs)
|
mvs)
|
||||||
basic_machine=i370-ibm
|
basic_machine=i370-ibm
|
||||||
os=-mvs
|
os=-mvs
|
||||||
;;
|
;;
|
||||||
|
nacl)
|
||||||
|
basic_machine=le32-unknown
|
||||||
|
os=-nacl
|
||||||
|
;;
|
||||||
ncr3000)
|
ncr3000)
|
||||||
basic_machine=i486-ncr
|
basic_machine=i486-ncr
|
||||||
os=-sysv4
|
os=-sysv4
|
||||||
|
@ -839,6 +905,12 @@ case $basic_machine in
|
||||||
np1)
|
np1)
|
||||||
basic_machine=np1-gould
|
basic_machine=np1-gould
|
||||||
;;
|
;;
|
||||||
|
neo-tandem)
|
||||||
|
basic_machine=neo-tandem
|
||||||
|
;;
|
||||||
|
nse-tandem)
|
||||||
|
basic_machine=nse-tandem
|
||||||
|
;;
|
||||||
nsr-tandem)
|
nsr-tandem)
|
||||||
basic_machine=nsr-tandem
|
basic_machine=nsr-tandem
|
||||||
;;
|
;;
|
||||||
|
@ -921,9 +993,10 @@ case $basic_machine in
|
||||||
;;
|
;;
|
||||||
power) basic_machine=power-ibm
|
power) basic_machine=power-ibm
|
||||||
;;
|
;;
|
||||||
ppc) basic_machine=powerpc-unknown
|
ppc | ppcbe) basic_machine=powerpc-unknown
|
||||||
;;
|
;;
|
||||||
ppc-*) basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'`
|
ppc-* | ppcbe-*)
|
||||||
|
basic_machine=powerpc-`echo $basic_machine | sed 's/^[^-]*-//'`
|
||||||
;;
|
;;
|
||||||
ppcle | powerpclittle | ppc-le | powerpc-little)
|
ppcle | powerpclittle | ppc-le | powerpc-little)
|
||||||
basic_machine=powerpcle-unknown
|
basic_machine=powerpcle-unknown
|
||||||
|
@ -948,7 +1021,11 @@ case $basic_machine in
|
||||||
basic_machine=i586-unknown
|
basic_machine=i586-unknown
|
||||||
os=-pw32
|
os=-pw32
|
||||||
;;
|
;;
|
||||||
rdos)
|
rdos | rdos64)
|
||||||
|
basic_machine=x86_64-pc
|
||||||
|
os=-rdos
|
||||||
|
;;
|
||||||
|
rdos32)
|
||||||
basic_machine=i386-pc
|
basic_machine=i386-pc
|
||||||
os=-rdos
|
os=-rdos
|
||||||
;;
|
;;
|
||||||
|
@ -1017,6 +1094,9 @@ case $basic_machine in
|
||||||
basic_machine=i860-stratus
|
basic_machine=i860-stratus
|
||||||
os=-sysv4
|
os=-sysv4
|
||||||
;;
|
;;
|
||||||
|
strongarm-* | thumb-*)
|
||||||
|
basic_machine=arm-`echo $basic_machine | sed 's/^[^-]*-//'`
|
||||||
|
;;
|
||||||
sun2)
|
sun2)
|
||||||
basic_machine=m68000-sun
|
basic_machine=m68000-sun
|
||||||
;;
|
;;
|
||||||
|
@ -1073,20 +1153,8 @@ case $basic_machine in
|
||||||
basic_machine=t90-cray
|
basic_machine=t90-cray
|
||||||
os=-unicos
|
os=-unicos
|
||||||
;;
|
;;
|
||||||
tic54x | c54x*)
|
|
||||||
basic_machine=tic54x-unknown
|
|
||||||
os=-coff
|
|
||||||
;;
|
|
||||||
tic55x | c55x*)
|
|
||||||
basic_machine=tic55x-unknown
|
|
||||||
os=-coff
|
|
||||||
;;
|
|
||||||
tic6x | c6x*)
|
|
||||||
basic_machine=tic6x-unknown
|
|
||||||
os=-coff
|
|
||||||
;;
|
|
||||||
tile*)
|
tile*)
|
||||||
basic_machine=tile-unknown
|
basic_machine=$basic_machine-unknown
|
||||||
os=-linux-gnu
|
os=-linux-gnu
|
||||||
;;
|
;;
|
||||||
tx39)
|
tx39)
|
||||||
|
@ -1156,6 +1224,9 @@ case $basic_machine in
|
||||||
xps | xps100)
|
xps | xps100)
|
||||||
basic_machine=xps100-honeywell
|
basic_machine=xps100-honeywell
|
||||||
;;
|
;;
|
||||||
|
xscale-* | xscalee[bl]-*)
|
||||||
|
basic_machine=`echo $basic_machine | sed 's/^xscale/arm/'`
|
||||||
|
;;
|
||||||
ymp)
|
ymp)
|
||||||
basic_machine=ymp-cray
|
basic_machine=ymp-cray
|
||||||
os=-unicos
|
os=-unicos
|
||||||
|
@ -1281,20 +1352,21 @@ case $os in
|
||||||
-gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \
|
-gnu* | -bsd* | -mach* | -minix* | -genix* | -ultrix* | -irix* \
|
||||||
| -*vms* | -sco* | -esix* | -isc* | -aix* | -cnk* | -sunos | -sunos[34]*\
|
| -*vms* | -sco* | -esix* | -isc* | -aix* | -cnk* | -sunos | -sunos[34]*\
|
||||||
| -hpux* | -unos* | -osf* | -luna* | -dgux* | -auroraux* | -solaris* \
|
| -hpux* | -unos* | -osf* | -luna* | -dgux* | -auroraux* | -solaris* \
|
||||||
| -sym* | -kopensolaris* \
|
| -sym* | -kopensolaris* | -plan9* \
|
||||||
| -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \
|
| -amigaos* | -amigados* | -msdos* | -newsos* | -unicos* | -aof* \
|
||||||
| -aos* | -aros* \
|
| -aos* | -aros* \
|
||||||
| -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \
|
| -nindy* | -vxsim* | -vxworks* | -ebmon* | -hms* | -mvs* \
|
||||||
| -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \
|
| -clix* | -riscos* | -uniplus* | -iris* | -rtu* | -xenix* \
|
||||||
| -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* \
|
| -hiux* | -386bsd* | -knetbsd* | -mirbsd* | -netbsd* \
|
||||||
| -openbsd* | -solidbsd* \
|
| -bitrig* | -openbsd* | -solidbsd* \
|
||||||
| -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \
|
| -ekkobsd* | -kfreebsd* | -freebsd* | -riscix* | -lynxos* \
|
||||||
| -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \
|
| -bosx* | -nextstep* | -cxux* | -aout* | -elf* | -oabi* \
|
||||||
| -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \
|
| -ptx* | -coff* | -ecoff* | -winnt* | -domain* | -vsta* \
|
||||||
| -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \
|
| -udi* | -eabi* | -lites* | -ieee* | -go32* | -aux* \
|
||||||
| -chorusos* | -chorusrdb* | -cegcc* \
|
| -chorusos* | -chorusrdb* | -cegcc* \
|
||||||
| -cygwin* | -pe* | -psos* | -moss* | -proelf* | -rtems* \
|
| -cygwin* | -msys* | -pe* | -psos* | -moss* | -proelf* | -rtems* \
|
||||||
| -mingw32* | -linux-gnu* | -linux-newlib* | -linux-uclibc* \
|
| -mingw32* | -mingw64* | -linux-gnu* | -linux-android* \
|
||||||
|
| -linux-newlib* | -linux-musl* | -linux-uclibc* \
|
||||||
| -uxpv* | -beos* | -mpeix* | -udk* \
|
| -uxpv* | -beos* | -mpeix* | -udk* \
|
||||||
| -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \
|
| -interix* | -uwin* | -mks* | -rhapsody* | -darwin* | -opened* \
|
||||||
| -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \
|
| -openstep* | -oskit* | -conix* | -pw32* | -nonstopux* \
|
||||||
|
@ -1426,15 +1498,14 @@ case $os in
|
||||||
-aros*)
|
-aros*)
|
||||||
os=-aros
|
os=-aros
|
||||||
;;
|
;;
|
||||||
-kaos*)
|
|
||||||
os=-kaos
|
|
||||||
;;
|
|
||||||
-zvmoe)
|
-zvmoe)
|
||||||
os=-zvmoe
|
os=-zvmoe
|
||||||
;;
|
;;
|
||||||
-dicos*)
|
-dicos*)
|
||||||
os=-dicos
|
os=-dicos
|
||||||
;;
|
;;
|
||||||
|
-nacl*)
|
||||||
|
;;
|
||||||
-none)
|
-none)
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
|
@ -1475,6 +1546,18 @@ case $basic_machine in
|
||||||
c4x-* | tic4x-*)
|
c4x-* | tic4x-*)
|
||||||
os=-coff
|
os=-coff
|
||||||
;;
|
;;
|
||||||
|
hexagon-*)
|
||||||
|
os=-elf
|
||||||
|
;;
|
||||||
|
tic54x-*)
|
||||||
|
os=-coff
|
||||||
|
;;
|
||||||
|
tic55x-*)
|
||||||
|
os=-coff
|
||||||
|
;;
|
||||||
|
tic6x-*)
|
||||||
|
os=-coff
|
||||||
|
;;
|
||||||
# This must come before the *-dec entry.
|
# This must come before the *-dec entry.
|
||||||
pdp10-*)
|
pdp10-*)
|
||||||
os=-tops20
|
os=-tops20
|
||||||
|
@ -1493,9 +1576,6 @@ case $basic_machine in
|
||||||
;;
|
;;
|
||||||
m68000-sun)
|
m68000-sun)
|
||||||
os=-sunos3
|
os=-sunos3
|
||||||
# This also exists in the configure program, but was not the
|
|
||||||
# default.
|
|
||||||
# os=-sunos4
|
|
||||||
;;
|
;;
|
||||||
m68*-cisco)
|
m68*-cisco)
|
||||||
os=-aout
|
os=-aout
|
||||||
|
@ -1509,6 +1589,9 @@ case $basic_machine in
|
||||||
mips*-*)
|
mips*-*)
|
||||||
os=-elf
|
os=-elf
|
||||||
;;
|
;;
|
||||||
|
or1k-*)
|
||||||
|
os=-elf
|
||||||
|
;;
|
||||||
or32-*)
|
or32-*)
|
||||||
os=-coff
|
os=-coff
|
||||||
;;
|
;;
|
||||||
|
|
423
config/depcomp
423
config/depcomp
|
@ -1,10 +1,9 @@
|
||||||
#! /bin/sh
|
#! /bin/sh
|
||||||
# depcomp - compile a program generating dependencies as side-effects
|
# depcomp - compile a program generating dependencies as side-effects
|
||||||
|
|
||||||
scriptversion=2009-04-28.21; # UTC
|
scriptversion=2013-05-30.07; # UTC
|
||||||
|
|
||||||
# Copyright (C) 1999, 2000, 2003, 2004, 2005, 2006, 2007, 2009 Free
|
# Copyright (C) 1999-2013 Free Software Foundation, Inc.
|
||||||
# Software Foundation, Inc.
|
|
||||||
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
# 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
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
@ -28,7 +27,7 @@ scriptversion=2009-04-28.21; # UTC
|
||||||
|
|
||||||
case $1 in
|
case $1 in
|
||||||
'')
|
'')
|
||||||
echo "$0: No command. Try \`$0 --help' for more information." 1>&2
|
echo "$0: No command. Try '$0 --help' for more information." 1>&2
|
||||||
exit 1;
|
exit 1;
|
||||||
;;
|
;;
|
||||||
-h | --h*)
|
-h | --h*)
|
||||||
|
@ -40,11 +39,11 @@ as side-effects.
|
||||||
|
|
||||||
Environment variables:
|
Environment variables:
|
||||||
depmode Dependency tracking mode.
|
depmode Dependency tracking mode.
|
||||||
source Source file read by `PROGRAMS ARGS'.
|
source Source file read by 'PROGRAMS ARGS'.
|
||||||
object Object file output by `PROGRAMS ARGS'.
|
object Object file output by 'PROGRAMS ARGS'.
|
||||||
DEPDIR directory where to store dependencies.
|
DEPDIR directory where to store dependencies.
|
||||||
depfile Dependency file to output.
|
depfile Dependency file to output.
|
||||||
tmpdepfile Temporary file to use when outputing dependencies.
|
tmpdepfile Temporary file to use when outputting dependencies.
|
||||||
libtool Whether libtool is used (yes/no).
|
libtool Whether libtool is used (yes/no).
|
||||||
|
|
||||||
Report bugs to <bug-automake@gnu.org>.
|
Report bugs to <bug-automake@gnu.org>.
|
||||||
|
@ -57,6 +56,66 @@ EOF
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
# Get the directory component of the given path, and save it in the
|
||||||
|
# global variables '$dir'. Note that this directory component will
|
||||||
|
# be either empty or ending with a '/' character. This is deliberate.
|
||||||
|
set_dir_from ()
|
||||||
|
{
|
||||||
|
case $1 in
|
||||||
|
*/*) dir=`echo "$1" | sed -e 's|/[^/]*$|/|'`;;
|
||||||
|
*) dir=;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
# Get the suffix-stripped basename of the given path, and save it the
|
||||||
|
# global variable '$base'.
|
||||||
|
set_base_from ()
|
||||||
|
{
|
||||||
|
base=`echo "$1" | sed -e 's|^.*/||' -e 's/\.[^.]*$//'`
|
||||||
|
}
|
||||||
|
|
||||||
|
# If no dependency file was actually created by the compiler invocation,
|
||||||
|
# we still have to create a dummy depfile, to avoid errors with the
|
||||||
|
# Makefile "include basename.Plo" scheme.
|
||||||
|
make_dummy_depfile ()
|
||||||
|
{
|
||||||
|
echo "#dummy" > "$depfile"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Factor out some common post-processing of the generated depfile.
|
||||||
|
# Requires the auxiliary global variable '$tmpdepfile' to be set.
|
||||||
|
aix_post_process_depfile ()
|
||||||
|
{
|
||||||
|
# If the compiler actually managed to produce a dependency file,
|
||||||
|
# post-process it.
|
||||||
|
if test -f "$tmpdepfile"; then
|
||||||
|
# Each line is of the form 'foo.o: dependency.h'.
|
||||||
|
# Do two passes, one to just change these to
|
||||||
|
# $object: dependency.h
|
||||||
|
# and one to simply output
|
||||||
|
# dependency.h:
|
||||||
|
# which is needed to avoid the deleted-header problem.
|
||||||
|
{ sed -e "s,^.*\.[$lower]*:,$object:," < "$tmpdepfile"
|
||||||
|
sed -e "s,^.*\.[$lower]*:[$tab ]*,," -e 's,$,:,' < "$tmpdepfile"
|
||||||
|
} > "$depfile"
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
else
|
||||||
|
make_dummy_depfile
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
# A tabulation character.
|
||||||
|
tab=' '
|
||||||
|
# A newline character.
|
||||||
|
nl='
|
||||||
|
'
|
||||||
|
# Character ranges might be problematic outside the C locale.
|
||||||
|
# These definitions help.
|
||||||
|
upper=ABCDEFGHIJKLMNOPQRSTUVWXYZ
|
||||||
|
lower=abcdefghijklmnopqrstuvwxyz
|
||||||
|
digits=0123456789
|
||||||
|
alpha=${upper}${lower}
|
||||||
|
|
||||||
if test -z "$depmode" || test -z "$source" || test -z "$object"; then
|
if test -z "$depmode" || test -z "$source" || test -z "$object"; then
|
||||||
echo "depcomp: Variables source, object and depmode must be set" 1>&2
|
echo "depcomp: Variables source, object and depmode must be set" 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
|
@ -69,6 +128,9 @@ tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`}
|
||||||
|
|
||||||
rm -f "$tmpdepfile"
|
rm -f "$tmpdepfile"
|
||||||
|
|
||||||
|
# Avoid interferences from the environment.
|
||||||
|
gccflag= dashmflag=
|
||||||
|
|
||||||
# Some modes work just like other modes, but use different flags. We
|
# Some modes work just like other modes, but use different flags. We
|
||||||
# parameterize here, but still list the modes in the big case below,
|
# parameterize here, but still list the modes in the big case below,
|
||||||
# to make depend.m4 easier to write. Note that we *cannot* use a case
|
# to make depend.m4 easier to write. Note that we *cannot* use a case
|
||||||
|
@ -90,10 +152,24 @@ if test "$depmode" = msvcmsys; then
|
||||||
# This is just like msvisualcpp but w/o cygpath translation.
|
# This is just like msvisualcpp but w/o cygpath translation.
|
||||||
# Just convert the backslash-escaped backslashes to single forward
|
# Just convert the backslash-escaped backslashes to single forward
|
||||||
# slashes to satisfy depend.m4
|
# slashes to satisfy depend.m4
|
||||||
cygpath_u="sed s,\\\\\\\\,/,g"
|
cygpath_u='sed s,\\\\,/,g'
|
||||||
depmode=msvisualcpp
|
depmode=msvisualcpp
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
if test "$depmode" = msvc7msys; then
|
||||||
|
# This is just like msvc7 but w/o cygpath translation.
|
||||||
|
# Just convert the backslash-escaped backslashes to single forward
|
||||||
|
# slashes to satisfy depend.m4
|
||||||
|
cygpath_u='sed s,\\\\,/,g'
|
||||||
|
depmode=msvc7
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test "$depmode" = xlc; then
|
||||||
|
# IBM C/C++ Compilers xlc/xlC can output gcc-like dependency information.
|
||||||
|
gccflag=-qmakedep=gcc,-MF
|
||||||
|
depmode=gcc
|
||||||
|
fi
|
||||||
|
|
||||||
case "$depmode" in
|
case "$depmode" in
|
||||||
gcc3)
|
gcc3)
|
||||||
## gcc 3 implements dependency tracking that does exactly what
|
## gcc 3 implements dependency tracking that does exactly what
|
||||||
|
@ -114,8 +190,7 @@ gcc3)
|
||||||
done
|
done
|
||||||
"$@"
|
"$@"
|
||||||
stat=$?
|
stat=$?
|
||||||
if test $stat -eq 0; then :
|
if test $stat -ne 0; then
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile"
|
rm -f "$tmpdepfile"
|
||||||
exit $stat
|
exit $stat
|
||||||
fi
|
fi
|
||||||
|
@ -123,13 +198,17 @@ gcc3)
|
||||||
;;
|
;;
|
||||||
|
|
||||||
gcc)
|
gcc)
|
||||||
|
## Note that this doesn't just cater to obsosete pre-3.x GCC compilers.
|
||||||
|
## but also to in-use compilers like IMB xlc/xlC and the HP C compiler.
|
||||||
|
## (see the conditional assignment to $gccflag above).
|
||||||
## There are various ways to get dependency output from gcc. Here's
|
## There are various ways to get dependency output from gcc. Here's
|
||||||
## why we pick this rather obscure method:
|
## why we pick this rather obscure method:
|
||||||
## - Don't want to use -MD because we'd like the dependencies to end
|
## - Don't want to use -MD because we'd like the dependencies to end
|
||||||
## up in a subdir. Having to rename by hand is ugly.
|
## up in a subdir. Having to rename by hand is ugly.
|
||||||
## (We might end up doing this anyway to support other compilers.)
|
## (We might end up doing this anyway to support other compilers.)
|
||||||
## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like
|
## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like
|
||||||
## -MM, not -M (despite what the docs say).
|
## -MM, not -M (despite what the docs say). Also, it might not be
|
||||||
|
## supported by the other compilers which use the 'gcc' depmode.
|
||||||
## - Using -M directly means running the compiler twice (even worse
|
## - Using -M directly means running the compiler twice (even worse
|
||||||
## than renaming).
|
## than renaming).
|
||||||
if test -z "$gccflag"; then
|
if test -z "$gccflag"; then
|
||||||
|
@ -137,31 +216,31 @@ gcc)
|
||||||
fi
|
fi
|
||||||
"$@" -Wp,"$gccflag$tmpdepfile"
|
"$@" -Wp,"$gccflag$tmpdepfile"
|
||||||
stat=$?
|
stat=$?
|
||||||
if test $stat -eq 0; then :
|
if test $stat -ne 0; then
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile"
|
rm -f "$tmpdepfile"
|
||||||
exit $stat
|
exit $stat
|
||||||
fi
|
fi
|
||||||
rm -f "$depfile"
|
rm -f "$depfile"
|
||||||
echo "$object : \\" > "$depfile"
|
echo "$object : \\" > "$depfile"
|
||||||
alpha=ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz
|
# The second -e expression handles DOS-style file names with drive
|
||||||
## The second -e expression handles DOS-style file names with drive letters.
|
# letters.
|
||||||
sed -e 's/^[^:]*: / /' \
|
sed -e 's/^[^:]*: / /' \
|
||||||
-e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile"
|
-e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile"
|
||||||
## This next piece of magic avoids the `deleted header file' problem.
|
## This next piece of magic avoids the "deleted header file" problem.
|
||||||
## The problem is that when a header file which appears in a .P file
|
## The problem is that when a header file which appears in a .P file
|
||||||
## is deleted, the dependency causes make to die (because there is
|
## is deleted, the dependency causes make to die (because there is
|
||||||
## typically no way to rebuild the header). We avoid this by adding
|
## typically no way to rebuild the header). We avoid this by adding
|
||||||
## dummy dependencies for each header file. Too bad gcc doesn't do
|
## dummy dependencies for each header file. Too bad gcc doesn't do
|
||||||
## this for us directly.
|
## this for us directly.
|
||||||
tr ' ' '
|
## Some versions of gcc put a space before the ':'. On the theory
|
||||||
' < "$tmpdepfile" |
|
|
||||||
## Some versions of gcc put a space before the `:'. On the theory
|
|
||||||
## that the space means something, we add a space to the output as
|
## that the space means something, we add a space to the output as
|
||||||
## well.
|
## well. hp depmode also adds that space, but also prefixes the VPATH
|
||||||
|
## to the object. Take care to not repeat it in the output.
|
||||||
## Some versions of the HPUX 10.20 sed can't process this invocation
|
## Some versions of the HPUX 10.20 sed can't process this invocation
|
||||||
## correctly. Breaking it into two sed invocations is a workaround.
|
## correctly. Breaking it into two sed invocations is a workaround.
|
||||||
sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
|
tr ' ' "$nl" < "$tmpdepfile" \
|
||||||
|
| sed -e 's/^\\$//' -e '/^$/d' -e "s|.*$object$||" -e '/:$/d' \
|
||||||
|
| sed -e 's/$/ :/' >> "$depfile"
|
||||||
rm -f "$tmpdepfile"
|
rm -f "$tmpdepfile"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
@ -179,8 +258,7 @@ sgi)
|
||||||
"$@" -MDupdate "$tmpdepfile"
|
"$@" -MDupdate "$tmpdepfile"
|
||||||
fi
|
fi
|
||||||
stat=$?
|
stat=$?
|
||||||
if test $stat -eq 0; then :
|
if test $stat -ne 0; then
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile"
|
rm -f "$tmpdepfile"
|
||||||
exit $stat
|
exit $stat
|
||||||
fi
|
fi
|
||||||
|
@ -188,43 +266,41 @@ sgi)
|
||||||
|
|
||||||
if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files
|
if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files
|
||||||
echo "$object : \\" > "$depfile"
|
echo "$object : \\" > "$depfile"
|
||||||
|
|
||||||
# Clip off the initial element (the dependent). Don't try to be
|
# Clip off the initial element (the dependent). Don't try to be
|
||||||
# clever and replace this with sed code, as IRIX sed won't handle
|
# clever and replace this with sed code, as IRIX sed won't handle
|
||||||
# lines with more than a fixed number of characters (4096 in
|
# lines with more than a fixed number of characters (4096 in
|
||||||
# IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines;
|
# IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines;
|
||||||
# the IRIX cc adds comments like `#:fec' to the end of the
|
# the IRIX cc adds comments like '#:fec' to the end of the
|
||||||
# dependency line.
|
# dependency line.
|
||||||
tr ' ' '
|
tr ' ' "$nl" < "$tmpdepfile" \
|
||||||
' < "$tmpdepfile" \
|
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' \
|
||||||
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' | \
|
| tr "$nl" ' ' >> "$depfile"
|
||||||
tr '
|
|
||||||
' ' ' >> "$depfile"
|
|
||||||
echo >> "$depfile"
|
echo >> "$depfile"
|
||||||
|
|
||||||
# The second pass generates a dummy entry for each header file.
|
# The second pass generates a dummy entry for each header file.
|
||||||
tr ' ' '
|
tr ' ' "$nl" < "$tmpdepfile" \
|
||||||
' < "$tmpdepfile" \
|
|
||||||
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \
|
| sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \
|
||||||
>> "$depfile"
|
>> "$depfile"
|
||||||
else
|
else
|
||||||
# The sourcefile does not contain any dependencies, so just
|
make_dummy_depfile
|
||||||
# store a dummy comment line, to avoid errors with the Makefile
|
|
||||||
# "include basename.Plo" scheme.
|
|
||||||
echo "#dummy" > "$depfile"
|
|
||||||
fi
|
fi
|
||||||
rm -f "$tmpdepfile"
|
rm -f "$tmpdepfile"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
xlc)
|
||||||
|
# This case exists only to let depend.m4 do its work. It works by
|
||||||
|
# looking at the text of this script. This case will never be run,
|
||||||
|
# since it is checked for above.
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
|
||||||
aix)
|
aix)
|
||||||
# The C for AIX Compiler uses -M and outputs the dependencies
|
# The C for AIX Compiler uses -M and outputs the dependencies
|
||||||
# in a .u file. In older versions, this file always lives in the
|
# in a .u file. In older versions, this file always lives in the
|
||||||
# current directory. Also, the AIX compiler puts `$object:' at the
|
# current directory. Also, the AIX compiler puts '$object:' at the
|
||||||
# start of each line; $object doesn't have directory information.
|
# start of each line; $object doesn't have directory information.
|
||||||
# Version 6 uses the directory in both cases.
|
# Version 6 uses the directory in both cases.
|
||||||
dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
|
set_dir_from "$object"
|
||||||
test "x$dir" = "x$object" && dir=
|
set_base_from "$object"
|
||||||
base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
|
|
||||||
if test "$libtool" = yes; then
|
if test "$libtool" = yes; then
|
||||||
tmpdepfile1=$dir$base.u
|
tmpdepfile1=$dir$base.u
|
||||||
tmpdepfile2=$base.u
|
tmpdepfile2=$base.u
|
||||||
|
@ -237,9 +313,7 @@ aix)
|
||||||
"$@" -M
|
"$@" -M
|
||||||
fi
|
fi
|
||||||
stat=$?
|
stat=$?
|
||||||
|
if test $stat -ne 0; then
|
||||||
if test $stat -eq 0; then :
|
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
||||||
exit $stat
|
exit $stat
|
||||||
fi
|
fi
|
||||||
|
@ -248,44 +322,100 @@ aix)
|
||||||
do
|
do
|
||||||
test -f "$tmpdepfile" && break
|
test -f "$tmpdepfile" && break
|
||||||
done
|
done
|
||||||
if test -f "$tmpdepfile"; then
|
aix_post_process_depfile
|
||||||
# Each line is of the form `foo.o: dependent.h'.
|
;;
|
||||||
# Do two passes, one to just change these to
|
|
||||||
# `$object: dependent.h' and one to simply `dependent.h:'.
|
tcc)
|
||||||
sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile"
|
# tcc (Tiny C Compiler) understand '-MD -MF file' since version 0.9.26
|
||||||
# That's a tab and a space in the [].
|
# FIXME: That version still under development at the moment of writing.
|
||||||
sed -e 's,^.*\.[a-z]*:[ ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile"
|
# Make that this statement remains true also for stable, released
|
||||||
else
|
# versions.
|
||||||
# The sourcefile does not contain any dependencies, so just
|
# It will wrap lines (doesn't matter whether long or short) with a
|
||||||
# store a dummy comment line, to avoid errors with the Makefile
|
# trailing '\', as in:
|
||||||
# "include basename.Plo" scheme.
|
#
|
||||||
echo "#dummy" > "$depfile"
|
# foo.o : \
|
||||||
|
# foo.c \
|
||||||
|
# foo.h \
|
||||||
|
#
|
||||||
|
# It will put a trailing '\' even on the last line, and will use leading
|
||||||
|
# spaces rather than leading tabs (at least since its commit 0394caf7
|
||||||
|
# "Emit spaces for -MD").
|
||||||
|
"$@" -MD -MF "$tmpdepfile"
|
||||||
|
stat=$?
|
||||||
|
if test $stat -ne 0; then
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
exit $stat
|
||||||
fi
|
fi
|
||||||
|
rm -f "$depfile"
|
||||||
|
# Each non-empty line is of the form 'foo.o : \' or ' dep.h \'.
|
||||||
|
# We have to change lines of the first kind to '$object: \'.
|
||||||
|
sed -e "s|.*:|$object :|" < "$tmpdepfile" > "$depfile"
|
||||||
|
# And for each line of the second kind, we have to emit a 'dep.h:'
|
||||||
|
# dummy dependency, to avoid the deleted-header problem.
|
||||||
|
sed -n -e 's|^ *\(.*\) *\\$|\1:|p' < "$tmpdepfile" >> "$depfile"
|
||||||
rm -f "$tmpdepfile"
|
rm -f "$tmpdepfile"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
icc)
|
## The order of this option in the case statement is important, since the
|
||||||
# Intel's C compiler understands `-MD -MF file'. However on
|
## shell code in configure will try each of these formats in the order
|
||||||
# icc -MD -MF foo.d -c -o sub/foo.o sub/foo.c
|
## listed in this file. A plain '-MD' option would be understood by many
|
||||||
# ICC 7.0 will fill foo.d with something like
|
## compilers, so we must ensure this comes after the gcc and icc options.
|
||||||
# foo.o: sub/foo.c
|
pgcc)
|
||||||
# foo.o: sub/foo.h
|
# Portland's C compiler understands '-MD'.
|
||||||
# which is wrong. We want:
|
# Will always output deps to 'file.d' where file is the root name of the
|
||||||
# sub/foo.o: sub/foo.c
|
# source file under compilation, even if file resides in a subdirectory.
|
||||||
# sub/foo.o: sub/foo.h
|
# The object file name does not affect the name of the '.d' file.
|
||||||
# sub/foo.c:
|
# pgcc 10.2 will output
|
||||||
# sub/foo.h:
|
|
||||||
# ICC 7.1 will output
|
|
||||||
# foo.o: sub/foo.c sub/foo.h
|
# foo.o: sub/foo.c sub/foo.h
|
||||||
# and will wrap long lines using \ :
|
# and will wrap long lines using '\' :
|
||||||
# foo.o: sub/foo.c ... \
|
# foo.o: sub/foo.c ... \
|
||||||
# sub/foo.h ... \
|
# sub/foo.h ... \
|
||||||
# ...
|
# ...
|
||||||
|
set_dir_from "$object"
|
||||||
|
# Use the source, not the object, to determine the base name, since
|
||||||
|
# that's sadly what pgcc will do too.
|
||||||
|
set_base_from "$source"
|
||||||
|
tmpdepfile=$base.d
|
||||||
|
|
||||||
"$@" -MD -MF "$tmpdepfile"
|
# For projects that build the same source file twice into different object
|
||||||
|
# files, the pgcc approach of using the *source* file root name can cause
|
||||||
|
# problems in parallel builds. Use a locking strategy to avoid stomping on
|
||||||
|
# the same $tmpdepfile.
|
||||||
|
lockdir=$base.d-lock
|
||||||
|
trap "
|
||||||
|
echo '$0: caught signal, cleaning up...' >&2
|
||||||
|
rmdir '$lockdir'
|
||||||
|
exit 1
|
||||||
|
" 1 2 13 15
|
||||||
|
numtries=100
|
||||||
|
i=$numtries
|
||||||
|
while test $i -gt 0; do
|
||||||
|
# mkdir is a portable test-and-set.
|
||||||
|
if mkdir "$lockdir" 2>/dev/null; then
|
||||||
|
# This process acquired the lock.
|
||||||
|
"$@" -MD
|
||||||
stat=$?
|
stat=$?
|
||||||
if test $stat -eq 0; then :
|
# Release the lock.
|
||||||
|
rmdir "$lockdir"
|
||||||
|
break
|
||||||
else
|
else
|
||||||
|
# If the lock is being held by a different process, wait
|
||||||
|
# until the winning process is done or we timeout.
|
||||||
|
while test -d "$lockdir" && test $i -gt 0; do
|
||||||
|
sleep 1
|
||||||
|
i=`expr $i - 1`
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
i=`expr $i - 1`
|
||||||
|
done
|
||||||
|
trap - 1 2 13 15
|
||||||
|
if test $i -le 0; then
|
||||||
|
echo "$0: failed to acquire lock after $numtries attempts" >&2
|
||||||
|
echo "$0: check lockdir '$lockdir'" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if test $stat -ne 0; then
|
||||||
rm -f "$tmpdepfile"
|
rm -f "$tmpdepfile"
|
||||||
exit $stat
|
exit $stat
|
||||||
fi
|
fi
|
||||||
|
@ -297,8 +427,8 @@ icc)
|
||||||
sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile"
|
sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile"
|
||||||
# Some versions of the HPUX 10.20 sed can't process this invocation
|
# Some versions of the HPUX 10.20 sed can't process this invocation
|
||||||
# correctly. Breaking it into two sed invocations is a workaround.
|
# correctly. Breaking it into two sed invocations is a workaround.
|
||||||
sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" |
|
sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" \
|
||||||
sed -e 's/$/ :/' >> "$depfile"
|
| sed -e 's/$/ :/' >> "$depfile"
|
||||||
rm -f "$tmpdepfile"
|
rm -f "$tmpdepfile"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
@ -309,9 +439,8 @@ hp2)
|
||||||
# 'foo.d', which lands next to the object file, wherever that
|
# 'foo.d', which lands next to the object file, wherever that
|
||||||
# happens to be.
|
# happens to be.
|
||||||
# Much of this is similar to the tru64 case; see comments there.
|
# Much of this is similar to the tru64 case; see comments there.
|
||||||
dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
|
set_dir_from "$object"
|
||||||
test "x$dir" = "x$object" && dir=
|
set_base_from "$object"
|
||||||
base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
|
|
||||||
if test "$libtool" = yes; then
|
if test "$libtool" = yes; then
|
||||||
tmpdepfile1=$dir$base.d
|
tmpdepfile1=$dir$base.d
|
||||||
tmpdepfile2=$dir.libs/$base.d
|
tmpdepfile2=$dir.libs/$base.d
|
||||||
|
@ -322,8 +451,7 @@ hp2)
|
||||||
"$@" +Maked
|
"$@" +Maked
|
||||||
fi
|
fi
|
||||||
stat=$?
|
stat=$?
|
||||||
if test $stat -eq 0; then :
|
if test $stat -ne 0; then
|
||||||
else
|
|
||||||
rm -f "$tmpdepfile1" "$tmpdepfile2"
|
rm -f "$tmpdepfile1" "$tmpdepfile2"
|
||||||
exit $stat
|
exit $stat
|
||||||
fi
|
fi
|
||||||
|
@ -333,8 +461,8 @@ hp2)
|
||||||
test -f "$tmpdepfile" && break
|
test -f "$tmpdepfile" && break
|
||||||
done
|
done
|
||||||
if test -f "$tmpdepfile"; then
|
if test -f "$tmpdepfile"; then
|
||||||
sed -e "s,^.*\.[a-z]*:,$object:," "$tmpdepfile" > "$depfile"
|
sed -e "s,^.*\.[$lower]*:,$object:," "$tmpdepfile" > "$depfile"
|
||||||
# Add `dependent.h:' lines.
|
# Add 'dependent.h:' lines.
|
||||||
sed -ne '2,${
|
sed -ne '2,${
|
||||||
s/^ *//
|
s/^ *//
|
||||||
s/ \\*$//
|
s/ \\*$//
|
||||||
|
@ -342,67 +470,97 @@ hp2)
|
||||||
p
|
p
|
||||||
}' "$tmpdepfile" >> "$depfile"
|
}' "$tmpdepfile" >> "$depfile"
|
||||||
else
|
else
|
||||||
echo "#dummy" > "$depfile"
|
make_dummy_depfile
|
||||||
fi
|
fi
|
||||||
rm -f "$tmpdepfile" "$tmpdepfile2"
|
rm -f "$tmpdepfile" "$tmpdepfile2"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
tru64)
|
tru64)
|
||||||
# The Tru64 compiler uses -MD to generate dependencies as a side
|
# The Tru64 compiler uses -MD to generate dependencies as a side
|
||||||
# effect. `cc -MD -o foo.o ...' puts the dependencies into `foo.o.d'.
|
# effect. 'cc -MD -o foo.o ...' puts the dependencies into 'foo.o.d'.
|
||||||
# At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put
|
# At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put
|
||||||
# dependencies in `foo.d' instead, so we check for that too.
|
# dependencies in 'foo.d' instead, so we check for that too.
|
||||||
# Subdirectories are respected.
|
# Subdirectories are respected.
|
||||||
dir=`echo "$object" | sed -e 's|/[^/]*$|/|'`
|
set_dir_from "$object"
|
||||||
test "x$dir" = "x$object" && dir=
|
set_base_from "$object"
|
||||||
base=`echo "$object" | sed -e 's|^.*/||' -e 's/\.o$//' -e 's/\.lo$//'`
|
|
||||||
|
|
||||||
if test "$libtool" = yes; then
|
if test "$libtool" = yes; then
|
||||||
# With Tru64 cc, shared objects can also be used to make a
|
# Libtool generates 2 separate objects for the 2 libraries. These
|
||||||
# static library. This mechanism is used in libtool 1.4 series to
|
# two compilations output dependencies in $dir.libs/$base.o.d and
|
||||||
# handle both shared and static libraries in a single compilation.
|
|
||||||
# With libtool 1.4, dependencies were output in $dir.libs/$base.lo.d.
|
|
||||||
#
|
|
||||||
# With libtool 1.5 this exception was removed, and libtool now
|
|
||||||
# generates 2 separate objects for the 2 libraries. These two
|
|
||||||
# compilations output dependencies in $dir.libs/$base.o.d and
|
|
||||||
# in $dir$base.o.d. We have to check for both files, because
|
# in $dir$base.o.d. We have to check for both files, because
|
||||||
# one of the two compilations can be disabled. We should prefer
|
# one of the two compilations can be disabled. We should prefer
|
||||||
# $dir$base.o.d over $dir.libs/$base.o.d because the latter is
|
# $dir$base.o.d over $dir.libs/$base.o.d because the latter is
|
||||||
# automatically cleaned when .libs/ is deleted, while ignoring
|
# automatically cleaned when .libs/ is deleted, while ignoring
|
||||||
# the former would cause a distcleancheck panic.
|
# the former would cause a distcleancheck panic.
|
||||||
tmpdepfile1=$dir.libs/$base.lo.d # libtool 1.4
|
tmpdepfile1=$dir$base.o.d # libtool 1.5
|
||||||
tmpdepfile2=$dir$base.o.d # libtool 1.5
|
tmpdepfile2=$dir.libs/$base.o.d # Likewise.
|
||||||
tmpdepfile3=$dir.libs/$base.o.d # libtool 1.5
|
tmpdepfile3=$dir.libs/$base.d # Compaq CCC V6.2-504
|
||||||
tmpdepfile4=$dir.libs/$base.d # Compaq CCC V6.2-504
|
|
||||||
"$@" -Wc,-MD
|
"$@" -Wc,-MD
|
||||||
else
|
else
|
||||||
tmpdepfile1=$dir$base.o.d
|
tmpdepfile1=$dir$base.d
|
||||||
tmpdepfile2=$dir$base.d
|
tmpdepfile2=$dir$base.d
|
||||||
tmpdepfile3=$dir$base.d
|
tmpdepfile3=$dir$base.d
|
||||||
tmpdepfile4=$dir$base.d
|
|
||||||
"$@" -MD
|
"$@" -MD
|
||||||
fi
|
fi
|
||||||
|
|
||||||
stat=$?
|
stat=$?
|
||||||
if test $stat -eq 0; then :
|
if test $stat -ne 0; then
|
||||||
else
|
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
||||||
rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4"
|
|
||||||
exit $stat
|
exit $stat
|
||||||
fi
|
fi
|
||||||
|
|
||||||
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" "$tmpdepfile4"
|
for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3"
|
||||||
do
|
do
|
||||||
test -f "$tmpdepfile" && break
|
test -f "$tmpdepfile" && break
|
||||||
done
|
done
|
||||||
if test -f "$tmpdepfile"; then
|
# Same post-processing that is required for AIX mode.
|
||||||
sed -e "s,^.*\.[a-z]*:,$object:," < "$tmpdepfile" > "$depfile"
|
aix_post_process_depfile
|
||||||
# That's a tab and a space in the [].
|
;;
|
||||||
sed -e 's,^.*\.[a-z]*:[ ]*,,' -e 's,$,:,' < "$tmpdepfile" >> "$depfile"
|
|
||||||
|
msvc7)
|
||||||
|
if test "$libtool" = yes; then
|
||||||
|
showIncludes=-Wc,-showIncludes
|
||||||
else
|
else
|
||||||
echo "#dummy" > "$depfile"
|
showIncludes=-showIncludes
|
||||||
fi
|
fi
|
||||||
|
"$@" $showIncludes > "$tmpdepfile"
|
||||||
|
stat=$?
|
||||||
|
grep -v '^Note: including file: ' "$tmpdepfile"
|
||||||
|
if test $stat -ne 0; then
|
||||||
rm -f "$tmpdepfile"
|
rm -f "$tmpdepfile"
|
||||||
|
exit $stat
|
||||||
|
fi
|
||||||
|
rm -f "$depfile"
|
||||||
|
echo "$object : \\" > "$depfile"
|
||||||
|
# The first sed program below extracts the file names and escapes
|
||||||
|
# backslashes for cygpath. The second sed program outputs the file
|
||||||
|
# name when reading, but also accumulates all include files in the
|
||||||
|
# hold buffer in order to output them again at the end. This only
|
||||||
|
# works with sed implementations that can handle large buffers.
|
||||||
|
sed < "$tmpdepfile" -n '
|
||||||
|
/^Note: including file: *\(.*\)/ {
|
||||||
|
s//\1/
|
||||||
|
s/\\/\\\\/g
|
||||||
|
p
|
||||||
|
}' | $cygpath_u | sort -u | sed -n '
|
||||||
|
s/ /\\ /g
|
||||||
|
s/\(.*\)/'"$tab"'\1 \\/p
|
||||||
|
s/.\(.*\) \\/\1:/
|
||||||
|
H
|
||||||
|
$ {
|
||||||
|
s/.*/'"$tab"'/
|
||||||
|
G
|
||||||
|
p
|
||||||
|
}' >> "$depfile"
|
||||||
|
echo >> "$depfile" # make sure the fragment doesn't end with a backslash
|
||||||
|
rm -f "$tmpdepfile"
|
||||||
|
;;
|
||||||
|
|
||||||
|
msvc7msys)
|
||||||
|
# This case exists only to let depend.m4 do its work. It works by
|
||||||
|
# looking at the text of this script. This case will never be run,
|
||||||
|
# since it is checked for above.
|
||||||
|
exit 1
|
||||||
;;
|
;;
|
||||||
|
|
||||||
#nosideeffect)
|
#nosideeffect)
|
||||||
|
@ -422,7 +580,7 @@ dashmstdout)
|
||||||
shift
|
shift
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Remove `-o $object'.
|
# Remove '-o $object'.
|
||||||
IFS=" "
|
IFS=" "
|
||||||
for arg
|
for arg
|
||||||
do
|
do
|
||||||
|
@ -442,18 +600,18 @@ dashmstdout)
|
||||||
done
|
done
|
||||||
|
|
||||||
test -z "$dashmflag" && dashmflag=-M
|
test -z "$dashmflag" && dashmflag=-M
|
||||||
# Require at least two characters before searching for `:'
|
# Require at least two characters before searching for ':'
|
||||||
# in the target name. This is to cope with DOS-style filenames:
|
# in the target name. This is to cope with DOS-style filenames:
|
||||||
# a dependency such as `c:/foo/bar' could be seen as target `c' otherwise.
|
# a dependency such as 'c:/foo/bar' could be seen as target 'c' otherwise.
|
||||||
"$@" $dashmflag |
|
"$@" $dashmflag |
|
||||||
sed 's:^[ ]*[^: ][^:][^:]*\:[ ]*:'"$object"'\: :' > "$tmpdepfile"
|
sed "s|^[$tab ]*[^:$tab ][^:][^:]*:[$tab ]*|$object: |" > "$tmpdepfile"
|
||||||
rm -f "$depfile"
|
rm -f "$depfile"
|
||||||
cat < "$tmpdepfile" > "$depfile"
|
cat < "$tmpdepfile" > "$depfile"
|
||||||
tr ' ' '
|
# Some versions of the HPUX 10.20 sed can't process this sed invocation
|
||||||
' < "$tmpdepfile" | \
|
# correctly. Breaking it into two sed invocations is a workaround.
|
||||||
## Some versions of the HPUX 10.20 sed can't process this invocation
|
tr ' ' "$nl" < "$tmpdepfile" \
|
||||||
## correctly. Breaking it into two sed invocations is a workaround.
|
| sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \
|
||||||
sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
|
| sed -e 's/$/ :/' >> "$depfile"
|
||||||
rm -f "$tmpdepfile"
|
rm -f "$tmpdepfile"
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
@ -503,12 +661,15 @@ makedepend)
|
||||||
touch "$tmpdepfile"
|
touch "$tmpdepfile"
|
||||||
${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@"
|
${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@"
|
||||||
rm -f "$depfile"
|
rm -f "$depfile"
|
||||||
cat < "$tmpdepfile" > "$depfile"
|
# makedepend may prepend the VPATH from the source file name to the object.
|
||||||
sed '1,2d' "$tmpdepfile" | tr ' ' '
|
# No need to regex-escape $object, excess matching of '.' is harmless.
|
||||||
' | \
|
sed "s|^.*\($object *:\)|\1|" "$tmpdepfile" > "$depfile"
|
||||||
## Some versions of the HPUX 10.20 sed can't process this invocation
|
# Some versions of the HPUX 10.20 sed can't process the last invocation
|
||||||
## correctly. Breaking it into two sed invocations is a workaround.
|
# correctly. Breaking it into two sed invocations is a workaround.
|
||||||
sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' | sed -e 's/$/ :/' >> "$depfile"
|
sed '1,2d' "$tmpdepfile" \
|
||||||
|
| tr ' ' "$nl" \
|
||||||
|
| sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \
|
||||||
|
| sed -e 's/$/ :/' >> "$depfile"
|
||||||
rm -f "$tmpdepfile" "$tmpdepfile".bak
|
rm -f "$tmpdepfile" "$tmpdepfile".bak
|
||||||
;;
|
;;
|
||||||
|
|
||||||
|
@ -525,7 +686,7 @@ cpp)
|
||||||
shift
|
shift
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Remove `-o $object'.
|
# Remove '-o $object'.
|
||||||
IFS=" "
|
IFS=" "
|
||||||
for arg
|
for arg
|
||||||
do
|
do
|
||||||
|
@ -544,10 +705,10 @@ cpp)
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
"$@" -E |
|
"$@" -E \
|
||||||
sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \
|
| sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \
|
||||||
-e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' |
|
-e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \
|
||||||
sed '$ s: \\$::' > "$tmpdepfile"
|
| sed '$ s: \\$::' > "$tmpdepfile"
|
||||||
rm -f "$depfile"
|
rm -f "$depfile"
|
||||||
echo "$object : \\" > "$depfile"
|
echo "$object : \\" > "$depfile"
|
||||||
cat < "$tmpdepfile" >> "$depfile"
|
cat < "$tmpdepfile" >> "$depfile"
|
||||||
|
@ -594,8 +755,8 @@ msvisualcpp)
|
||||||
sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile"
|
sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile"
|
||||||
rm -f "$depfile"
|
rm -f "$depfile"
|
||||||
echo "$object : \\" > "$depfile"
|
echo "$object : \\" > "$depfile"
|
||||||
sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s:: \1 \\:p' >> "$depfile"
|
sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::'"$tab"'\1 \\:p' >> "$depfile"
|
||||||
echo " " >> "$depfile"
|
echo "$tab" >> "$depfile"
|
||||||
sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile"
|
sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile"
|
||||||
rm -f "$tmpdepfile"
|
rm -f "$tmpdepfile"
|
||||||
;;
|
;;
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
# install - install a program, script, or datafile
|
# install - install a program, script, or datafile
|
||||||
|
|
||||||
scriptversion=2009-04-28.21; # UTC
|
scriptversion=2011-11-20.07; # UTC
|
||||||
|
|
||||||
# This originates from X11R5 (mit/util/scripts/install.sh), which was
|
# This originates from X11R5 (mit/util/scripts/install.sh), which was
|
||||||
# later released in X11R6 (xc/config/util/install.sh) with the
|
# later released in X11R6 (xc/config/util/install.sh) with the
|
||||||
|
@ -35,7 +35,7 @@ scriptversion=2009-04-28.21; # UTC
|
||||||
# FSF changes to this file are in the public domain.
|
# FSF changes to this file are in the public domain.
|
||||||
#
|
#
|
||||||
# Calling this script install-sh is preferred over install.sh, to prevent
|
# Calling this script install-sh is preferred over install.sh, to prevent
|
||||||
# `make' implicit rules from creating a file called install from it
|
# 'make' implicit rules from creating a file called install from it
|
||||||
# when there is no Makefile.
|
# when there is no Makefile.
|
||||||
#
|
#
|
||||||
# This script is compatible with the BSD install script, but was written
|
# This script is compatible with the BSD install script, but was written
|
||||||
|
@ -156,6 +156,10 @@ while test $# -ne 0; do
|
||||||
-s) stripcmd=$stripprog;;
|
-s) stripcmd=$stripprog;;
|
||||||
|
|
||||||
-t) dst_arg=$2
|
-t) dst_arg=$2
|
||||||
|
# Protect names problematic for 'test' and other utilities.
|
||||||
|
case $dst_arg in
|
||||||
|
-* | [=\(\)!]) dst_arg=./$dst_arg;;
|
||||||
|
esac
|
||||||
shift;;
|
shift;;
|
||||||
|
|
||||||
-T) no_target_directory=true;;
|
-T) no_target_directory=true;;
|
||||||
|
@ -186,6 +190,10 @@ if test $# -ne 0 && test -z "$dir_arg$dst_arg"; then
|
||||||
fi
|
fi
|
||||||
shift # arg
|
shift # arg
|
||||||
dst_arg=$arg
|
dst_arg=$arg
|
||||||
|
# Protect names problematic for 'test' and other utilities.
|
||||||
|
case $dst_arg in
|
||||||
|
-* | [=\(\)!]) dst_arg=./$dst_arg;;
|
||||||
|
esac
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
@ -194,13 +202,17 @@ if test $# -eq 0; then
|
||||||
echo "$0: no input file specified." >&2
|
echo "$0: no input file specified." >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
# It's OK to call `install-sh -d' without argument.
|
# It's OK to call 'install-sh -d' without argument.
|
||||||
# This can happen when creating conditional directories.
|
# This can happen when creating conditional directories.
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test -z "$dir_arg"; then
|
if test -z "$dir_arg"; then
|
||||||
trap '(exit $?); exit' 1 2 13 15
|
do_exit='(exit $ret); exit $ret'
|
||||||
|
trap "ret=129; $do_exit" 1
|
||||||
|
trap "ret=130; $do_exit" 2
|
||||||
|
trap "ret=141; $do_exit" 13
|
||||||
|
trap "ret=143; $do_exit" 15
|
||||||
|
|
||||||
# Set umask so as not to create temps with too-generous modes.
|
# Set umask so as not to create temps with too-generous modes.
|
||||||
# However, 'strip' requires both read and write access to temps.
|
# However, 'strip' requires both read and write access to temps.
|
||||||
|
@ -228,9 +240,9 @@ fi
|
||||||
|
|
||||||
for src
|
for src
|
||||||
do
|
do
|
||||||
# Protect names starting with `-'.
|
# Protect names problematic for 'test' and other utilities.
|
||||||
case $src in
|
case $src in
|
||||||
-*) src=./$src;;
|
-* | [=\(\)!]) src=./$src;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
if test -n "$dir_arg"; then
|
if test -n "$dir_arg"; then
|
||||||
|
@ -252,12 +264,7 @@ do
|
||||||
echo "$0: no destination specified." >&2
|
echo "$0: no destination specified." >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
dst=$dst_arg
|
dst=$dst_arg
|
||||||
# Protect names starting with `-'.
|
|
||||||
case $dst in
|
|
||||||
-*) dst=./$dst;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# If destination is a directory, append the input filename; won't work
|
# If destination is a directory, append the input filename; won't work
|
||||||
# if double slashes aren't ignored.
|
# if double slashes aren't ignored.
|
||||||
|
@ -347,7 +354,7 @@ do
|
||||||
if test -z "$dir_arg" || {
|
if test -z "$dir_arg" || {
|
||||||
# Check for POSIX incompatibilities with -m.
|
# Check for POSIX incompatibilities with -m.
|
||||||
# HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or
|
# HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or
|
||||||
# other-writeable bit of parent directory when it shouldn't.
|
# other-writable bit of parent directory when it shouldn't.
|
||||||
# FreeBSD 6.1 mkdir -m -p sets mode of existing directory.
|
# FreeBSD 6.1 mkdir -m -p sets mode of existing directory.
|
||||||
ls_ld_tmpdir=`ls -ld "$tmpdir"`
|
ls_ld_tmpdir=`ls -ld "$tmpdir"`
|
||||||
case $ls_ld_tmpdir in
|
case $ls_ld_tmpdir in
|
||||||
|
@ -385,7 +392,7 @@ do
|
||||||
|
|
||||||
case $dstdir in
|
case $dstdir in
|
||||||
/*) prefix='/';;
|
/*) prefix='/';;
|
||||||
-*) prefix='./';;
|
[-=\(\)!]*) prefix='./';;
|
||||||
*) prefix='';;
|
*) prefix='';;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
@ -403,7 +410,7 @@ do
|
||||||
|
|
||||||
for d
|
for d
|
||||||
do
|
do
|
||||||
test -z "$d" && continue
|
test X"$d" = X && continue
|
||||||
|
|
||||||
prefix=$prefix$d
|
prefix=$prefix$d
|
||||||
if test -d "$prefix"; then
|
if test -d "$prefix"; then
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
413
config/missing
413
config/missing
|
@ -1,11 +1,10 @@
|
||||||
#! /bin/sh
|
#! /bin/sh
|
||||||
# Common stub for a few missing GNU programs while installing.
|
# Common wrapper for a few potentially missing GNU programs.
|
||||||
|
|
||||||
scriptversion=2009-04-28.21; # UTC
|
scriptversion=2012-06-26.16; # UTC
|
||||||
|
|
||||||
# Copyright (C) 1996, 1997, 1999, 2000, 2002, 2003, 2004, 2005, 2006,
|
# Copyright (C) 1996-2013 Free Software Foundation, Inc.
|
||||||
# 2008, 2009 Free Software Foundation, Inc.
|
# Originally written by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996.
|
||||||
# Originally by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996.
|
|
||||||
|
|
||||||
# This program is free software; you can redistribute it and/or modify
|
# 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
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
@ -26,69 +25,40 @@ scriptversion=2009-04-28.21; # UTC
|
||||||
# the same distribution terms that you use for the rest of that program.
|
# the same distribution terms that you use for the rest of that program.
|
||||||
|
|
||||||
if test $# -eq 0; then
|
if test $# -eq 0; then
|
||||||
echo 1>&2 "Try \`$0 --help' for more information"
|
echo 1>&2 "Try '$0 --help' for more information"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
run=:
|
|
||||||
sed_output='s/.* --output[ =]\([^ ]*\).*/\1/p'
|
|
||||||
sed_minuso='s/.* -o \([^ ]*\).*/\1/p'
|
|
||||||
|
|
||||||
# In the cases where this matters, `missing' is being run in the
|
|
||||||
# srcdir already.
|
|
||||||
if test -f configure.ac; then
|
|
||||||
configure_ac=configure.ac
|
|
||||||
else
|
|
||||||
configure_ac=configure.in
|
|
||||||
fi
|
|
||||||
|
|
||||||
msg="missing on your system"
|
|
||||||
|
|
||||||
case $1 in
|
case $1 in
|
||||||
--run)
|
|
||||||
# Try to run requested program, and just exit if it succeeds.
|
--is-lightweight)
|
||||||
run=
|
# Used by our autoconf macros to check whether the available missing
|
||||||
|
# script is modern enough.
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
|
||||||
|
--run)
|
||||||
|
# Back-compat with the calling convention used by older automake.
|
||||||
shift
|
shift
|
||||||
"$@" && exit 0
|
|
||||||
# Exit code 63 means version mismatch. This often happens
|
|
||||||
# when the user try to use an ancient version of a tool on
|
|
||||||
# a file that requires a minimum version. In this case we
|
|
||||||
# we should proceed has if the program had been absent, or
|
|
||||||
# if --run hadn't been passed.
|
|
||||||
if test $? = 63; then
|
|
||||||
run=:
|
|
||||||
msg="probably too old"
|
|
||||||
fi
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
-h|--h|--he|--hel|--help)
|
-h|--h|--he|--hel|--help)
|
||||||
echo "\
|
echo "\
|
||||||
$0 [OPTION]... PROGRAM [ARGUMENT]...
|
$0 [OPTION]... PROGRAM [ARGUMENT]...
|
||||||
|
|
||||||
Handle \`PROGRAM [ARGUMENT]...' for when PROGRAM is missing, or return an
|
Run 'PROGRAM [ARGUMENT]...', returning a proper advice when this fails due
|
||||||
error status if there is no known handling for PROGRAM.
|
to PROGRAM being missing or too old.
|
||||||
|
|
||||||
Options:
|
Options:
|
||||||
-h, --help display this help and exit
|
-h, --help display this help and exit
|
||||||
-v, --version output version information and exit
|
-v, --version output version information and exit
|
||||||
--run try to run the given command, and emulate it if it fails
|
|
||||||
|
|
||||||
Supported PROGRAM values:
|
Supported PROGRAM values:
|
||||||
aclocal touch file \`aclocal.m4'
|
aclocal autoconf autoheader autom4te automake makeinfo
|
||||||
autoconf touch file \`configure'
|
bison yacc flex lex help2man
|
||||||
autoheader touch file \`config.h.in'
|
|
||||||
autom4te touch the output file, or create a stub one
|
|
||||||
automake touch all \`Makefile.in' files
|
|
||||||
bison create \`y.tab.[ch]', if possible, from existing .[ch]
|
|
||||||
flex create \`lex.yy.c', if possible, from existing .c
|
|
||||||
help2man touch the output file
|
|
||||||
lex create \`lex.yy.c', if possible, from existing .c
|
|
||||||
makeinfo touch the output file
|
|
||||||
tar try tar, gnutar, gtar, then tar without non-portable flags
|
|
||||||
yacc create \`y.tab.[ch]', if possible, from existing .[ch]
|
|
||||||
|
|
||||||
Version suffixes to PROGRAM as well as the prefixes \`gnu-', \`gnu', and
|
Version suffixes to PROGRAM as well as the prefixes 'gnu-', 'gnu', and
|
||||||
\`g' are ignored when checking the name.
|
'g' are ignored when checking the name.
|
||||||
|
|
||||||
Send bug reports to <bug-automake@gnu.org>."
|
Send bug reports to <bug-automake@gnu.org>."
|
||||||
exit $?
|
exit $?
|
||||||
|
@ -100,272 +70,141 @@ Send bug reports to <bug-automake@gnu.org>."
|
||||||
;;
|
;;
|
||||||
|
|
||||||
-*)
|
-*)
|
||||||
echo 1>&2 "$0: Unknown \`$1' option"
|
echo 1>&2 "$0: unknown '$1' option"
|
||||||
echo 1>&2 "Try \`$0 --help' for more information"
|
echo 1>&2 "Try '$0 --help' for more information"
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
|
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# normalize program name to check for.
|
# Run the given program, remember its exit status.
|
||||||
program=`echo "$1" | sed '
|
"$@"; st=$?
|
||||||
|
|
||||||
|
# If it succeeded, we are done.
|
||||||
|
test $st -eq 0 && exit 0
|
||||||
|
|
||||||
|
# Also exit now if we it failed (or wasn't found), and '--version' was
|
||||||
|
# passed; such an option is passed most likely to detect whether the
|
||||||
|
# program is present and works.
|
||||||
|
case $2 in --version|--help) exit $st;; esac
|
||||||
|
|
||||||
|
# Exit code 63 means version mismatch. This often happens when the user
|
||||||
|
# tries to use an ancient version of a tool on a file that requires a
|
||||||
|
# minimum version.
|
||||||
|
if test $st -eq 63; then
|
||||||
|
msg="probably too old"
|
||||||
|
elif test $st -eq 127; then
|
||||||
|
# Program was missing.
|
||||||
|
msg="missing on your system"
|
||||||
|
else
|
||||||
|
# Program was found and executed, but failed. Give up.
|
||||||
|
exit $st
|
||||||
|
fi
|
||||||
|
|
||||||
|
perl_URL=http://www.perl.org/
|
||||||
|
flex_URL=http://flex.sourceforge.net/
|
||||||
|
gnu_software_URL=http://www.gnu.org/software
|
||||||
|
|
||||||
|
program_details ()
|
||||||
|
{
|
||||||
|
case $1 in
|
||||||
|
aclocal|automake)
|
||||||
|
echo "The '$1' program is part of the GNU Automake package:"
|
||||||
|
echo "<$gnu_software_URL/automake>"
|
||||||
|
echo "It also requires GNU Autoconf, GNU m4 and Perl in order to run:"
|
||||||
|
echo "<$gnu_software_URL/autoconf>"
|
||||||
|
echo "<$gnu_software_URL/m4/>"
|
||||||
|
echo "<$perl_URL>"
|
||||||
|
;;
|
||||||
|
autoconf|autom4te|autoheader)
|
||||||
|
echo "The '$1' program is part of the GNU Autoconf package:"
|
||||||
|
echo "<$gnu_software_URL/autoconf/>"
|
||||||
|
echo "It also requires GNU m4 and Perl in order to run:"
|
||||||
|
echo "<$gnu_software_URL/m4/>"
|
||||||
|
echo "<$perl_URL>"
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
give_advice ()
|
||||||
|
{
|
||||||
|
# Normalize program name to check for.
|
||||||
|
normalized_program=`echo "$1" | sed '
|
||||||
s/^gnu-//; t
|
s/^gnu-//; t
|
||||||
s/^gnu//; t
|
s/^gnu//; t
|
||||||
s/^g//; t'`
|
s/^g//; t'`
|
||||||
|
|
||||||
# Now exit if we have it, but it failed. Also exit now if we
|
printf '%s\n' "'$1' is $msg."
|
||||||
# don't have it and --version was passed (most likely to detect
|
|
||||||
# the program). This is about non-GNU programs, so use $1 not
|
|
||||||
# $program.
|
|
||||||
case $1 in
|
|
||||||
lex*|yacc*)
|
|
||||||
# Not GNU programs, they don't have --version.
|
|
||||||
;;
|
|
||||||
|
|
||||||
tar*)
|
|
||||||
if test -n "$run"; then
|
|
||||||
echo 1>&2 "ERROR: \`tar' requires --run"
|
|
||||||
exit 1
|
|
||||||
elif test "x$2" = "x--version" || test "x$2" = "x--help"; then
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
|
||||||
if test -z "$run" && ($1 --version) > /dev/null 2>&1; then
|
|
||||||
# We have it, but it failed.
|
|
||||||
exit 1
|
|
||||||
elif test "x$2" = "x--version" || test "x$2" = "x--help"; then
|
|
||||||
# Could not run --version or --help. This is probably someone
|
|
||||||
# running `$TOOL --version' or `$TOOL --help' to check whether
|
|
||||||
# $TOOL exists and not knowing $TOOL uses missing.
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# If it does not exist, or fails to run (possibly an outdated version),
|
|
||||||
# try to emulate it.
|
|
||||||
case $program in
|
|
||||||
aclocal*)
|
|
||||||
echo 1>&2 "\
|
|
||||||
WARNING: \`$1' is $msg. You should only need it if
|
|
||||||
you modified \`acinclude.m4' or \`${configure_ac}'. You might want
|
|
||||||
to install the \`Automake' and \`Perl' packages. Grab them from
|
|
||||||
any GNU archive site."
|
|
||||||
touch aclocal.m4
|
|
||||||
;;
|
|
||||||
|
|
||||||
|
configure_deps="'configure.ac' or m4 files included by 'configure.ac'"
|
||||||
|
case $normalized_program in
|
||||||
autoconf*)
|
autoconf*)
|
||||||
echo 1>&2 "\
|
echo "You should only need it if you modified 'configure.ac',"
|
||||||
WARNING: \`$1' is $msg. You should only need it if
|
echo "or m4 files included by it."
|
||||||
you modified \`${configure_ac}'. You might want to install the
|
program_details 'autoconf'
|
||||||
\`Autoconf' and \`GNU m4' packages. Grab them from any GNU
|
|
||||||
archive site."
|
|
||||||
touch configure
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
autoheader*)
|
autoheader*)
|
||||||
echo 1>&2 "\
|
echo "You should only need it if you modified 'acconfig.h' or"
|
||||||
WARNING: \`$1' is $msg. You should only need it if
|
echo "$configure_deps."
|
||||||
you modified \`acconfig.h' or \`${configure_ac}'. You might want
|
program_details 'autoheader'
|
||||||
to install the \`Autoconf' and \`GNU m4' packages. Grab them
|
|
||||||
from any GNU archive site."
|
|
||||||
files=`sed -n 's/^[ ]*A[CM]_CONFIG_HEADER(\([^)]*\)).*/\1/p' ${configure_ac}`
|
|
||||||
test -z "$files" && files="config.h"
|
|
||||||
touch_files=
|
|
||||||
for f in $files; do
|
|
||||||
case $f in
|
|
||||||
*:*) touch_files="$touch_files "`echo "$f" |
|
|
||||||
sed -e 's/^[^:]*://' -e 's/:.*//'`;;
|
|
||||||
*) touch_files="$touch_files $f.in";;
|
|
||||||
esac
|
|
||||||
done
|
|
||||||
touch $touch_files
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
automake*)
|
automake*)
|
||||||
echo 1>&2 "\
|
echo "You should only need it if you modified 'Makefile.am' or"
|
||||||
WARNING: \`$1' is $msg. You should only need it if
|
echo "$configure_deps."
|
||||||
you modified \`Makefile.am', \`acinclude.m4' or \`${configure_ac}'.
|
program_details 'automake'
|
||||||
You might want to install the \`Automake' and \`Perl' packages.
|
;;
|
||||||
Grab them from any GNU archive site."
|
aclocal*)
|
||||||
find . -type f -name Makefile.am -print |
|
echo "You should only need it if you modified 'acinclude.m4' or"
|
||||||
sed 's/\.am$/.in/' |
|
echo "$configure_deps."
|
||||||
while read f; do touch "$f"; done
|
program_details 'aclocal'
|
||||||
;;
|
;;
|
||||||
|
|
||||||
autom4te*)
|
autom4te*)
|
||||||
echo 1>&2 "\
|
echo "You might have modified some maintainer files that require"
|
||||||
WARNING: \`$1' is needed, but is $msg.
|
echo "the 'automa4te' program to be rebuilt."
|
||||||
You might have modified some files without having the
|
program_details 'autom4te'
|
||||||
proper tools for further handling them.
|
|
||||||
You can get \`$1' as part of \`Autoconf' from any GNU
|
|
||||||
archive site."
|
|
||||||
|
|
||||||
file=`echo "$*" | sed -n "$sed_output"`
|
|
||||||
test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"`
|
|
||||||
if test -f "$file"; then
|
|
||||||
touch $file
|
|
||||||
else
|
|
||||||
test -z "$file" || exec >$file
|
|
||||||
echo "#! /bin/sh"
|
|
||||||
echo "# Created by GNU Automake missing as a replacement of"
|
|
||||||
echo "# $ $@"
|
|
||||||
echo "exit 0"
|
|
||||||
chmod +x $file
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
bison*|yacc*)
|
bison*|yacc*)
|
||||||
echo 1>&2 "\
|
echo "You should only need it if you modified a '.y' file."
|
||||||
WARNING: \`$1' $msg. You should only need it if
|
echo "You may want to install the GNU Bison package:"
|
||||||
you modified a \`.y' file. You may need the \`Bison' package
|
echo "<$gnu_software_URL/bison/>"
|
||||||
in order for those modifications to take effect. You can get
|
|
||||||
\`Bison' from any GNU archive site."
|
|
||||||
rm -f y.tab.c y.tab.h
|
|
||||||
if test $# -ne 1; then
|
|
||||||
eval LASTARG="\${$#}"
|
|
||||||
case $LASTARG in
|
|
||||||
*.y)
|
|
||||||
SRCFILE=`echo "$LASTARG" | sed 's/y$/c/'`
|
|
||||||
if test -f "$SRCFILE"; then
|
|
||||||
cp "$SRCFILE" y.tab.c
|
|
||||||
fi
|
|
||||||
SRCFILE=`echo "$LASTARG" | sed 's/y$/h/'`
|
|
||||||
if test -f "$SRCFILE"; then
|
|
||||||
cp "$SRCFILE" y.tab.h
|
|
||||||
fi
|
|
||||||
;;
|
;;
|
||||||
esac
|
|
||||||
fi
|
|
||||||
if test ! -f y.tab.h; then
|
|
||||||
echo >y.tab.h
|
|
||||||
fi
|
|
||||||
if test ! -f y.tab.c; then
|
|
||||||
echo 'main() { return 0; }' >y.tab.c
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
lex*|flex*)
|
lex*|flex*)
|
||||||
echo 1>&2 "\
|
echo "You should only need it if you modified a '.l' file."
|
||||||
WARNING: \`$1' is $msg. You should only need it if
|
echo "You may want to install the Fast Lexical Analyzer package:"
|
||||||
you modified a \`.l' file. You may need the \`Flex' package
|
echo "<$flex_URL>"
|
||||||
in order for those modifications to take effect. You can get
|
|
||||||
\`Flex' from any GNU archive site."
|
|
||||||
rm -f lex.yy.c
|
|
||||||
if test $# -ne 1; then
|
|
||||||
eval LASTARG="\${$#}"
|
|
||||||
case $LASTARG in
|
|
||||||
*.l)
|
|
||||||
SRCFILE=`echo "$LASTARG" | sed 's/l$/c/'`
|
|
||||||
if test -f "$SRCFILE"; then
|
|
||||||
cp "$SRCFILE" lex.yy.c
|
|
||||||
fi
|
|
||||||
;;
|
;;
|
||||||
esac
|
|
||||||
fi
|
|
||||||
if test ! -f lex.yy.c; then
|
|
||||||
echo 'main() { return 0; }' >lex.yy.c
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
|
|
||||||
help2man*)
|
help2man*)
|
||||||
echo 1>&2 "\
|
echo "You should only need it if you modified a dependency" \
|
||||||
WARNING: \`$1' is $msg. You should only need it if
|
"of a man page."
|
||||||
you modified a dependency of a manual page. You may need the
|
echo "You may want to install the GNU Help2man package:"
|
||||||
\`Help2man' package in order for those modifications to take
|
echo "<$gnu_software_URL/help2man/>"
|
||||||
effect. You can get \`Help2man' from any GNU archive site."
|
|
||||||
|
|
||||||
file=`echo "$*" | sed -n "$sed_output"`
|
|
||||||
test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"`
|
|
||||||
if test -f "$file"; then
|
|
||||||
touch $file
|
|
||||||
else
|
|
||||||
test -z "$file" || exec >$file
|
|
||||||
echo ".ab help2man is required to generate this page"
|
|
||||||
exit $?
|
|
||||||
fi
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
makeinfo*)
|
makeinfo*)
|
||||||
echo 1>&2 "\
|
echo "You should only need it if you modified a '.texi' file, or"
|
||||||
WARNING: \`$1' is $msg. You should only need it if
|
echo "any other file indirectly affecting the aspect of the manual."
|
||||||
you modified a \`.texi' or \`.texinfo' file, or any other file
|
echo "You might want to install the Texinfo package:"
|
||||||
indirectly affecting the aspect of the manual. The spurious
|
echo "<$gnu_software_URL/texinfo/>"
|
||||||
call might also be the consequence of using a buggy \`make' (AIX,
|
echo "The spurious makeinfo call might also be the consequence of"
|
||||||
DU, IRIX). You might want to install the \`Texinfo' package or
|
echo "using a buggy 'make' (AIX, DU, IRIX), in which case you might"
|
||||||
the \`GNU make' package. Grab either from any GNU archive site."
|
echo "want to install GNU make:"
|
||||||
# The file to touch is that specified with -o ...
|
echo "<$gnu_software_URL/make/>"
|
||||||
file=`echo "$*" | sed -n "$sed_output"`
|
|
||||||
test -z "$file" && file=`echo "$*" | sed -n "$sed_minuso"`
|
|
||||||
if test -z "$file"; then
|
|
||||||
# ... or it is the one specified with @setfilename ...
|
|
||||||
infile=`echo "$*" | sed 's/.* \([^ ]*\) *$/\1/'`
|
|
||||||
file=`sed -n '
|
|
||||||
/^@setfilename/{
|
|
||||||
s/.* \([^ ]*\) *$/\1/
|
|
||||||
p
|
|
||||||
q
|
|
||||||
}' $infile`
|
|
||||||
# ... or it is derived from the source name (dir/f.texi becomes f.info)
|
|
||||||
test -z "$file" && file=`echo "$infile" | sed 's,.*/,,;s,.[^.]*$,,'`.info
|
|
||||||
fi
|
|
||||||
# If the file does not exist, the user really needs makeinfo;
|
|
||||||
# let's fail without touching anything.
|
|
||||||
test -f $file || exit 1
|
|
||||||
touch $file
|
|
||||||
;;
|
;;
|
||||||
|
|
||||||
tar*)
|
|
||||||
shift
|
|
||||||
|
|
||||||
# We have already tried tar in the generic part.
|
|
||||||
# Look for gnutar/gtar before invocation to avoid ugly error
|
|
||||||
# messages.
|
|
||||||
if (gnutar --version > /dev/null 2>&1); then
|
|
||||||
gnutar "$@" && exit 0
|
|
||||||
fi
|
|
||||||
if (gtar --version > /dev/null 2>&1); then
|
|
||||||
gtar "$@" && exit 0
|
|
||||||
fi
|
|
||||||
firstarg="$1"
|
|
||||||
if shift; then
|
|
||||||
case $firstarg in
|
|
||||||
*o*)
|
|
||||||
firstarg=`echo "$firstarg" | sed s/o//`
|
|
||||||
tar "$firstarg" "$@" && exit 0
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
case $firstarg in
|
|
||||||
*h*)
|
|
||||||
firstarg=`echo "$firstarg" | sed s/h//`
|
|
||||||
tar "$firstarg" "$@" && exit 0
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo 1>&2 "\
|
|
||||||
WARNING: I can't seem to be able to run \`tar' with the given arguments.
|
|
||||||
You may want to install GNU tar or Free paxutils, or check the
|
|
||||||
command line arguments."
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
|
|
||||||
*)
|
*)
|
||||||
echo 1>&2 "\
|
echo "You might have modified some files without having the proper"
|
||||||
WARNING: \`$1' is needed, and is $msg.
|
echo "tools for further handling them. Check the 'README' file, it"
|
||||||
You might have modified some files without having the
|
echo "often tells you about the needed prerequisites for installing"
|
||||||
proper tools for further handling them. Check the \`README' file,
|
echo "this package. You may also peek at any GNU archive site, in"
|
||||||
it often tells you about the needed prerequisites for installing
|
echo "case some other package contains this missing '$1' program."
|
||||||
this package. You may also peek at any GNU archive site, in case
|
|
||||||
some other package would contain this missing \`$1' program."
|
|
||||||
exit 1
|
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
exit 0
|
give_advice "$1" | sed -e '1s/^/WARNING: /' \
|
||||||
|
-e '2,$s/^/ /' >&2
|
||||||
|
|
||||||
|
# Propagate the correct exit status (expected to be 127 for a program
|
||||||
|
# not found, 63 for a program that failed due to version mismatch).
|
||||||
|
exit $st
|
||||||
|
|
||||||
# Local variables:
|
# Local variables:
|
||||||
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
# eval: (add-hook 'write-file-hooks 'time-stamp)
|
||||||
|
|
|
@ -13,7 +13,6 @@ unsigned[1] reserved = 0;
|
||||||
position offsetBeforeData;
|
position offsetBeforeData;
|
||||||
|
|
||||||
#meta subsetNumber bufr_subset_number();
|
#meta subsetNumber bufr_subset_number();
|
||||||
meta selectGroupNumber bufr_group_number();
|
|
||||||
|
|
||||||
transient subsetNumber=0;
|
transient subsetNumber=0;
|
||||||
if (compressedData) {
|
if (compressedData) {
|
||||||
|
|
File diff suppressed because it is too large
Load Diff
|
@ -1,13 +1,14 @@
|
||||||
# Helper functions for option handling. -*- Autoconf -*-
|
# Helper functions for option handling. -*- Autoconf -*-
|
||||||
#
|
#
|
||||||
# Copyright (C) 2004, 2005, 2007, 2008 Free Software Foundation, Inc.
|
# Copyright (C) 2004, 2005, 2007, 2008, 2009 Free Software Foundation,
|
||||||
|
# Inc.
|
||||||
# Written by Gary V. Vaughan, 2004
|
# Written by Gary V. Vaughan, 2004
|
||||||
#
|
#
|
||||||
# This file is free software; the Free Software Foundation gives
|
# This file is free software; the Free Software Foundation gives
|
||||||
# unlimited permission to copy and/or distribute it, with or without
|
# unlimited permission to copy and/or distribute it, with or without
|
||||||
# modifications, as long as this notice is preserved.
|
# modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
# serial 6 ltoptions.m4
|
# serial 7 ltoptions.m4
|
||||||
|
|
||||||
# This is to help aclocal find these macros, as it can't see m4_define.
|
# This is to help aclocal find these macros, as it can't see m4_define.
|
||||||
AC_DEFUN([LTOPTIONS_VERSION], [m4_if([1])])
|
AC_DEFUN([LTOPTIONS_VERSION], [m4_if([1])])
|
||||||
|
@ -125,7 +126,7 @@ LT_OPTION_DEFINE([LT_INIT], [win32-dll],
|
||||||
[enable_win32_dll=yes
|
[enable_win32_dll=yes
|
||||||
|
|
||||||
case $host in
|
case $host in
|
||||||
*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-cegcc*)
|
*-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-cegcc*)
|
||||||
AC_CHECK_TOOL(AS, as, false)
|
AC_CHECK_TOOL(AS, as, false)
|
||||||
AC_CHECK_TOOL(DLLTOOL, dlltool, false)
|
AC_CHECK_TOOL(DLLTOOL, dlltool, false)
|
||||||
AC_CHECK_TOOL(OBJDUMP, objdump, false)
|
AC_CHECK_TOOL(OBJDUMP, objdump, false)
|
||||||
|
@ -133,13 +134,13 @@ case $host in
|
||||||
esac
|
esac
|
||||||
|
|
||||||
test -z "$AS" && AS=as
|
test -z "$AS" && AS=as
|
||||||
_LT_DECL([], [AS], [0], [Assembler program])dnl
|
_LT_DECL([], [AS], [1], [Assembler program])dnl
|
||||||
|
|
||||||
test -z "$DLLTOOL" && DLLTOOL=dlltool
|
test -z "$DLLTOOL" && DLLTOOL=dlltool
|
||||||
_LT_DECL([], [DLLTOOL], [0], [DLL creation program])dnl
|
_LT_DECL([], [DLLTOOL], [1], [DLL creation program])dnl
|
||||||
|
|
||||||
test -z "$OBJDUMP" && OBJDUMP=objdump
|
test -z "$OBJDUMP" && OBJDUMP=objdump
|
||||||
_LT_DECL([], [OBJDUMP], [0], [Object dumper program])dnl
|
_LT_DECL([], [OBJDUMP], [1], [Object dumper program])dnl
|
||||||
])# win32-dll
|
])# win32-dll
|
||||||
|
|
||||||
AU_DEFUN([AC_LIBTOOL_WIN32_DLL],
|
AU_DEFUN([AC_LIBTOOL_WIN32_DLL],
|
||||||
|
@ -325,9 +326,24 @@ dnl AC_DEFUN([AM_DISABLE_FAST_INSTALL], [])
|
||||||
# MODE is either `yes' or `no'. If omitted, it defaults to `both'.
|
# MODE is either `yes' or `no'. If omitted, it defaults to `both'.
|
||||||
m4_define([_LT_WITH_PIC],
|
m4_define([_LT_WITH_PIC],
|
||||||
[AC_ARG_WITH([pic],
|
[AC_ARG_WITH([pic],
|
||||||
[AS_HELP_STRING([--with-pic],
|
[AS_HELP_STRING([--with-pic@<:@=PKGS@:>@],
|
||||||
[try to use only PIC/non-PIC objects @<:@default=use both@:>@])],
|
[try to use only PIC/non-PIC objects @<:@default=use both@:>@])],
|
||||||
[pic_mode="$withval"],
|
[lt_p=${PACKAGE-default}
|
||||||
|
case $withval in
|
||||||
|
yes|no) pic_mode=$withval ;;
|
||||||
|
*)
|
||||||
|
pic_mode=default
|
||||||
|
# Look at the argument we got. We use all the common list separators.
|
||||||
|
lt_save_ifs="$IFS"; IFS="${IFS}$PATH_SEPARATOR,"
|
||||||
|
for lt_pkg in $withval; do
|
||||||
|
IFS="$lt_save_ifs"
|
||||||
|
if test "X$lt_pkg" = "X$lt_p"; then
|
||||||
|
pic_mode=yes
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
IFS="$lt_save_ifs"
|
||||||
|
;;
|
||||||
|
esac],
|
||||||
[pic_mode=default])
|
[pic_mode=default])
|
||||||
|
|
||||||
test -z "$pic_mode" && pic_mode=m4_default([$1], [default])
|
test -z "$pic_mode" && pic_mode=m4_default([$1], [default])
|
||||||
|
|
|
@ -7,17 +7,17 @@
|
||||||
# unlimited permission to copy and/or distribute it, with or without
|
# unlimited permission to copy and/or distribute it, with or without
|
||||||
# modifications, as long as this notice is preserved.
|
# modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
# Generated from ltversion.in.
|
# @configure_input@
|
||||||
|
|
||||||
# serial 3017 ltversion.m4
|
# serial 3337 ltversion.m4
|
||||||
# This file is part of GNU Libtool
|
# This file is part of GNU Libtool
|
||||||
|
|
||||||
m4_define([LT_PACKAGE_VERSION], [2.2.6b])
|
m4_define([LT_PACKAGE_VERSION], [2.4.2])
|
||||||
m4_define([LT_PACKAGE_REVISION], [1.3017])
|
m4_define([LT_PACKAGE_REVISION], [1.3337])
|
||||||
|
|
||||||
AC_DEFUN([LTVERSION_VERSION],
|
AC_DEFUN([LTVERSION_VERSION],
|
||||||
[macro_version='2.2.6b'
|
[macro_version='2.4.2'
|
||||||
macro_revision='1.3017'
|
macro_revision='1.3337'
|
||||||
_LT_DECL(, macro_version, 0, [Which release of libtool.m4 was used?])
|
_LT_DECL(, macro_version, 0, [Which release of libtool.m4 was used?])
|
||||||
_LT_DECL(, macro_revision, 0)
|
_LT_DECL(, macro_revision, 0)
|
||||||
])
|
])
|
||||||
|
|
|
@ -1,13 +1,13 @@
|
||||||
# lt~obsolete.m4 -- aclocal satisfying obsolete definitions. -*-Autoconf-*-
|
# lt~obsolete.m4 -- aclocal satisfying obsolete definitions. -*-Autoconf-*-
|
||||||
#
|
#
|
||||||
# Copyright (C) 2004, 2005, 2007 Free Software Foundation, Inc.
|
# Copyright (C) 2004, 2005, 2007, 2009 Free Software Foundation, Inc.
|
||||||
# Written by Scott James Remnant, 2004.
|
# Written by Scott James Remnant, 2004.
|
||||||
#
|
#
|
||||||
# This file is free software; the Free Software Foundation gives
|
# This file is free software; the Free Software Foundation gives
|
||||||
# unlimited permission to copy and/or distribute it, with or without
|
# unlimited permission to copy and/or distribute it, with or without
|
||||||
# modifications, as long as this notice is preserved.
|
# modifications, as long as this notice is preserved.
|
||||||
|
|
||||||
# serial 4 lt~obsolete.m4
|
# serial 5 lt~obsolete.m4
|
||||||
|
|
||||||
# These exist entirely to fool aclocal when bootstrapping libtool.
|
# These exist entirely to fool aclocal when bootstrapping libtool.
|
||||||
#
|
#
|
||||||
|
@ -77,7 +77,6 @@ m4_ifndef([AC_DISABLE_FAST_INSTALL], [AC_DEFUN([AC_DISABLE_FAST_INSTALL])])
|
||||||
m4_ifndef([_LT_AC_LANG_CXX], [AC_DEFUN([_LT_AC_LANG_CXX])])
|
m4_ifndef([_LT_AC_LANG_CXX], [AC_DEFUN([_LT_AC_LANG_CXX])])
|
||||||
m4_ifndef([_LT_AC_LANG_F77], [AC_DEFUN([_LT_AC_LANG_F77])])
|
m4_ifndef([_LT_AC_LANG_F77], [AC_DEFUN([_LT_AC_LANG_F77])])
|
||||||
m4_ifndef([_LT_AC_LANG_GCJ], [AC_DEFUN([_LT_AC_LANG_GCJ])])
|
m4_ifndef([_LT_AC_LANG_GCJ], [AC_DEFUN([_LT_AC_LANG_GCJ])])
|
||||||
m4_ifndef([AC_LIBTOOL_RC], [AC_DEFUN([AC_LIBTOOL_RC])])
|
|
||||||
m4_ifndef([AC_LIBTOOL_LANG_C_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_C_CONFIG])])
|
m4_ifndef([AC_LIBTOOL_LANG_C_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_C_CONFIG])])
|
||||||
m4_ifndef([_LT_AC_LANG_C_CONFIG], [AC_DEFUN([_LT_AC_LANG_C_CONFIG])])
|
m4_ifndef([_LT_AC_LANG_C_CONFIG], [AC_DEFUN([_LT_AC_LANG_C_CONFIG])])
|
||||||
m4_ifndef([AC_LIBTOOL_LANG_CXX_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_CXX_CONFIG])])
|
m4_ifndef([AC_LIBTOOL_LANG_CXX_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_CXX_CONFIG])])
|
||||||
|
@ -90,3 +89,10 @@ m4_ifndef([AC_LIBTOOL_LANG_RC_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_RC_CONFIG])])
|
||||||
m4_ifndef([_LT_AC_LANG_RC_CONFIG], [AC_DEFUN([_LT_AC_LANG_RC_CONFIG])])
|
m4_ifndef([_LT_AC_LANG_RC_CONFIG], [AC_DEFUN([_LT_AC_LANG_RC_CONFIG])])
|
||||||
m4_ifndef([AC_LIBTOOL_CONFIG], [AC_DEFUN([AC_LIBTOOL_CONFIG])])
|
m4_ifndef([AC_LIBTOOL_CONFIG], [AC_DEFUN([AC_LIBTOOL_CONFIG])])
|
||||||
m4_ifndef([_LT_AC_FILE_LTDLL_C], [AC_DEFUN([_LT_AC_FILE_LTDLL_C])])
|
m4_ifndef([_LT_AC_FILE_LTDLL_C], [AC_DEFUN([_LT_AC_FILE_LTDLL_C])])
|
||||||
|
m4_ifndef([_LT_REQUIRED_DARWIN_CHECKS], [AC_DEFUN([_LT_REQUIRED_DARWIN_CHECKS])])
|
||||||
|
m4_ifndef([_LT_AC_PROG_CXXCPP], [AC_DEFUN([_LT_AC_PROG_CXXCPP])])
|
||||||
|
m4_ifndef([_LT_PREPARE_SED_QUOTE_VARS], [AC_DEFUN([_LT_PREPARE_SED_QUOTE_VARS])])
|
||||||
|
m4_ifndef([_LT_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_PROG_ECHO_BACKSLASH])])
|
||||||
|
m4_ifndef([_LT_PROG_F77], [AC_DEFUN([_LT_PROG_F77])])
|
||||||
|
m4_ifndef([_LT_PROG_FC], [AC_DEFUN([_LT_PROG_FC])])
|
||||||
|
m4_ifndef([_LT_PROG_CXX], [AC_DEFUN([_LT_PROG_CXX])])
|
||||||
|
|
|
@ -43,7 +43,6 @@ libgrib_api_la_prototypes= \
|
||||||
action_class_close.c \
|
action_class_close.c \
|
||||||
action_class_variable.c \
|
action_class_variable.c \
|
||||||
action_class_modify.c \
|
action_class_modify.c \
|
||||||
eccodes.c \
|
|
||||||
grib_accessor.c \
|
grib_accessor.c \
|
||||||
grib_concept.c \
|
grib_concept.c \
|
||||||
grib_hash_array.c \
|
grib_hash_array.c \
|
||||||
|
@ -65,16 +64,12 @@ libgrib_api_la_prototypes= \
|
||||||
grib_accessor_class_bufr_data.c \
|
grib_accessor_class_bufr_data.c \
|
||||||
grib_accessor_class_bufr_data_array.c \
|
grib_accessor_class_bufr_data_array.c \
|
||||||
grib_accessor_class_bufr_data_element.c \
|
grib_accessor_class_bufr_data_element.c \
|
||||||
grib_accessor_class_bufr_group.c \
|
|
||||||
grib_accessor_class_unpack_bufr_values.c \
|
|
||||||
grib_accessor_class_bufr_uncompressed_data.c \
|
|
||||||
grib_accessor_class_bufr_element.c \
|
|
||||||
grib_accessor_class_bufr_elements_table.c \
|
grib_accessor_class_bufr_elements_table.c \
|
||||||
grib_accessor_class_bufr_has_delayed_replication.c \
|
grib_accessor_class_bufr_group.c \
|
||||||
grib_accessor_class_bufr_subset_number.c \
|
|
||||||
grib_accessor_class_bufr_group_number.c \
|
|
||||||
grib_accessor_class_apply_operators.c \
|
|
||||||
grib_accessor_class_group.c \
|
grib_accessor_class_group.c \
|
||||||
|
grib_accessor_class_unpack_bufr_values.c \
|
||||||
|
grib_accessor_class_bufr_has_delayed_replication.c \
|
||||||
|
grib_accessor_class_apply_operators.c \
|
||||||
grib_accessor_class_non_alpha.c \
|
grib_accessor_class_non_alpha.c \
|
||||||
grib_accessor_class_g1bitmap.c \
|
grib_accessor_class_g1bitmap.c \
|
||||||
grib_accessor_class_g2bitmap.c \
|
grib_accessor_class_g2bitmap.c \
|
||||||
|
@ -353,7 +348,7 @@ libgrib_api_la_prototypes= \
|
||||||
|
|
||||||
libgrib_api_extra_prototypes = grib_bits_any_endian.c grib_bits_any_endian_simple.c
|
libgrib_api_extra_prototypes = grib_bits_any_endian.c grib_bits_any_endian_simple.c
|
||||||
|
|
||||||
libgrib_api_la_SOURCES = $(libgrib_api_la_prototypes) grib_yacc.c grib_lex.c md5.c
|
libgrib_api_la_SOURCES = $(libgrib_api_la_prototypes) eccodes.c grib_yacc.c grib_lex.c md5.c
|
||||||
|
|
||||||
libgrib_api_la_LIBADD = @LIBOBJS@
|
libgrib_api_la_LIBADD = @LIBOBJS@
|
||||||
libgrib_api_la_DEPENDENCIES = grib_api.h $(libgrib_api_la_LIBADD)
|
libgrib_api_la_DEPENDENCIES = grib_api.h $(libgrib_api_la_LIBADD)
|
||||||
|
|
|
@ -15,13 +15,9 @@ extern grib_accessor_class* grib_accessor_class_budgdate;
|
||||||
extern grib_accessor_class* grib_accessor_class_bufr_data;
|
extern grib_accessor_class* grib_accessor_class_bufr_data;
|
||||||
extern grib_accessor_class* grib_accessor_class_bufr_data_array;
|
extern grib_accessor_class* grib_accessor_class_bufr_data_array;
|
||||||
extern grib_accessor_class* grib_accessor_class_bufr_data_element;
|
extern grib_accessor_class* grib_accessor_class_bufr_data_element;
|
||||||
extern grib_accessor_class* grib_accessor_class_bufr_element;
|
|
||||||
extern grib_accessor_class* grib_accessor_class_bufr_elements_table;
|
extern grib_accessor_class* grib_accessor_class_bufr_elements_table;
|
||||||
extern grib_accessor_class* grib_accessor_class_bufr_group;
|
extern grib_accessor_class* grib_accessor_class_bufr_group;
|
||||||
extern grib_accessor_class* grib_accessor_class_bufr_group_number;
|
|
||||||
extern grib_accessor_class* grib_accessor_class_bufr_has_delayed_replication;
|
extern grib_accessor_class* grib_accessor_class_bufr_has_delayed_replication;
|
||||||
extern grib_accessor_class* grib_accessor_class_bufr_subset_number;
|
|
||||||
extern grib_accessor_class* grib_accessor_class_bufr_uncompressed_data;
|
|
||||||
extern grib_accessor_class* grib_accessor_class_bufrdc_expanded_descriptors;
|
extern grib_accessor_class* grib_accessor_class_bufrdc_expanded_descriptors;
|
||||||
extern grib_accessor_class* grib_accessor_class_bytes;
|
extern grib_accessor_class* grib_accessor_class_bytes;
|
||||||
extern grib_accessor_class* grib_accessor_class_change_scanning_direction;
|
extern grib_accessor_class* grib_accessor_class_change_scanning_direction;
|
||||||
|
|
|
@ -1,326 +0,0 @@
|
||||||
/**
|
|
||||||
* Copyright 2005-2015 ECMWF
|
|
||||||
*
|
|
||||||
* Licensed under the GNU Lesser General Public License which
|
|
||||||
* incorporates the terms and conditions of version 3 of the GNU
|
|
||||||
* General Public License.
|
|
||||||
* See LICENSE and gpl-3.0.txt for details.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*****************************************
|
|
||||||
* Enrico Fucile
|
|
||||||
****************************************/
|
|
||||||
|
|
||||||
#include "grib_api_internal.h"
|
|
||||||
#include <ctype.h>
|
|
||||||
|
|
||||||
/*
|
|
||||||
This is used by make_class.pl
|
|
||||||
|
|
||||||
START_CLASS_DEF
|
|
||||||
CLASS = accessor
|
|
||||||
SUPER = grib_accessor_class_gen
|
|
||||||
IMPLEMENTS = init;dump
|
|
||||||
IMPLEMENTS = unpack_string;unpack_string_array;unpack_long; unpack_double
|
|
||||||
IMPLEMENTS = value_count; destroy; get_native_type;
|
|
||||||
MEMBERS = grib_accessor* data_accessor
|
|
||||||
MEMBERS = int index
|
|
||||||
MEMBERS = int ielement
|
|
||||||
MEMBERS = int type
|
|
||||||
MEMBERS = int size
|
|
||||||
|
|
||||||
END_CLASS_DEF
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* START_CLASS_IMP */
|
|
||||||
|
|
||||||
/*
|
|
||||||
|
|
||||||
Don't edit anything between START_CLASS_IMP and END_CLASS_IMP
|
|
||||||
Instead edit values between START_CLASS_DEF and END_CLASS_DEF
|
|
||||||
or edit "accessor.class" and rerun ./make_class.pl
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
static int get_native_type(grib_accessor*);
|
|
||||||
static int unpack_double(grib_accessor*, double* val,size_t *len);
|
|
||||||
static int unpack_long(grib_accessor*, long* val,size_t *len);
|
|
||||||
static int unpack_string (grib_accessor*, char*, size_t *len);
|
|
||||||
static int unpack_string_array (grib_accessor*, char**, size_t *len);
|
|
||||||
static int value_count(grib_accessor*,long*);
|
|
||||||
static void destroy(grib_context*,grib_accessor*);
|
|
||||||
static void dump(grib_accessor*, grib_dumper*);
|
|
||||||
static void init(grib_accessor*,const long, grib_arguments* );
|
|
||||||
static void init_class(grib_accessor_class*);
|
|
||||||
|
|
||||||
typedef struct grib_accessor_bufr_element {
|
|
||||||
grib_accessor att;
|
|
||||||
/* Members defined in gen */
|
|
||||||
/* Members defined in bufr_element */
|
|
||||||
grib_accessor* data_accessor;
|
|
||||||
int index;
|
|
||||||
int ielement;
|
|
||||||
int type;
|
|
||||||
int size;
|
|
||||||
} grib_accessor_bufr_element;
|
|
||||||
|
|
||||||
extern grib_accessor_class* grib_accessor_class_gen;
|
|
||||||
|
|
||||||
static grib_accessor_class _grib_accessor_class_bufr_element = {
|
|
||||||
&grib_accessor_class_gen, /* super */
|
|
||||||
"bufr_element", /* name */
|
|
||||||
sizeof(grib_accessor_bufr_element), /* size */
|
|
||||||
0, /* inited */
|
|
||||||
&init_class, /* init_class */
|
|
||||||
&init, /* init */
|
|
||||||
0, /* post_init */
|
|
||||||
&destroy, /* free mem */
|
|
||||||
&dump, /* describes himself */
|
|
||||||
0, /* get length of section */
|
|
||||||
0, /* get length of string */
|
|
||||||
&value_count, /* get number of values */
|
|
||||||
0, /* get number of bytes */
|
|
||||||
0, /* get offset to bytes */
|
|
||||||
&get_native_type, /* get native type */
|
|
||||||
0, /* get sub_section */
|
|
||||||
0, /* grib_pack procedures long */
|
|
||||||
0, /* grib_pack procedures long */
|
|
||||||
0, /* grib_pack procedures long */
|
|
||||||
&unpack_long, /* grib_unpack procedures long */
|
|
||||||
0, /* grib_pack procedures double */
|
|
||||||
&unpack_double, /* grib_unpack procedures double */
|
|
||||||
0, /* grib_pack procedures string */
|
|
||||||
&unpack_string, /* grib_unpack procedures string */
|
|
||||||
0, /* grib_pack array procedures string */
|
|
||||||
&unpack_string_array, /* grib_unpack array procedures string */
|
|
||||||
0, /* grib_pack procedures bytes */
|
|
||||||
0, /* grib_unpack procedures bytes */
|
|
||||||
0, /* pack_expression */
|
|
||||||
0, /* notify_change */
|
|
||||||
0, /* update_size */
|
|
||||||
0, /* preferred_size */
|
|
||||||
0, /* resize */
|
|
||||||
0, /* nearest_smaller_value */
|
|
||||||
0, /* next accessor */
|
|
||||||
0, /* compare vs. another accessor */
|
|
||||||
0, /* unpack only ith value */
|
|
||||||
0, /* unpack a subarray */
|
|
||||||
0, /* clear */
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
grib_accessor_class* grib_accessor_class_bufr_element = &_grib_accessor_class_bufr_element;
|
|
||||||
|
|
||||||
|
|
||||||
static void init_class(grib_accessor_class* c)
|
|
||||||
{
|
|
||||||
c->next_offset = (*(c->super))->next_offset;
|
|
||||||
c->string_length = (*(c->super))->string_length;
|
|
||||||
c->byte_count = (*(c->super))->byte_count;
|
|
||||||
c->byte_offset = (*(c->super))->byte_offset;
|
|
||||||
c->sub_section = (*(c->super))->sub_section;
|
|
||||||
c->pack_missing = (*(c->super))->pack_missing;
|
|
||||||
c->is_missing = (*(c->super))->is_missing;
|
|
||||||
c->pack_long = (*(c->super))->pack_long;
|
|
||||||
c->pack_double = (*(c->super))->pack_double;
|
|
||||||
c->pack_string = (*(c->super))->pack_string;
|
|
||||||
c->pack_string_array = (*(c->super))->pack_string_array;
|
|
||||||
c->pack_bytes = (*(c->super))->pack_bytes;
|
|
||||||
c->unpack_bytes = (*(c->super))->unpack_bytes;
|
|
||||||
c->pack_expression = (*(c->super))->pack_expression;
|
|
||||||
c->notify_change = (*(c->super))->notify_change;
|
|
||||||
c->update_size = (*(c->super))->update_size;
|
|
||||||
c->preferred_size = (*(c->super))->preferred_size;
|
|
||||||
c->resize = (*(c->super))->resize;
|
|
||||||
c->nearest_smaller_value = (*(c->super))->nearest_smaller_value;
|
|
||||||
c->next = (*(c->super))->next;
|
|
||||||
c->compare = (*(c->super))->compare;
|
|
||||||
c->unpack_double_element = (*(c->super))->unpack_double_element;
|
|
||||||
c->unpack_double_subarray = (*(c->super))->unpack_double_subarray;
|
|
||||||
c->clear = (*(c->super))->clear;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* END_CLASS_IMP */
|
|
||||||
|
|
||||||
/*TODO move all those typedef in a unique .h file*/
|
|
||||||
typedef struct grib_accessor_bufr_uncompressed_data {
|
|
||||||
grib_accessor att;
|
|
||||||
/* Members defined in gen */
|
|
||||||
/* Members defined in bufr_uncompressed_data */
|
|
||||||
const char* offsetSection4Name;
|
|
||||||
const char* offsetBeforeDataName;
|
|
||||||
const char* offsetEndSection4Name;
|
|
||||||
const char* section4LengthName;
|
|
||||||
const char* numberOfDataSubsetsName;
|
|
||||||
const char* subsetNumberName;
|
|
||||||
const char* expandedDescriptorsName;
|
|
||||||
const char* abbreviationName;
|
|
||||||
const char* typeName;
|
|
||||||
const char* nameName;
|
|
||||||
const char* unitName;
|
|
||||||
const char* referenceName;
|
|
||||||
const char* scaleName;
|
|
||||||
const char* widthName;
|
|
||||||
const char* codeFlags;
|
|
||||||
const char* bitmapNumberName;
|
|
||||||
const char* associatedBitmapNumberName;
|
|
||||||
const char* associatedBitmapIndexName;
|
|
||||||
long* expandedDescriptors;
|
|
||||||
char** abbreviation;
|
|
||||||
char** type;
|
|
||||||
char** names;
|
|
||||||
char** units;
|
|
||||||
long* reference;
|
|
||||||
double* factor;
|
|
||||||
long* width;
|
|
||||||
long* bitmapNumber;
|
|
||||||
long* associatedBitmapNumber;
|
|
||||||
long* associatedBitmapIndex;
|
|
||||||
long numberOfElements;
|
|
||||||
long numberOfDataSubsets;
|
|
||||||
size_t numberOfDescriptors;
|
|
||||||
grib_darray* dvalues;
|
|
||||||
grib_sarray* svalues;
|
|
||||||
grib_iarray* is_constant;
|
|
||||||
grib_iarray* constant;
|
|
||||||
int do_compute;
|
|
||||||
} grib_accessor_bufr_uncompressed_data;
|
|
||||||
|
|
||||||
|
|
||||||
static void init(grib_accessor* a, const long len, grib_arguments* params) {
|
|
||||||
grib_accessor_bufr_element* self = (grib_accessor_bufr_element*)a;
|
|
||||||
|
|
||||||
a->length = 0;
|
|
||||||
self->size=1;
|
|
||||||
/* a->flags |= GRIB_ACCESSOR_FLAG_READ_ONLY; */
|
|
||||||
}
|
|
||||||
|
|
||||||
static void dump(grib_accessor* a, grib_dumper* dumper)
|
|
||||||
{
|
|
||||||
int type=get_native_type(a);
|
|
||||||
|
|
||||||
switch (type) {
|
|
||||||
case GRIB_TYPE_LONG:
|
|
||||||
grib_dump_long(dumper,a,NULL);
|
|
||||||
break;
|
|
||||||
case GRIB_TYPE_DOUBLE:
|
|
||||||
grib_dump_values(dumper,a);
|
|
||||||
break;
|
|
||||||
case GRIB_TYPE_STRING:
|
|
||||||
grib_dump_string_array(dumper,a,NULL);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static int unpack_string_array (grib_accessor* a, char** val, size_t *len)
|
|
||||||
{
|
|
||||||
grib_accessor_bufr_element* self = (grib_accessor_bufr_element*)a;
|
|
||||||
grib_accessor_bufr_uncompressed_data* data=(grib_accessor_bufr_uncompressed_data*)self->data_accessor;
|
|
||||||
long i=0;
|
|
||||||
long size=0;
|
|
||||||
int err=0;
|
|
||||||
|
|
||||||
err=value_count(a,&size);
|
|
||||||
if (err) return err;
|
|
||||||
|
|
||||||
if (*len < size) return GRIB_ARRAY_TOO_SMALL;
|
|
||||||
|
|
||||||
for (i=0;i<size;i++) val[i]=data->svalues->v[self->index+i];
|
|
||||||
*len=size;
|
|
||||||
|
|
||||||
return GRIB_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int unpack_string (grib_accessor* a, char* val, size_t *len)
|
|
||||||
{
|
|
||||||
grib_accessor_bufr_element* self = (grib_accessor_bufr_element*)a;
|
|
||||||
grib_accessor_bufr_uncompressed_data* data=(grib_accessor_bufr_uncompressed_data*)self->data_accessor;
|
|
||||||
long size=0;
|
|
||||||
|
|
||||||
size=strlen(data->svalues->v[self->index]);
|
|
||||||
|
|
||||||
if (*len < size) return GRIB_ARRAY_TOO_SMALL;
|
|
||||||
|
|
||||||
sprintf(val,"%s",data->svalues->v[self->index]);
|
|
||||||
|
|
||||||
return GRIB_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int unpack_long (grib_accessor* a, long* val, size_t *len)
|
|
||||||
{
|
|
||||||
grib_accessor_bufr_element* self = (grib_accessor_bufr_element*)a;
|
|
||||||
grib_accessor_bufr_uncompressed_data* data=(grib_accessor_bufr_uncompressed_data*)self->data_accessor;
|
|
||||||
long i=0;
|
|
||||||
long size=0;
|
|
||||||
int err=0;
|
|
||||||
double missingValue=GRIB_MISSING_DOUBLE;
|
|
||||||
|
|
||||||
err=value_count(a,&size);
|
|
||||||
if (err) return err;
|
|
||||||
|
|
||||||
if (*len < size) return GRIB_ARRAY_TOO_SMALL;
|
|
||||||
grib_get_double(a->parent->h,"missingValue",&missingValue);
|
|
||||||
|
|
||||||
for (i=0;i<size;i++) {
|
|
||||||
if (data->dvalues->v[self->index+i]==GRIB_MISSING_DOUBLE)
|
|
||||||
val[i]=missingValue;
|
|
||||||
else
|
|
||||||
val[i]=data->dvalues->v[self->index+i];
|
|
||||||
}
|
|
||||||
*len=size;
|
|
||||||
|
|
||||||
return GRIB_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int unpack_double (grib_accessor* a, double* val, size_t *len)
|
|
||||||
{
|
|
||||||
grib_accessor_bufr_element* self = (grib_accessor_bufr_element*)a;
|
|
||||||
grib_accessor_bufr_uncompressed_data* data=(grib_accessor_bufr_uncompressed_data*)self->data_accessor;
|
|
||||||
long i=0;
|
|
||||||
long size=0;
|
|
||||||
int start=self->index;
|
|
||||||
int err=0;
|
|
||||||
double missingValue=GRIB_MISSING_DOUBLE;
|
|
||||||
|
|
||||||
err=value_count(a,&size);
|
|
||||||
if (err) return err;
|
|
||||||
|
|
||||||
if (*len < size) return GRIB_ARRAY_TOO_SMALL;
|
|
||||||
grib_get_double(a->parent->h,"missingValue",&missingValue);
|
|
||||||
|
|
||||||
for (i=0;i<size;i++) {
|
|
||||||
if (data->dvalues->v[self->index+i]==GRIB_MISSING_DOUBLE)
|
|
||||||
val[i]=missingValue;
|
|
||||||
else
|
|
||||||
val[i]=data->dvalues->v[start+i];
|
|
||||||
}
|
|
||||||
*len=size;
|
|
||||||
|
|
||||||
return GRIB_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int value_count(grib_accessor* a,long* count)
|
|
||||||
{
|
|
||||||
grib_accessor_bufr_element* self = (grib_accessor_bufr_element*)a;
|
|
||||||
*count=self->size;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void destroy(grib_context* context,grib_accessor* a)
|
|
||||||
{
|
|
||||||
if (a->vvalue != NULL) {
|
|
||||||
grib_context_free(context, a->vvalue);
|
|
||||||
a->vvalue=NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
static int get_native_type(grib_accessor* a){
|
|
||||||
grib_accessor_bufr_element* self = (grib_accessor_bufr_element*)a;
|
|
||||||
return self->type;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,160 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright 2005-2015 ECMWF.
|
|
||||||
*
|
|
||||||
* This software is licensed under the terms of the Apache Licence Version 2.0
|
|
||||||
* which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
|
|
||||||
*
|
|
||||||
* In applying this licence, ECMWF does not waive the privileges and immunities granted to it by
|
|
||||||
* virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/************************************
|
|
||||||
* Enrico Fucile
|
|
||||||
**********************************/
|
|
||||||
|
|
||||||
#include "grib_api_internal.h"
|
|
||||||
/*
|
|
||||||
This is used by make_class.pl
|
|
||||||
|
|
||||||
START_CLASS_DEF
|
|
||||||
CLASS = accessor
|
|
||||||
SUPER = grib_accessor_class_long
|
|
||||||
IMPLEMENTS = unpack_long
|
|
||||||
IMPLEMENTS = get_native_type
|
|
||||||
IMPLEMENTS = pack_long
|
|
||||||
IMPLEMENTS = init
|
|
||||||
END_CLASS_DEF
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* START_CLASS_IMP */
|
|
||||||
|
|
||||||
/*
|
|
||||||
|
|
||||||
Don't edit anything between START_CLASS_IMP and END_CLASS_IMP
|
|
||||||
Instead edit values between START_CLASS_DEF and END_CLASS_DEF
|
|
||||||
or edit "accessor.class" and rerun ./make_class.pl
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
static int get_native_type(grib_accessor*);
|
|
||||||
static int pack_long(grib_accessor*, const long* val,size_t *len);
|
|
||||||
static int unpack_long(grib_accessor*, long* val,size_t *len);
|
|
||||||
static void init(grib_accessor*,const long, grib_arguments* );
|
|
||||||
static void init_class(grib_accessor_class*);
|
|
||||||
|
|
||||||
typedef struct grib_accessor_bufr_group_number {
|
|
||||||
grib_accessor att;
|
|
||||||
/* Members defined in gen */
|
|
||||||
/* Members defined in long */
|
|
||||||
/* Members defined in bufr_group_number */
|
|
||||||
} grib_accessor_bufr_group_number;
|
|
||||||
|
|
||||||
extern grib_accessor_class* grib_accessor_class_long;
|
|
||||||
|
|
||||||
static grib_accessor_class _grib_accessor_class_bufr_group_number = {
|
|
||||||
&grib_accessor_class_long, /* super */
|
|
||||||
"bufr_group_number", /* name */
|
|
||||||
sizeof(grib_accessor_bufr_group_number), /* size */
|
|
||||||
0, /* inited */
|
|
||||||
&init_class, /* init_class */
|
|
||||||
&init, /* init */
|
|
||||||
0, /* post_init */
|
|
||||||
0, /* free mem */
|
|
||||||
0, /* describes himself */
|
|
||||||
0, /* get length of section */
|
|
||||||
0, /* get length of string */
|
|
||||||
0, /* get number of values */
|
|
||||||
0, /* get number of bytes */
|
|
||||||
0, /* get offset to bytes */
|
|
||||||
&get_native_type, /* get native type */
|
|
||||||
0, /* get sub_section */
|
|
||||||
0, /* grib_pack procedures long */
|
|
||||||
0, /* grib_pack procedures long */
|
|
||||||
&pack_long, /* grib_pack procedures long */
|
|
||||||
&unpack_long, /* grib_unpack procedures long */
|
|
||||||
0, /* grib_pack procedures double */
|
|
||||||
0, /* grib_unpack procedures double */
|
|
||||||
0, /* grib_pack procedures string */
|
|
||||||
0, /* grib_unpack procedures string */
|
|
||||||
0, /* grib_pack array procedures string */
|
|
||||||
0, /* grib_unpack array procedures string */
|
|
||||||
0, /* grib_pack procedures bytes */
|
|
||||||
0, /* grib_unpack procedures bytes */
|
|
||||||
0, /* pack_expression */
|
|
||||||
0, /* notify_change */
|
|
||||||
0, /* update_size */
|
|
||||||
0, /* preferred_size */
|
|
||||||
0, /* resize */
|
|
||||||
0, /* nearest_smaller_value */
|
|
||||||
0, /* next accessor */
|
|
||||||
0, /* compare vs. another accessor */
|
|
||||||
0, /* unpack only ith value */
|
|
||||||
0, /* unpack a subarray */
|
|
||||||
0, /* clear */
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
grib_accessor_class* grib_accessor_class_bufr_group_number = &_grib_accessor_class_bufr_group_number;
|
|
||||||
|
|
||||||
|
|
||||||
static void init_class(grib_accessor_class* c)
|
|
||||||
{
|
|
||||||
c->dump = (*(c->super))->dump;
|
|
||||||
c->next_offset = (*(c->super))->next_offset;
|
|
||||||
c->string_length = (*(c->super))->string_length;
|
|
||||||
c->value_count = (*(c->super))->value_count;
|
|
||||||
c->byte_count = (*(c->super))->byte_count;
|
|
||||||
c->byte_offset = (*(c->super))->byte_offset;
|
|
||||||
c->sub_section = (*(c->super))->sub_section;
|
|
||||||
c->pack_missing = (*(c->super))->pack_missing;
|
|
||||||
c->is_missing = (*(c->super))->is_missing;
|
|
||||||
c->pack_double = (*(c->super))->pack_double;
|
|
||||||
c->unpack_double = (*(c->super))->unpack_double;
|
|
||||||
c->pack_string = (*(c->super))->pack_string;
|
|
||||||
c->unpack_string = (*(c->super))->unpack_string;
|
|
||||||
c->pack_string_array = (*(c->super))->pack_string_array;
|
|
||||||
c->unpack_string_array = (*(c->super))->unpack_string_array;
|
|
||||||
c->pack_bytes = (*(c->super))->pack_bytes;
|
|
||||||
c->unpack_bytes = (*(c->super))->unpack_bytes;
|
|
||||||
c->pack_expression = (*(c->super))->pack_expression;
|
|
||||||
c->notify_change = (*(c->super))->notify_change;
|
|
||||||
c->update_size = (*(c->super))->update_size;
|
|
||||||
c->preferred_size = (*(c->super))->preferred_size;
|
|
||||||
c->resize = (*(c->super))->resize;
|
|
||||||
c->nearest_smaller_value = (*(c->super))->nearest_smaller_value;
|
|
||||||
c->next = (*(c->super))->next;
|
|
||||||
c->compare = (*(c->super))->compare;
|
|
||||||
c->unpack_double_element = (*(c->super))->unpack_double_element;
|
|
||||||
c->unpack_double_subarray = (*(c->super))->unpack_double_subarray;
|
|
||||||
c->clear = (*(c->super))->clear;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* END_CLASS_IMP */
|
|
||||||
|
|
||||||
static void init(grib_accessor* a,const long l, grib_arguments* c)
|
|
||||||
{
|
|
||||||
a->bufr_group_number=0;
|
|
||||||
a->flags |= GRIB_ACCESSOR_FLAG_HIDDEN;
|
|
||||||
a->length=0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int pack_long (grib_accessor* a, const long* val, size_t *len)
|
|
||||||
{
|
|
||||||
a->parent->h->bufr_group_number=*val;
|
|
||||||
return GRIB_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int unpack_long (grib_accessor* a, long* val, size_t *len)
|
|
||||||
{
|
|
||||||
|
|
||||||
*val=a->parent->h->bufr_group_number;
|
|
||||||
*len=1;
|
|
||||||
|
|
||||||
return GRIB_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int get_native_type(grib_accessor* a)
|
|
||||||
{
|
|
||||||
return GRIB_TYPE_LONG;
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,153 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright 2005-2015 ECMWF.
|
|
||||||
*
|
|
||||||
* This software is licensed under the terms of the Apache Licence Version 2.0
|
|
||||||
* which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
|
|
||||||
*
|
|
||||||
* In applying this licence, ECMWF does not waive the privileges and immunities granted to it by
|
|
||||||
* virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/************************************
|
|
||||||
* Enrico Fucile
|
|
||||||
**********************************/
|
|
||||||
|
|
||||||
#include "grib_api_internal.h"
|
|
||||||
/*
|
|
||||||
This is used by make_class.pl
|
|
||||||
|
|
||||||
START_CLASS_DEF
|
|
||||||
CLASS = accessor
|
|
||||||
SUPER = grib_accessor_class_long
|
|
||||||
IMPLEMENTS = unpack_long
|
|
||||||
IMPLEMENTS = pack_long
|
|
||||||
IMPLEMENTS = init
|
|
||||||
END_CLASS_DEF
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* START_CLASS_IMP */
|
|
||||||
|
|
||||||
/*
|
|
||||||
|
|
||||||
Don't edit anything between START_CLASS_IMP and END_CLASS_IMP
|
|
||||||
Instead edit values between START_CLASS_DEF and END_CLASS_DEF
|
|
||||||
or edit "accessor.class" and rerun ./make_class.pl
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
static int pack_long(grib_accessor*, const long* val,size_t *len);
|
|
||||||
static int unpack_long(grib_accessor*, long* val,size_t *len);
|
|
||||||
static void init(grib_accessor*,const long, grib_arguments* );
|
|
||||||
static void init_class(grib_accessor_class*);
|
|
||||||
|
|
||||||
typedef struct grib_accessor_bufr_subset_number {
|
|
||||||
grib_accessor att;
|
|
||||||
/* Members defined in gen */
|
|
||||||
/* Members defined in long */
|
|
||||||
/* Members defined in bufr_subset_number */
|
|
||||||
} grib_accessor_bufr_subset_number;
|
|
||||||
|
|
||||||
extern grib_accessor_class* grib_accessor_class_long;
|
|
||||||
|
|
||||||
static grib_accessor_class _grib_accessor_class_bufr_subset_number = {
|
|
||||||
&grib_accessor_class_long, /* super */
|
|
||||||
"bufr_subset_number", /* name */
|
|
||||||
sizeof(grib_accessor_bufr_subset_number), /* size */
|
|
||||||
0, /* inited */
|
|
||||||
&init_class, /* init_class */
|
|
||||||
&init, /* init */
|
|
||||||
0, /* post_init */
|
|
||||||
0, /* free mem */
|
|
||||||
0, /* describes himself */
|
|
||||||
0, /* get length of section */
|
|
||||||
0, /* get length of string */
|
|
||||||
0, /* get number of values */
|
|
||||||
0, /* get number of bytes */
|
|
||||||
0, /* get offset to bytes */
|
|
||||||
0, /* get native type */
|
|
||||||
0, /* get sub_section */
|
|
||||||
0, /* grib_pack procedures long */
|
|
||||||
0, /* grib_pack procedures long */
|
|
||||||
&pack_long, /* grib_pack procedures long */
|
|
||||||
&unpack_long, /* grib_unpack procedures long */
|
|
||||||
0, /* grib_pack procedures double */
|
|
||||||
0, /* grib_unpack procedures double */
|
|
||||||
0, /* grib_pack procedures string */
|
|
||||||
0, /* grib_unpack procedures string */
|
|
||||||
0, /* grib_pack array procedures string */
|
|
||||||
0, /* grib_unpack array procedures string */
|
|
||||||
0, /* grib_pack procedures bytes */
|
|
||||||
0, /* grib_unpack procedures bytes */
|
|
||||||
0, /* pack_expression */
|
|
||||||
0, /* notify_change */
|
|
||||||
0, /* update_size */
|
|
||||||
0, /* preferred_size */
|
|
||||||
0, /* resize */
|
|
||||||
0, /* nearest_smaller_value */
|
|
||||||
0, /* next accessor */
|
|
||||||
0, /* compare vs. another accessor */
|
|
||||||
0, /* unpack only ith value */
|
|
||||||
0, /* unpack a subarray */
|
|
||||||
0, /* clear */
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
grib_accessor_class* grib_accessor_class_bufr_subset_number = &_grib_accessor_class_bufr_subset_number;
|
|
||||||
|
|
||||||
|
|
||||||
static void init_class(grib_accessor_class* c)
|
|
||||||
{
|
|
||||||
c->dump = (*(c->super))->dump;
|
|
||||||
c->next_offset = (*(c->super))->next_offset;
|
|
||||||
c->string_length = (*(c->super))->string_length;
|
|
||||||
c->value_count = (*(c->super))->value_count;
|
|
||||||
c->byte_count = (*(c->super))->byte_count;
|
|
||||||
c->byte_offset = (*(c->super))->byte_offset;
|
|
||||||
c->get_native_type = (*(c->super))->get_native_type;
|
|
||||||
c->sub_section = (*(c->super))->sub_section;
|
|
||||||
c->pack_missing = (*(c->super))->pack_missing;
|
|
||||||
c->is_missing = (*(c->super))->is_missing;
|
|
||||||
c->pack_double = (*(c->super))->pack_double;
|
|
||||||
c->unpack_double = (*(c->super))->unpack_double;
|
|
||||||
c->pack_string = (*(c->super))->pack_string;
|
|
||||||
c->unpack_string = (*(c->super))->unpack_string;
|
|
||||||
c->pack_string_array = (*(c->super))->pack_string_array;
|
|
||||||
c->unpack_string_array = (*(c->super))->unpack_string_array;
|
|
||||||
c->pack_bytes = (*(c->super))->pack_bytes;
|
|
||||||
c->unpack_bytes = (*(c->super))->unpack_bytes;
|
|
||||||
c->pack_expression = (*(c->super))->pack_expression;
|
|
||||||
c->notify_change = (*(c->super))->notify_change;
|
|
||||||
c->update_size = (*(c->super))->update_size;
|
|
||||||
c->preferred_size = (*(c->super))->preferred_size;
|
|
||||||
c->resize = (*(c->super))->resize;
|
|
||||||
c->nearest_smaller_value = (*(c->super))->nearest_smaller_value;
|
|
||||||
c->next = (*(c->super))->next;
|
|
||||||
c->compare = (*(c->super))->compare;
|
|
||||||
c->unpack_double_element = (*(c->super))->unpack_double_element;
|
|
||||||
c->unpack_double_subarray = (*(c->super))->unpack_double_subarray;
|
|
||||||
c->clear = (*(c->super))->clear;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* END_CLASS_IMP */
|
|
||||||
|
|
||||||
static void init(grib_accessor* a,const long l, grib_arguments* c)
|
|
||||||
{
|
|
||||||
a->parent->h->bufr_subset_number=0;
|
|
||||||
a->flags |= GRIB_ACCESSOR_FLAG_HIDDEN;
|
|
||||||
a->length=0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int pack_long (grib_accessor* a, const long* val, size_t *len)
|
|
||||||
{
|
|
||||||
a->parent->h->bufr_subset_number=*val;
|
|
||||||
return GRIB_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int unpack_long (grib_accessor* a, long* val, size_t *len)
|
|
||||||
{
|
|
||||||
|
|
||||||
*val=a->parent->h->bufr_subset_number;
|
|
||||||
|
|
||||||
return GRIB_SUCCESS;
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,788 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright 2005-2015 ECMWF.
|
|
||||||
*
|
|
||||||
* This software is licensed under the terms of the Apache Licence Version 2.0
|
|
||||||
* which can be obtained at http://www.apache.org/licenses/LICENSE-2.0.
|
|
||||||
*
|
|
||||||
* In applying this licence, ECMWF does not waive the privileges and immunities granted to it by
|
|
||||||
* virtue of its status as an intergovernmental organisation nor does it submit to any jurisdiction.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#include "grib_api_internal.h"
|
|
||||||
|
|
||||||
/*
|
|
||||||
This is used by make_class.pl
|
|
||||||
|
|
||||||
START_CLASS_DEF
|
|
||||||
CLASS = accessor
|
|
||||||
SUPER = grib_accessor_class_gen
|
|
||||||
IMPLEMENTS = init
|
|
||||||
IMPLEMENTS = dump
|
|
||||||
IMPLEMENTS = next_offset
|
|
||||||
IMPLEMENTS = byte_count; value_count
|
|
||||||
IMPLEMENTS = byte_offset
|
|
||||||
IMPLEMENTS = get_native_type
|
|
||||||
IMPLEMENTS = update_size
|
|
||||||
IMPLEMENTS = compare; next
|
|
||||||
IMPLEMENTS = pack_long; unpack_double; pack_double
|
|
||||||
MEMBERS= const char* offsetSection4Name
|
|
||||||
MEMBERS= const char* offsetBeforeDataName
|
|
||||||
MEMBERS= const char* offsetEndSection4Name
|
|
||||||
MEMBERS= const char* section4LengthName
|
|
||||||
MEMBERS= const char* numberOfDataSubsetsName
|
|
||||||
MEMBERS= const char* subsetNumberName
|
|
||||||
MEMBERS= const char* expandedDescriptorsName
|
|
||||||
MEMBERS= const char* abbreviationName
|
|
||||||
MEMBERS= const char* typeName
|
|
||||||
MEMBERS= const char* nameName
|
|
||||||
MEMBERS= const char* unitName
|
|
||||||
MEMBERS= const char* referenceName
|
|
||||||
MEMBERS= const char* scaleName
|
|
||||||
MEMBERS= const char* widthName
|
|
||||||
MEMBERS= const char* codeFlags
|
|
||||||
MEMBERS= const char* bitmapNumberName
|
|
||||||
MEMBERS= const char* associatedBitmapNumberName
|
|
||||||
MEMBERS= const char* associatedBitmapIndexName
|
|
||||||
MEMBERS= long* expandedDescriptors
|
|
||||||
MEMBERS= char** abbreviation
|
|
||||||
MEMBERS= char** type
|
|
||||||
MEMBERS= char** names
|
|
||||||
MEMBERS= char** units
|
|
||||||
MEMBERS= long* reference
|
|
||||||
MEMBERS= double* factor
|
|
||||||
MEMBERS= long* width
|
|
||||||
MEMBERS= long* bitmapNumber
|
|
||||||
MEMBERS= long* associatedBitmapNumber
|
|
||||||
MEMBERS= long* associatedBitmapIndex
|
|
||||||
MEMBERS= long numberOfElements
|
|
||||||
MEMBERS= long numberOfDataSubsets
|
|
||||||
MEMBERS= size_t numberOfDescriptors
|
|
||||||
MEMBERS= grib_darray* dvalues
|
|
||||||
MEMBERS= grib_sarray* svalues
|
|
||||||
MEMBERS= int do_compute
|
|
||||||
END_CLASS_DEF
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* START_CLASS_IMP */
|
|
||||||
|
|
||||||
/*
|
|
||||||
|
|
||||||
Don't edit anything between START_CLASS_IMP and END_CLASS_IMP
|
|
||||||
Instead edit values between START_CLASS_DEF and END_CLASS_DEF
|
|
||||||
or edit "accessor.class" and rerun ./make_class.pl
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
static int get_native_type(grib_accessor*);
|
|
||||||
static int pack_double(grib_accessor*, const double* val,size_t *len);
|
|
||||||
static int pack_long(grib_accessor*, const long* val,size_t *len);
|
|
||||||
static int unpack_double(grib_accessor*, double* val,size_t *len);
|
|
||||||
static long byte_count(grib_accessor*);
|
|
||||||
static long byte_offset(grib_accessor*);
|
|
||||||
static long next_offset(grib_accessor*);
|
|
||||||
static int value_count(grib_accessor*,long*);
|
|
||||||
static void dump(grib_accessor*, grib_dumper*);
|
|
||||||
static void init(grib_accessor*,const long, grib_arguments* );
|
|
||||||
static void init_class(grib_accessor_class*);
|
|
||||||
static void update_size(grib_accessor*,size_t);
|
|
||||||
static grib_accessor* next(grib_accessor*, int);
|
|
||||||
static int compare(grib_accessor*, grib_accessor*);
|
|
||||||
|
|
||||||
typedef struct grib_accessor_bufr_uncompressed_data {
|
|
||||||
grib_accessor att;
|
|
||||||
/* Members defined in gen */
|
|
||||||
/* Members defined in bufr_uncompressed_data */
|
|
||||||
const char* offsetSection4Name;
|
|
||||||
const char* offsetBeforeDataName;
|
|
||||||
const char* offsetEndSection4Name;
|
|
||||||
const char* section4LengthName;
|
|
||||||
const char* numberOfDataSubsetsName;
|
|
||||||
const char* subsetNumberName;
|
|
||||||
const char* expandedDescriptorsName;
|
|
||||||
const char* abbreviationName;
|
|
||||||
const char* typeName;
|
|
||||||
const char* nameName;
|
|
||||||
const char* unitName;
|
|
||||||
const char* referenceName;
|
|
||||||
const char* scaleName;
|
|
||||||
const char* widthName;
|
|
||||||
const char* codeFlags;
|
|
||||||
const char* bitmapNumberName;
|
|
||||||
const char* associatedBitmapNumberName;
|
|
||||||
const char* associatedBitmapIndexName;
|
|
||||||
long* expandedDescriptors;
|
|
||||||
char** abbreviation;
|
|
||||||
char** type;
|
|
||||||
char** names;
|
|
||||||
char** units;
|
|
||||||
long* reference;
|
|
||||||
double* factor;
|
|
||||||
long* width;
|
|
||||||
long* bitmapNumber;
|
|
||||||
long* associatedBitmapNumber;
|
|
||||||
long* associatedBitmapIndex;
|
|
||||||
long numberOfElements;
|
|
||||||
long numberOfDataSubsets;
|
|
||||||
size_t numberOfDescriptors;
|
|
||||||
grib_darray* dvalues;
|
|
||||||
grib_sarray* svalues;
|
|
||||||
int do_compute;
|
|
||||||
} grib_accessor_bufr_uncompressed_data;
|
|
||||||
|
|
||||||
extern grib_accessor_class* grib_accessor_class_gen;
|
|
||||||
|
|
||||||
static grib_accessor_class _grib_accessor_class_bufr_uncompressed_data = {
|
|
||||||
&grib_accessor_class_gen, /* super */
|
|
||||||
"bufr_uncompressed_data", /* name */
|
|
||||||
sizeof(grib_accessor_bufr_uncompressed_data), /* size */
|
|
||||||
0, /* inited */
|
|
||||||
&init_class, /* init_class */
|
|
||||||
&init, /* init */
|
|
||||||
0, /* post_init */
|
|
||||||
0, /* free mem */
|
|
||||||
&dump, /* describes himself */
|
|
||||||
&next_offset, /* get length of section */
|
|
||||||
0, /* get length of string */
|
|
||||||
&value_count, /* get number of values */
|
|
||||||
&byte_count, /* get number of bytes */
|
|
||||||
&byte_offset, /* get offset to bytes */
|
|
||||||
&get_native_type, /* get native type */
|
|
||||||
0, /* get sub_section */
|
|
||||||
0, /* grib_pack procedures long */
|
|
||||||
0, /* grib_pack procedures long */
|
|
||||||
&pack_long, /* grib_pack procedures long */
|
|
||||||
0, /* grib_unpack procedures long */
|
|
||||||
&pack_double, /* grib_pack procedures double */
|
|
||||||
&unpack_double, /* grib_unpack procedures double */
|
|
||||||
0, /* grib_pack procedures string */
|
|
||||||
0, /* grib_unpack procedures string */
|
|
||||||
0, /* grib_pack array procedures string */
|
|
||||||
0, /* grib_unpack array procedures string */
|
|
||||||
0, /* grib_pack procedures bytes */
|
|
||||||
0, /* grib_unpack procedures bytes */
|
|
||||||
0, /* pack_expression */
|
|
||||||
0, /* notify_change */
|
|
||||||
&update_size, /* update_size */
|
|
||||||
0, /* preferred_size */
|
|
||||||
0, /* resize */
|
|
||||||
0, /* nearest_smaller_value */
|
|
||||||
&next, /* next accessor */
|
|
||||||
&compare, /* compare vs. another accessor */
|
|
||||||
0, /* unpack only ith value */
|
|
||||||
0, /* unpack a subarray */
|
|
||||||
0, /* clear */
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
grib_accessor_class* grib_accessor_class_bufr_uncompressed_data = &_grib_accessor_class_bufr_uncompressed_data;
|
|
||||||
|
|
||||||
|
|
||||||
static void init_class(grib_accessor_class* c)
|
|
||||||
{
|
|
||||||
c->string_length = (*(c->super))->string_length;
|
|
||||||
c->sub_section = (*(c->super))->sub_section;
|
|
||||||
c->pack_missing = (*(c->super))->pack_missing;
|
|
||||||
c->is_missing = (*(c->super))->is_missing;
|
|
||||||
c->unpack_long = (*(c->super))->unpack_long;
|
|
||||||
c->pack_string = (*(c->super))->pack_string;
|
|
||||||
c->unpack_string = (*(c->super))->unpack_string;
|
|
||||||
c->pack_string_array = (*(c->super))->pack_string_array;
|
|
||||||
c->unpack_string_array = (*(c->super))->unpack_string_array;
|
|
||||||
c->pack_bytes = (*(c->super))->pack_bytes;
|
|
||||||
c->unpack_bytes = (*(c->super))->unpack_bytes;
|
|
||||||
c->pack_expression = (*(c->super))->pack_expression;
|
|
||||||
c->notify_change = (*(c->super))->notify_change;
|
|
||||||
c->preferred_size = (*(c->super))->preferred_size;
|
|
||||||
c->resize = (*(c->super))->resize;
|
|
||||||
c->nearest_smaller_value = (*(c->super))->nearest_smaller_value;
|
|
||||||
c->unpack_double_element = (*(c->super))->unpack_double_element;
|
|
||||||
c->unpack_double_subarray = (*(c->super))->unpack_double_subarray;
|
|
||||||
c->clear = (*(c->super))->clear;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* END_CLASS_IMP */
|
|
||||||
|
|
||||||
typedef struct grib_accessor_constant {
|
|
||||||
grib_accessor att;
|
|
||||||
/* Members defined in gen */
|
|
||||||
/* Members defined in variable */
|
|
||||||
double dval;
|
|
||||||
char* cval;
|
|
||||||
int type;
|
|
||||||
/* Members defined in constant */
|
|
||||||
} grib_accessor_constant;
|
|
||||||
|
|
||||||
typedef struct grib_accessor_bufr_element {
|
|
||||||
grib_accessor att;
|
|
||||||
/* Members defined in gen */
|
|
||||||
/* Members defined in bufr_element */
|
|
||||||
grib_accessor* data_accessor;
|
|
||||||
int index;
|
|
||||||
int ielement;
|
|
||||||
int type;
|
|
||||||
int size;
|
|
||||||
} grib_accessor_bufr_element;
|
|
||||||
|
|
||||||
static long init_length(grib_accessor* a)
|
|
||||||
{
|
|
||||||
grib_accessor_bufr_uncompressed_data *self =(grib_accessor_bufr_uncompressed_data*)a;
|
|
||||||
long section4Length=0;
|
|
||||||
|
|
||||||
grib_handle* h=a->parent->h;
|
|
||||||
|
|
||||||
grib_get_long(h,self->section4LengthName,§ion4Length);
|
|
||||||
|
|
||||||
return section4Length-4;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void init(grib_accessor* a,const long v, grib_arguments* params)
|
|
||||||
{
|
|
||||||
grib_accessor_bufr_uncompressed_data *self =(grib_accessor_bufr_uncompressed_data*)a;
|
|
||||||
int n = 0;
|
|
||||||
|
|
||||||
a->sub_section = grib_section_create(a->parent->h,a);
|
|
||||||
|
|
||||||
self->offsetSection4Name = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->offsetBeforeDataName = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->offsetEndSection4Name = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->section4LengthName = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->numberOfDataSubsetsName = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->subsetNumberName = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->expandedDescriptorsName = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->abbreviationName = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->typeName = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->nameName = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->unitName = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->referenceName = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->scaleName = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->widthName = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->codeFlags = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->bitmapNumberName = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->associatedBitmapNumberName = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->associatedBitmapIndexName = grib_arguments_get_name(a->parent->h,params,n++);
|
|
||||||
self->expandedDescriptors=0;
|
|
||||||
self->numberOfDescriptors=0;
|
|
||||||
self->numberOfElements=0;
|
|
||||||
self->numberOfDataSubsets=0;
|
|
||||||
self->expandedDescriptors=0;
|
|
||||||
self->abbreviation=0;
|
|
||||||
self->type=0;
|
|
||||||
self->names=0;
|
|
||||||
self->units=0;
|
|
||||||
self->reference=0;
|
|
||||||
self->factor=0;
|
|
||||||
self->width=0;
|
|
||||||
self->dvalues=0;
|
|
||||||
self->svalues=0;
|
|
||||||
self->do_compute=1;
|
|
||||||
|
|
||||||
a->length = init_length(a);
|
|
||||||
|
|
||||||
/* Assert(a->length>=0); */
|
|
||||||
}
|
|
||||||
|
|
||||||
static int get_native_type(grib_accessor* a){
|
|
||||||
return GRIB_TYPE_DOUBLE;
|
|
||||||
}
|
|
||||||
|
|
||||||
static long byte_count(grib_accessor* a){
|
|
||||||
return a->length;
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
static long byte_offset(grib_accessor* a){
|
|
||||||
return a->offset;
|
|
||||||
}
|
|
||||||
|
|
||||||
static long next_offset(grib_accessor* a){
|
|
||||||
return a->offset+a->length;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void update_size(grib_accessor* a,size_t s)
|
|
||||||
{
|
|
||||||
grib_context_log(a->parent->h->context,GRIB_LOG_DEBUG,"updating size of %s old %ld new %ld",a->name,a->length,s);
|
|
||||||
a->length = s;
|
|
||||||
Assert(a->length>=0);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int compare(grib_accessor* a, grib_accessor* b) {
|
|
||||||
return GRIB_NOT_IMPLEMENTED;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int pack_long(grib_accessor* a, const long* val, size_t *len)
|
|
||||||
{
|
|
||||||
grib_accessor_bufr_uncompressed_data *self =(grib_accessor_bufr_uncompressed_data*)a;
|
|
||||||
self->do_compute=1;
|
|
||||||
|
|
||||||
return GRIB_NOT_IMPLEMENTED;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int pack_double(grib_accessor* a, const double* val, size_t *len)
|
|
||||||
{
|
|
||||||
grib_accessor_bufr_uncompressed_data *self =(grib_accessor_bufr_uncompressed_data*)a;
|
|
||||||
self->do_compute=1;
|
|
||||||
if (self->dvalues) grib_context_free(a->parent->h->context,self->dvalues);
|
|
||||||
if (self->svalues) grib_context_free(a->parent->h->context,self->svalues);
|
|
||||||
|
|
||||||
return GRIB_NOT_IMPLEMENTED;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
static int get_descriptors(grib_accessor* a) {
|
|
||||||
int err=0;
|
|
||||||
size_t size=0;
|
|
||||||
long* scale=0;
|
|
||||||
double* factor=0;
|
|
||||||
int i=0;
|
|
||||||
grib_accessor_bufr_uncompressed_data *self =(grib_accessor_bufr_uncompressed_data*)a;
|
|
||||||
grib_accessor* expandedDescriptors=0;
|
|
||||||
grib_handle* h=a->parent->h;
|
|
||||||
grib_context* c=a->parent->h->context;
|
|
||||||
|
|
||||||
expandedDescriptors=grib_find_accessor(a->parent->h,self->expandedDescriptorsName);
|
|
||||||
if (!expandedDescriptors) {
|
|
||||||
grib_context_log(a->parent->h->context,GRIB_LOG_ERROR,
|
|
||||||
"unable to find accessor %s",self->expandedDescriptorsName);
|
|
||||||
return GRIB_NOT_FOUND;
|
|
||||||
}
|
|
||||||
|
|
||||||
err=_grib_get_size(a->parent->h,expandedDescriptors,&(self->numberOfDescriptors));
|
|
||||||
if (err) return err;
|
|
||||||
|
|
||||||
self->expandedDescriptors=(long*)grib_context_malloc_clear(a->parent->h->context,sizeof(long)*self->numberOfDescriptors);
|
|
||||||
if (!self->expandedDescriptors) {
|
|
||||||
grib_context_log(a->parent->h->context,GRIB_LOG_FATAL,
|
|
||||||
"unable to allocate %ld bytes",(long)(self->numberOfDescriptors));
|
|
||||||
return GRIB_OUT_OF_MEMORY;
|
|
||||||
}
|
|
||||||
|
|
||||||
if( (err = grib_unpack_long(expandedDescriptors,self->expandedDescriptors,&(self->numberOfDescriptors)))
|
|
||||||
!= GRIB_SUCCESS)
|
|
||||||
return err;
|
|
||||||
|
|
||||||
size=self->numberOfDescriptors;
|
|
||||||
self->abbreviation=(char**)grib_context_malloc_clear(c,size*sizeof(char*));
|
|
||||||
err=grib_get_string_array(h,self->abbreviationName,self->abbreviation,&size);
|
|
||||||
|
|
||||||
self->type=(char**)grib_context_malloc_clear(c,size*sizeof(char*));
|
|
||||||
err=grib_get_string_array(h,self->typeName,self->type,&size);
|
|
||||||
|
|
||||||
self->names=(char**)grib_context_malloc_clear(c,size*sizeof(char*));
|
|
||||||
err=grib_get_string_array(h,self->nameName,self->names,&size);
|
|
||||||
|
|
||||||
self->units=(char**)grib_context_malloc_clear(c,size*sizeof(char*));
|
|
||||||
err=grib_get_string_array(h,self->unitName,self->units,&size);
|
|
||||||
|
|
||||||
self->reference=(long*)grib_context_malloc_clear(c,size*sizeof(long));
|
|
||||||
err=grib_get_long_array(h,self->referenceName,self->reference,&size);
|
|
||||||
|
|
||||||
scale=(long*)grib_context_malloc_clear(c,size*sizeof(long));
|
|
||||||
factor=(double*)grib_context_malloc_clear(c,size*sizeof(double));
|
|
||||||
err=grib_get_long_array(h,self->scaleName,scale,&size);
|
|
||||||
for (i=0;i<size;i++) factor[i]=grib_power(-scale[i],10);
|
|
||||||
self->factor=factor;
|
|
||||||
grib_context_free(c,scale);
|
|
||||||
|
|
||||||
self->width=(long*)grib_context_malloc_clear(c,size*sizeof(long));
|
|
||||||
err=grib_get_long_array(h,self->widthName,self->width,&size);
|
|
||||||
|
|
||||||
self->bitmapNumber=(long*)grib_context_malloc_clear(c,size*sizeof(long));
|
|
||||||
err=grib_get_long_array(h,self->bitmapNumberName,self->bitmapNumber,&size);
|
|
||||||
|
|
||||||
self->associatedBitmapNumber=(long*)grib_context_malloc_clear(c,size*sizeof(long));
|
|
||||||
err=grib_get_long_array(h,self->associatedBitmapNumberName,self->associatedBitmapNumber,&size);
|
|
||||||
|
|
||||||
self->associatedBitmapIndex=(long*)grib_context_malloc_clear(c,size*sizeof(long));
|
|
||||||
err=grib_get_long_array(h,self->associatedBitmapIndexName,self->associatedBitmapIndex,&size);
|
|
||||||
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void push_units_accessor(grib_accessor* a,long groupNumber,long i) {
|
|
||||||
char buf[1024]={0,};
|
|
||||||
grib_accessor_bufr_uncompressed_data *self =(grib_accessor_bufr_uncompressed_data*)a;
|
|
||||||
grib_accessor* gaUnits=0;
|
|
||||||
grib_action creatorUnits = {0, };
|
|
||||||
grib_context* c=a->parent->h->context;
|
|
||||||
|
|
||||||
if (self->units[i][0]=='C' && ( !strcmp(self->units[i],"CCITTIA5") ||
|
|
||||||
!strncmp(self->units[i],"COMMON",6)) )
|
|
||||||
return;
|
|
||||||
|
|
||||||
creatorUnits.op = "variable";
|
|
||||||
creatorUnits.name_space = "";
|
|
||||||
creatorUnits.flags = GRIB_ACCESSOR_FLAG_DUMP;
|
|
||||||
creatorUnits.set = 0;
|
|
||||||
|
|
||||||
sprintf(buf,"%sUnits",self->abbreviation[i]);
|
|
||||||
creatorUnits.name=grib_context_strdup(c,buf);
|
|
||||||
gaUnits = grib_accessor_factory(a->sub_section, &creatorUnits, 0, NULL);
|
|
||||||
gaUnits->bufr_group_number=groupNumber;
|
|
||||||
((grib_accessor_constant*)gaUnits)->type=GRIB_TYPE_STRING;
|
|
||||||
|
|
||||||
if (self->units[i][0]=='C' && !strcmp(self->units[i],"CODETABLE") ) {
|
|
||||||
sprintf(buf,"codetable %ld",self->expandedDescriptors[i]);
|
|
||||||
((grib_accessor_constant*)gaUnits)->cval=grib_context_strdup(c,buf);
|
|
||||||
} else {
|
|
||||||
((grib_accessor_constant*)gaUnits)->cval=grib_context_strdup(c,self->units[i]);
|
|
||||||
}
|
|
||||||
|
|
||||||
grib_push_accessor(gaUnits,a->sub_section->block);
|
|
||||||
}
|
|
||||||
|
|
||||||
#define MAX_NESTED_REPLICATIONS 8
|
|
||||||
|
|
||||||
static int decode_elements(grib_accessor* a) {
|
|
||||||
int err=0;
|
|
||||||
grib_accessor_bufr_uncompressed_data *self =(grib_accessor_bufr_uncompressed_data*)a;
|
|
||||||
unsigned char* data =NULL;
|
|
||||||
long i=0,k=0,jj=0,inr;
|
|
||||||
/* long iloop,irr; */
|
|
||||||
long innr;
|
|
||||||
char buf[1024]={0,};
|
|
||||||
long pos=0;
|
|
||||||
long n[MAX_NESTED_REPLICATIONS]={0,};
|
|
||||||
long nn[MAX_NESTED_REPLICATIONS]={0,};
|
|
||||||
long numberOfElementsToRepeat[MAX_NESTED_REPLICATIONS]={0,};
|
|
||||||
long numberOfRepetitions[MAX_NESTED_REPLICATIONS]={0,};
|
|
||||||
long startRepetition[MAX_NESTED_REPLICATIONS]={0,};
|
|
||||||
long numberOfNestedRepetions=0;
|
|
||||||
long* width;
|
|
||||||
long* reference;
|
|
||||||
long groupNumber;
|
|
||||||
int notSignificanceElement;
|
|
||||||
char* sval;
|
|
||||||
double* factor;
|
|
||||||
double val=0;
|
|
||||||
int *F,*X,*Y;
|
|
||||||
int bitmapIndex[10]={0,};
|
|
||||||
long lval=0;
|
|
||||||
int ir;
|
|
||||||
char prevname[1024]={0,};
|
|
||||||
grib_accessor* prevaccessor=NULL;
|
|
||||||
grib_iarray* index=0;
|
|
||||||
grib_handle* h=a->parent->h;
|
|
||||||
grib_context* c=h->context;
|
|
||||||
|
|
||||||
grib_accessor* gaGroup=0;
|
|
||||||
grib_action creatorGroup = {0, };
|
|
||||||
|
|
||||||
grib_accessor* gaReplications=0;
|
|
||||||
grib_action creatorReplications = {0, };
|
|
||||||
|
|
||||||
grib_accessor* ga=0;
|
|
||||||
grib_action creator = {0, };
|
|
||||||
creator.op = "bufr_element";
|
|
||||||
creator.name_space = "";
|
|
||||||
creator.flags = GRIB_ACCESSOR_FLAG_DUMP;
|
|
||||||
creator.set = 0;
|
|
||||||
|
|
||||||
creatorGroup.op = "variable";
|
|
||||||
creatorGroup.name_space = "";
|
|
||||||
creatorGroup.flags = GRIB_ACCESSOR_FLAG_DUMP;
|
|
||||||
creatorGroup.set = 0;
|
|
||||||
|
|
||||||
creatorReplications.op = "variable";
|
|
||||||
creatorReplications.name_space = "";
|
|
||||||
creatorReplications.flags = GRIB_ACCESSOR_FLAG_DUMP;
|
|
||||||
creatorReplications.set = 0;
|
|
||||||
|
|
||||||
data = (unsigned char*)h->buffer->data;
|
|
||||||
pos=a->offset*8;
|
|
||||||
|
|
||||||
err=get_descriptors(a);
|
|
||||||
if (err) return err;
|
|
||||||
|
|
||||||
width=self->width;
|
|
||||||
factor=self->factor;
|
|
||||||
reference=self->reference;
|
|
||||||
|
|
||||||
grib_get_long(h,self->numberOfDataSubsetsName,&(self->numberOfDataSubsets));
|
|
||||||
|
|
||||||
/* TODO: implement multiple subsets*/
|
|
||||||
Assert(self->numberOfDataSubsets==1);
|
|
||||||
|
|
||||||
F=(int*)grib_context_malloc_clear(c,sizeof(int)*self->numberOfDescriptors);
|
|
||||||
X=(int*)grib_context_malloc_clear(c,sizeof(int)*self->numberOfDescriptors);
|
|
||||||
Y=(int*)grib_context_malloc_clear(c,sizeof(int)*self->numberOfDescriptors);
|
|
||||||
for (i=0;i<self->numberOfDescriptors;i++) {
|
|
||||||
F[i]=self->expandedDescriptors[i]/100000;
|
|
||||||
X[i]=(self->expandedDescriptors[i]-F[i]*100000)/1000;
|
|
||||||
Y[i]=(self->expandedDescriptors[i]-F[i]*100000)%1000;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!self->dvalues)
|
|
||||||
self->dvalues=grib_darray_new(c,self->numberOfDescriptors,100);
|
|
||||||
if (!self->svalues)
|
|
||||||
self->svalues=grib_sarray_new(c,self->numberOfDescriptors,100);
|
|
||||||
|
|
||||||
index=grib_iarray_new(c,self->numberOfDescriptors,100);
|
|
||||||
|
|
||||||
self->dvalues->n=0;
|
|
||||||
self->svalues->n=0;
|
|
||||||
self->numberOfElements=0;
|
|
||||||
k=0;
|
|
||||||
groupNumber=1;
|
|
||||||
|
|
||||||
sprintf(buf,"groupNumber");
|
|
||||||
notSignificanceElement=0;
|
|
||||||
creatorGroup.name=grib_context_strdup(c,buf);
|
|
||||||
gaGroup = grib_accessor_factory(a->sub_section, &creatorGroup, 0, NULL);
|
|
||||||
gaGroup->bufr_group_number=groupNumber;
|
|
||||||
((grib_accessor_constant*)gaGroup)->type=GRIB_TYPE_LONG;
|
|
||||||
((grib_accessor_constant*)gaGroup)->dval=groupNumber;
|
|
||||||
grib_push_accessor(gaGroup,a->sub_section->block);
|
|
||||||
|
|
||||||
for (i=0;i<self->numberOfDescriptors;i++) {
|
|
||||||
if (F[i]==0 && X[i]==8 && notSignificanceElement) {
|
|
||||||
groupNumber++;
|
|
||||||
sprintf(buf,"groupNumber");
|
|
||||||
creatorGroup.name=grib_context_strdup(c,buf);
|
|
||||||
gaGroup = grib_accessor_factory(a->sub_section, &creatorGroup, 0, NULL);
|
|
||||||
gaGroup->bufr_group_number=groupNumber;
|
|
||||||
((grib_accessor_constant*)gaGroup)->type=GRIB_TYPE_LONG;
|
|
||||||
((grib_accessor_constant*)gaGroup)->dval=groupNumber;
|
|
||||||
grib_push_accessor(gaGroup,a->sub_section->block);
|
|
||||||
notSignificanceElement=0;
|
|
||||||
} else {
|
|
||||||
notSignificanceElement=1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (F[i]==1) {
|
|
||||||
/* delayed replication */
|
|
||||||
inr=numberOfNestedRepetions;
|
|
||||||
numberOfNestedRepetions++;
|
|
||||||
numberOfElementsToRepeat[inr]=X[i];
|
|
||||||
n[inr]=numberOfElementsToRepeat[inr];
|
|
||||||
i++;
|
|
||||||
lval=grib_decode_unsigned_long(data,&pos,width[i]);
|
|
||||||
numberOfRepetitions[inr]=(reference[i]+lval)*factor[i];
|
|
||||||
nn[inr]=numberOfRepetitions[inr];
|
|
||||||
sprintf(buf,"numberOfReplications");
|
|
||||||
creatorReplications.name=grib_context_strdup(c,buf);
|
|
||||||
gaReplications = grib_accessor_factory(a->sub_section, &creatorReplications, 0, NULL);
|
|
||||||
gaReplications->bufr_group_number=groupNumber;
|
|
||||||
((grib_accessor_constant*)gaReplications)->type=GRIB_TYPE_LONG;
|
|
||||||
((grib_accessor_constant*)gaReplications)->dval=numberOfRepetitions[inr];
|
|
||||||
grib_push_accessor(gaReplications,a->sub_section->block);
|
|
||||||
startRepetition[inr]=i;
|
|
||||||
Assert(numberOfNestedRepetions<=MAX_NESTED_REPLICATIONS);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (self->bitmapNumber[i]) {
|
|
||||||
/* bitmap extraction */
|
|
||||||
lval=grib_decode_unsigned_long(data,&pos,1);
|
|
||||||
if(!bitmapIndex[self->bitmapNumber[i]])
|
|
||||||
bitmapIndex[self->bitmapNumber[i]]=self->dvalues->n;
|
|
||||||
grib_iarray_push(index,i);
|
|
||||||
grib_darray_push(c,self->dvalues,(double)lval) ;
|
|
||||||
k=0;
|
|
||||||
jj=0;
|
|
||||||
} else if (self->associatedBitmapNumber[i]) {
|
|
||||||
/* bitmap application */
|
|
||||||
char name[1024]={0,};
|
|
||||||
if (!k) k=bitmapIndex[self->associatedBitmapNumber[i]];
|
|
||||||
else k++;
|
|
||||||
|
|
||||||
sprintf(name,"%sOf-%s",self->abbreviation[i],self->abbreviation[index->v[jj]]);
|
|
||||||
jj++;
|
|
||||||
creator.name = grib_context_strdup(c,name);
|
|
||||||
ga = grib_accessor_factory(a->sub_section, &creator, 0, NULL);
|
|
||||||
ga->bufr_group_number=groupNumber;
|
|
||||||
((grib_accessor_bufr_element*)ga)->data_accessor=a;
|
|
||||||
((grib_accessor_bufr_element*)ga)->index=self->dvalues->n;
|
|
||||||
((grib_accessor_bufr_element*)ga)->ielement=i;
|
|
||||||
((grib_accessor_bufr_element*)ga)->type=GRIB_TYPE_DOUBLE;
|
|
||||||
grib_iarray_push(index,i);
|
|
||||||
if (self->dvalues->v[k]==0) {
|
|
||||||
lval=grib_decode_unsigned_long(data,&pos,width[i]);
|
|
||||||
val=(reference[i]+lval)*factor[i];
|
|
||||||
grib_darray_push(c,self->dvalues,val);
|
|
||||||
grib_push_accessor(ga,a->sub_section->block);
|
|
||||||
} else {
|
|
||||||
val=GRIB_MISSING_DOUBLE;
|
|
||||||
i--;
|
|
||||||
grib_darray_push(c,self->dvalues,val);
|
|
||||||
grib_push_accessor(ga,a->sub_section->block);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
/* printf("++++++> %d %d %s=%g\n",i,jj,self->abbreviation[index->v[jj]],val); */
|
|
||||||
} else {
|
|
||||||
/* element decoding and accessor creation */
|
|
||||||
int gaindex,isnew;
|
|
||||||
if (!strcmp(prevname,self->abbreviation[i])) {
|
|
||||||
isnew=0;
|
|
||||||
ga=prevaccessor;
|
|
||||||
} else {
|
|
||||||
isnew=1;
|
|
||||||
sprintf(prevname,"%s",self->abbreviation[i]);
|
|
||||||
creator.name = self->abbreviation[i];
|
|
||||||
ga = grib_accessor_factory(a->sub_section, &creator, 0, NULL);
|
|
||||||
ga->bufr_group_number=groupNumber;
|
|
||||||
prevaccessor=ga;
|
|
||||||
((grib_accessor_bufr_element*)ga)->data_accessor=a;
|
|
||||||
push_units_accessor(a,groupNumber,i);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
if ( *(self->type[i])=='s') {
|
|
||||||
/* string element */
|
|
||||||
size_t widthInBytes=width[i]/8;
|
|
||||||
sval=(char*)grib_context_malloc_clear(c,widthInBytes+1);
|
|
||||||
sval=grib_decode_string(data,&pos,widthInBytes,sval);
|
|
||||||
gaindex=self->svalues->n;
|
|
||||||
((grib_accessor_bufr_element*)ga)->ielement=i;
|
|
||||||
((grib_accessor_bufr_element*)ga)->type=GRIB_TYPE_STRING;
|
|
||||||
grib_sarray_push(c,self->svalues,sval);
|
|
||||||
} else {
|
|
||||||
/* number element */
|
|
||||||
lval=grib_decode_unsigned_long(data,&pos,width[i]);
|
|
||||||
if (!grib_is_all_bits_one(lval,width[i])) {
|
|
||||||
val=(reference[i]+lval)*factor[i];
|
|
||||||
} else {
|
|
||||||
val=GRIB_MISSING_DOUBLE;
|
|
||||||
}
|
|
||||||
gaindex=self->dvalues->n;
|
|
||||||
((grib_accessor_bufr_element*)ga)->ielement=i;
|
|
||||||
grib_iarray_push(index,i);
|
|
||||||
grib_darray_push(c,self->dvalues,val);
|
|
||||||
((grib_accessor_bufr_element*)ga)->type=GRIB_TYPE_DOUBLE;
|
|
||||||
if ( *(self->type[i])=='l')
|
|
||||||
((grib_accessor_bufr_element*)ga)->type=GRIB_TYPE_LONG;
|
|
||||||
}
|
|
||||||
if (isnew) {
|
|
||||||
((grib_accessor_bufr_element*)ga)->index=gaindex;
|
|
||||||
((grib_accessor_bufr_element*)ga)->size=1;
|
|
||||||
grib_push_accessor(ga,a->sub_section->block);
|
|
||||||
} else {
|
|
||||||
((grib_accessor_bufr_element*)ga)->size++;
|
|
||||||
}
|
|
||||||
|
|
||||||
k=0;
|
|
||||||
jj=0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* delayed repetition check */
|
|
||||||
innr=numberOfNestedRepetions-1;
|
|
||||||
for (ir=innr;ir>=0;ir--) {
|
|
||||||
if (nn[ir]) {
|
|
||||||
if (n[ir]>1) {
|
|
||||||
n[ir]--;
|
|
||||||
break;
|
|
||||||
} else {
|
|
||||||
n[ir]=numberOfElementsToRepeat[ir];
|
|
||||||
nn[ir]--;
|
|
||||||
if (nn[ir]) {
|
|
||||||
i=startRepetition[ir];
|
|
||||||
break;
|
|
||||||
} else {
|
|
||||||
if (ir>0) {
|
|
||||||
n[ir-1]-=numberOfElementsToRepeat[ir]+1;
|
|
||||||
i=startRepetition[ir-1];
|
|
||||||
} else {
|
|
||||||
i=startRepetition[ir]+numberOfElementsToRepeat[ir];
|
|
||||||
}
|
|
||||||
numberOfNestedRepetions--;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
if (ir==0) {
|
|
||||||
i=startRepetition[ir]+numberOfElementsToRepeat[ir]+1;
|
|
||||||
numberOfNestedRepetions=0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* for (i=0;i<self->dvalues->n;i++) printf("%ld %g\n",i,self->dvalues->v[i]); */
|
|
||||||
|
|
||||||
grib_context_free(c,F);
|
|
||||||
grib_context_free(c,X);
|
|
||||||
grib_context_free(c,Y);
|
|
||||||
grib_iarray_delete(index);
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void dump(grib_accessor* a, grib_dumper* dumper)
|
|
||||||
{
|
|
||||||
grib_accessor_bufr_uncompressed_data *self =(grib_accessor_bufr_uncompressed_data*)a;
|
|
||||||
if (self->do_compute) {
|
|
||||||
decode_elements(a);
|
|
||||||
self->do_compute=0;
|
|
||||||
a->parent->h->unpacked=1;
|
|
||||||
}
|
|
||||||
grib_dump_section(dumper,a,a->sub_section->block);
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int unpack_double(grib_accessor* a, double* val, size_t *len) {
|
|
||||||
grib_accessor_bufr_uncompressed_data *self =(grib_accessor_bufr_uncompressed_data*)a;
|
|
||||||
int err=0;
|
|
||||||
|
|
||||||
if (self->do_compute) {
|
|
||||||
err=decode_elements(a);
|
|
||||||
self->do_compute=0;
|
|
||||||
a->parent->h->unpacked=1;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!val) return GRIB_SUCCESS;
|
|
||||||
else return GRIB_NOT_IMPLEMENTED;
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
if (*len < n)
|
|
||||||
return GRIB_ARRAY_TOO_SMALL;
|
|
||||||
|
|
||||||
|
|
||||||
if (self->values) {
|
|
||||||
grib_get_long(h,self->subsetNumberName,&subsetNumber);
|
|
||||||
if (subsetNumber>0) {
|
|
||||||
/* return only this subset */
|
|
||||||
for (i=0;i<self->numberOfElements;i++)
|
|
||||||
val[i]=self->values[numberOfDataSubsets*i+subsetNumber-1];
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
for (i=0;i<n;i++) val[i]=self->dvalues->v[i];
|
|
||||||
|
|
||||||
return err;
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
|
|
||||||
static int value_count(grib_accessor* a,long* count)
|
|
||||||
{
|
|
||||||
int err=0;
|
|
||||||
grib_accessor_bufr_uncompressed_data *self =(grib_accessor_bufr_uncompressed_data*)a;
|
|
||||||
grib_handle* h=a->parent->h;
|
|
||||||
|
|
||||||
err=get_descriptors(a);
|
|
||||||
if (err) return err;
|
|
||||||
|
|
||||||
err=grib_get_long(h,self->numberOfDataSubsetsName,&(self->numberOfDataSubsets));
|
|
||||||
if (err) return err;
|
|
||||||
|
|
||||||
/* TODO: implement multiple subsets*/
|
|
||||||
Assert(self->numberOfDataSubsets==1);
|
|
||||||
|
|
||||||
*count=self->numberOfElements;
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
static grib_accessor* next(grib_accessor* a,int explore) {
|
|
||||||
grib_accessor* next=NULL;
|
|
||||||
if (explore) {
|
|
||||||
next=a->sub_section->block->first;
|
|
||||||
if (!next) next=a->next;
|
|
||||||
} else {
|
|
||||||
next=a->next;
|
|
||||||
}
|
|
||||||
if (!next) {
|
|
||||||
if (a->parent->owner)
|
|
||||||
next=a->parent->owner->cclass->next(a->parent->owner,0);
|
|
||||||
}
|
|
||||||
return next;
|
|
||||||
}
|
|
||||||
|
|
|
@ -15,13 +15,9 @@
|
||||||
{ "bufr_data", &grib_accessor_class_bufr_data, },
|
{ "bufr_data", &grib_accessor_class_bufr_data, },
|
||||||
{ "bufr_data_array", &grib_accessor_class_bufr_data_array, },
|
{ "bufr_data_array", &grib_accessor_class_bufr_data_array, },
|
||||||
{ "bufr_data_element", &grib_accessor_class_bufr_data_element, },
|
{ "bufr_data_element", &grib_accessor_class_bufr_data_element, },
|
||||||
{ "bufr_element", &grib_accessor_class_bufr_element, },
|
|
||||||
{ "bufr_elements_table", &grib_accessor_class_bufr_elements_table, },
|
{ "bufr_elements_table", &grib_accessor_class_bufr_elements_table, },
|
||||||
{ "bufr_group", &grib_accessor_class_bufr_group, },
|
{ "bufr_group", &grib_accessor_class_bufr_group, },
|
||||||
{ "bufr_group_number", &grib_accessor_class_bufr_group_number, },
|
|
||||||
{ "bufr_has_delayed_replication", &grib_accessor_class_bufr_has_delayed_replication, },
|
{ "bufr_has_delayed_replication", &grib_accessor_class_bufr_has_delayed_replication, },
|
||||||
{ "bufr_subset_number", &grib_accessor_class_bufr_subset_number, },
|
|
||||||
{ "bufr_uncompressed_data", &grib_accessor_class_bufr_uncompressed_data, },
|
|
||||||
{ "bufrdc_expanded_descriptors", &grib_accessor_class_bufrdc_expanded_descriptors, },
|
{ "bufrdc_expanded_descriptors", &grib_accessor_class_bufrdc_expanded_descriptors, },
|
||||||
{ "bytes", &grib_accessor_class_bytes, },
|
{ "bytes", &grib_accessor_class_bytes, },
|
||||||
{ "change_scanning_direction", &grib_accessor_class_change_scanning_direction, },
|
{ "change_scanning_direction", &grib_accessor_class_change_scanning_direction, },
|
||||||
|
|
|
@ -265,29 +265,21 @@ void accessor_bufr_data_element_set_numericValues(grib_accessor *a, grib_vdarray
|
||||||
void accessor_bufr_data_element_set_stringValues(grib_accessor *a, grib_vsarray *stringValues);
|
void accessor_bufr_data_element_set_stringValues(grib_accessor *a, grib_vsarray *stringValues);
|
||||||
void accessor_bufr_data_element_set_elementsDescriptorsIndex(grib_accessor *a, grib_viarray *elementsDescriptorsIndex);
|
void accessor_bufr_data_element_set_elementsDescriptorsIndex(grib_accessor *a, grib_viarray *elementsDescriptorsIndex);
|
||||||
|
|
||||||
/* grib_accessor_class_bufr_group.c */
|
|
||||||
|
|
||||||
/* grib_accessor_class_unpack_bufr_values.c */
|
|
||||||
|
|
||||||
/* grib_accessor_class_bufr_uncompressed_data.c */
|
|
||||||
|
|
||||||
/* grib_accessor_class_bufr_element.c */
|
|
||||||
|
|
||||||
/* grib_accessor_class_bufr_elements_table.c */
|
/* grib_accessor_class_bufr_elements_table.c */
|
||||||
char **str_split(char *a_str, const char a_delim);
|
char **str_split(char *a_str, const char a_delim);
|
||||||
bufr_descriptor *accessor_bufr_elements_table_get_descriptor(grib_accessor *a, int code, int *err);
|
bufr_descriptor *accessor_bufr_elements_table_get_descriptor(grib_accessor *a, int code, int *err);
|
||||||
|
|
||||||
|
/* grib_accessor_class_bufr_group.c */
|
||||||
|
|
||||||
|
/* grib_accessor_class_group.c */
|
||||||
|
|
||||||
|
/* grib_accessor_class_unpack_bufr_values.c */
|
||||||
|
|
||||||
/* grib_accessor_class_bufr_has_delayed_replication.c */
|
/* grib_accessor_class_bufr_has_delayed_replication.c */
|
||||||
|
|
||||||
/* grib_accessor_class_bufr_subset_number.c */
|
|
||||||
|
|
||||||
/* grib_accessor_class_bufr_group_number.c */
|
|
||||||
|
|
||||||
/* grib_accessor_class_apply_operators.c */
|
/* grib_accessor_class_apply_operators.c */
|
||||||
size_t compute_size_AO(long *descriptors, size_t numberOfDescriptors);
|
size_t compute_size_AO(long *descriptors, size_t numberOfDescriptors);
|
||||||
|
|
||||||
/* grib_accessor_class_group.c */
|
|
||||||
|
|
||||||
/* grib_accessor_class_non_alpha.c */
|
/* grib_accessor_class_non_alpha.c */
|
||||||
|
|
||||||
/* grib_accessor_class_g1bitmap.c */
|
/* grib_accessor_class_g1bitmap.c */
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
|
|
||||||
grib_option grib_options[]={
|
grib_option grib_options[]={
|
||||||
/* {id, args, help}, on, command_line, value*/
|
/* {id, args, help}, on, command_line, value*/
|
||||||
{"j",0,0,0,1,0},
|
{"j",0,0,1,1,0},
|
||||||
{"S",0,0,1,0,0},
|
{"S",0,0,1,0,0},
|
||||||
{"O",0,"Octet mode. WMO documentation style dump.\n",0,1,0},
|
{"O",0,"Octet mode. WMO documentation style dump.\n",0,1,0},
|
||||||
{"D",0,0,0,1,0},
|
{"D",0,0,0,1,0},
|
||||||
|
|
Loading…
Reference in New Issue