[svn-r876] Changes since 19981102
----------------------
./bin/snapshot
Made same fix as for the release script yesterday.
./src/H5D.c
./src/H5Dprivate.h
./src/H5G.c
./src/H5Gprivate.h
./src/H5Gpublic.h
./src/H5O.c
./src/H5Oprivate.h
./src/H5RA.c
./src/H5RAprivate.h
./src/H5T.c
./src/H5Tprivate.h
Improved object type checking. Instead of determining the
object type by trying to open each of the possible types, we
keep a table of associations between object type number (like
H5G_GROUP, H5G_DATASET, H5D_TYPE, and H5D_RAGGED) and an `isa'
function that returns true if the object header has the right
messages to make the object a particular type. This mechanism
also allows specialization of object types by permitting an
object to satisfy more than one `isa' function.
Added `isa' functions for groups, datasets, ragged arrays, and
committed data types.
./src/H5config.h.in
Added HAVE_STAT_ST_BLOCKS. I thought this had already been
added, but apparently not.
./tools/h5ls.c
Removed system include files since they're already included by
H5private.h and since I wasn't including them portably anyway.
By default, 1-byte integer types are printed as integer values
instead of ASCII characters. However, the `-s' or `--string'
command-line switch causes the data to be interpretted as
ASCII. String data types are always printed as character
data.
Ragged arrays are now identified as ragged arrays and h5ls
doesn't descend into the group automatically. This uses the
new object type specialization stuff.
./tools/h5tools.c
./tools/h5tools.h
Added the ability to print 1-byte integer types as either
ASCII or numeric data instead of always ASCII. The default is
to print as numeric data.
1998-11-06 04:28:34 +08:00
|
|
|
dnl Process this file with autoconf to produce configure.
|
1997-08-16 00:35:53 +08:00
|
|
|
dnl
|
|
|
|
dnl Copyright (C) 1997 National Center for Supercomputing Applications.
|
|
|
|
dnl All rights reserved.
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl Initialize configure.
|
|
|
|
dnl
|
|
|
|
AC_REVISION($Id$)
|
|
|
|
AC_INIT(src/H5.c)
|
|
|
|
AC_CONFIG_HEADER(src/H5config.h)
|
|
|
|
AC_CONFIG_AUX_DIR(bin)
|
|
|
|
AC_CANONICAL_HOST
|
1998-02-20 02:19:48 +08:00
|
|
|
AC_SUBST(CPPFLAGS)
|
1997-08-16 00:35:53 +08:00
|
|
|
|
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl Check that the cache file was build on the same host as what we're
|
|
|
|
dnl running on now.
|
|
|
|
dnl
|
|
|
|
AC_CACHE_CHECK(for cached host,hdf5_cv_host,hdf5_cv_host="none");
|
|
|
|
if test $hdf5_cv_host = "none"; then
|
|
|
|
hdf5_cv_host=$host
|
|
|
|
elif test $hdf5_cv_host != $host; then
|
|
|
|
echo "The config.cache file was generated on $hdf5_cv_host but"
|
|
|
|
echo "this is $host. Please remove that file and try again."
|
|
|
|
AC_MSG_ERROR(config.cache file is invalid)
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl Source any special files that we need. These files normally aren't
|
|
|
|
dnl present but can be used by the maintainers to fine tune things like
|
1998-02-14 02:11:35 +08:00
|
|
|
dnl turning on debug or profiling flags for the compiler. The search order
|
|
|
|
dnl is:
|
|
|
|
dnl
|
|
|
|
dnl CPU-VENDOR-OS
|
|
|
|
dnl VENDOR-OS
|
|
|
|
dnl CPU-OS
|
|
|
|
dnl CPU-VENDOR
|
|
|
|
dnl OS
|
|
|
|
dnl VENDOR
|
|
|
|
dnl CPU
|
1997-08-16 00:35:53 +08:00
|
|
|
dnl
|
1998-07-09 02:41:04 +08:00
|
|
|
AC_MSG_CHECKING(for host config file)
|
|
|
|
host_config="none"
|
1998-02-14 02:11:35 +08:00
|
|
|
for f in $host \
|
|
|
|
$host_vendor-$host_os \
|
|
|
|
$host_cpu-$host_os \
|
|
|
|
$host_cpu-$host_vendor \
|
|
|
|
$host_os \
|
|
|
|
$host_vendor \
|
|
|
|
$host_cpu ; do
|
1997-08-16 00:35:53 +08:00
|
|
|
if test -f config/$f; then
|
1998-07-09 02:41:04 +08:00
|
|
|
host_config=config/$f
|
1997-08-16 00:35:53 +08:00
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
1998-07-09 02:41:04 +08:00
|
|
|
AC_MSG_RESULT($host_config)
|
|
|
|
if test $host_config != "none"; then
|
|
|
|
. $host_config
|
1997-08-16 00:35:53 +08:00
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl Check for programs.
|
|
|
|
dnl
|
|
|
|
AC_PROG_CC
|
|
|
|
AC_PROG_MAKE_SET
|
|
|
|
AC_PROG_INSTALL
|
|
|
|
AC_PROG_RANLIB
|
|
|
|
|
1998-03-06 13:34:36 +08:00
|
|
|
if test "X$AR" = "X"; then
|
|
|
|
AC_CHECK_PROGS(AR,ar xar,:,$PATH)
|
|
|
|
fi
|
|
|
|
AC_SUBST(AR)
|
|
|
|
|
1997-08-16 00:35:53 +08:00
|
|
|
AC_MSG_CHECKING(for GNU Make)
|
|
|
|
if test "`${MAKE-make} --version -f /dev/null 2>/dev/null |\
|
|
|
|
sed -n 1p|cut -c1-8`" = "GNU Make"; then
|
|
|
|
AC_MSG_RESULT(yes)
|
|
|
|
GMAKE=yes
|
|
|
|
else
|
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
fi
|
|
|
|
|
1998-04-07 23:34:16 +08:00
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl Turn on warning flags for gcc.
|
|
|
|
dnl
|
|
|
|
if test Xyes = "X$GCC"; then
|
1998-04-09 05:43:02 +08:00
|
|
|
CFLAGS="$CFLAGS -Wall -W -Wshadow -Wpointer-arith -Wbad-function-cast -Wcast-qual -Wcast-align -Wwrite-strings -Wstrict-prototypes -Wmissing-prototypes -Wmissing-declarations -Wnested-externs -Winline"
|
1998-04-07 23:34:16 +08:00
|
|
|
fi
|
|
|
|
|
1998-04-03 11:29:38 +08:00
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl Production flags?
|
|
|
|
dnl
|
|
|
|
AC_MSG_CHECKING(for production mode)
|
|
|
|
AC_ARG_ENABLE(production,
|
|
|
|
[--enable-production=yes|no Determines how to run the compiler.])
|
|
|
|
|
|
|
|
case "X-$enableval" in
|
|
|
|
X-yes)
|
|
|
|
AC_MSG_RESULT("production")
|
|
|
|
CFLAGS="$CFLAGS $PROD_CFLAGS"
|
|
|
|
CPPFLAGS="$CPPFLAGS $PROD_CPPFLAGS"
|
|
|
|
;;
|
|
|
|
X-|X-no)
|
|
|
|
AC_MSG_RESULT("development")
|
|
|
|
CFLAGS="$CFLAGS $DEBUG_CFLAGS"
|
|
|
|
CPPFLAGS="$CPPFLAGS $DEBUG_CPPFLAGS"
|
|
|
|
;;
|
|
|
|
X-pg|X-profile)
|
|
|
|
AC_MSG_RESULT("profile")
|
|
|
|
CFLAGS="$CFLAGS $PROFILE_CFLAGS"
|
|
|
|
CPPFLAGS="$CPPFLAGS $PROFILE_CPPFLAGS"
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
AC_MSG_RESULT("user-defined")
|
|
|
|
;;
|
|
|
|
esac
|
1997-08-16 00:35:53 +08:00
|
|
|
|
|
|
|
|
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl Check for libraries. (none required yet)
|
|
|
|
dnl
|
1998-06-13 01:31:06 +08:00
|
|
|
AC_CHECK_LIB(m, ceil)
|
1998-03-06 13:34:36 +08:00
|
|
|
AC_CHECK_LIB(coug, main) dnl ...for ASCI/Red
|
1998-04-18 05:29:43 +08:00
|
|
|
AC_CHECK_LIB(z, compress2)
|
1997-08-16 00:35:53 +08:00
|
|
|
|
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl Check for header files.
|
|
|
|
dnl
|
|
|
|
AC_HEADER_STDC
|
1998-11-03 01:58:28 +08:00
|
|
|
AC_HEADER_TIME
|
|
|
|
AC_CHECK_HEADERS(io.h sys/resource.h sys/time.h unistd.h winsock.h zlib.h)
|
1997-08-16 00:35:53 +08:00
|
|
|
|
|
|
|
|
|
|
|
dnl ----------------------------------------------------------------------
|
[svn-r339] Changes since 19980408
----------------------
./src/H5Osdspace.c
./html/H5.format.html
In the past we were allowed to have >2GB files on a 32-bit
machine as long as no dataset within the file was larger than
4GB (or whatever sizeof(size_t) is). That's been fixed now.
All dataset size calculations are done with `hsize_t' which is
normally defined as `unsigned long long'.
./src/H5F.c
./src/H5Ffamily.c
./src/H5Fprivate.h
./src/H5P.c
./src/H5Ppublic.h
The file family member size can now be set/queried. The
default is still 64MB, but it can be set to 1GB by saying:
H5Pset_family (plist, 30, H5P_DEFAULT);
When opening an existing file family the specified
bits-per-member is ignored and the first member of the family
determines the bits-per-member, which can be retrieved with
H5Pget_family().
./acconfig.h
./configure.in
./src/H5config.h
./src/H5public.h
Added `--disable-hsizet' so that those with old GCC compilers
(<2.8.1) can still compile the code.
./src/H5.c
./src/H5private.h
Added HDfprintf() which works just like fprintf() except you
can give `H' as a size modifier for the integer conversions
and supply an `hsize_t' or `hssize_t' argument without casting
it. For instance:
hsize_t npoints = H5Sget_npoints(space);
HDfprintf(stdout,"Dataset has %Hd (%#018Hx) points\n",
npoints, npoints);
You can now give `%a' as a format to print an address, but all
formating flags are ignored and it causes the return value of
HDfprintf() to not include the characters in the address (but
who uses the return value anyway :-). Example:
H5G_t *grp;
HDfprintf(stdout, "Group object header at %a\n",
&(grp->ent.header));
Added HDstrtoll() which works exactly like [HD]strtol() except
the result is an int64.
./src/debug.c
Large addresses can now be entered from the command-line. Use
either decimal, octal (leading `0') or hexadecimal (leading
`0x') when giving the address.
./src/h5ls.c
The printf format for dataset dimensions was changed to `%Hu'
to support large datasets.
./test/big.c [NEW]
A test for big datasets on 32-bit machines. This test is not
run by default. Don't try to run it on an nfs-mounted file
system or other file system that doesn't support holes because
it creates two 32GB datasets of all zero.
1998-04-10 04:22:11 +08:00
|
|
|
dnl Data types and their sizes.
|
1997-08-16 00:35:53 +08:00
|
|
|
dnl
|
|
|
|
AC_TYPE_OFF_T
|
|
|
|
AC_TYPE_SIZE_T
|
|
|
|
AC_C_BIGENDIAN
|
|
|
|
AC_CHECK_SIZEOF(short, 2)
|
|
|
|
AC_CHECK_SIZEOF(int, 4)
|
|
|
|
AC_CHECK_SIZEOF(long, 4)
|
|
|
|
AC_CHECK_SIZEOF(long long, 8)
|
1998-11-03 01:58:28 +08:00
|
|
|
AC_CHECK_SIZEOF(__int64, 8)
|
1997-08-16 00:35:53 +08:00
|
|
|
AC_CHECK_SIZEOF(float, 4)
|
|
|
|
AC_CHECK_SIZEOF(double, 8)
|
1998-06-17 03:38:26 +08:00
|
|
|
AC_CHECK_SIZEOF(long double, 8)
|
1998-03-06 05:27:38 +08:00
|
|
|
AC_CHECK_SIZEOF(size_t, 4)
|
|
|
|
cat >>confdefs.h <<\EOF
|
|
|
|
#include <sys/types.h> /*for off_t definition*/
|
|
|
|
EOF
|
|
|
|
AC_CHECK_SIZEOF(off_t, 4)
|
1997-08-16 00:35:53 +08:00
|
|
|
|
[svn-r339] Changes since 19980408
----------------------
./src/H5Osdspace.c
./html/H5.format.html
In the past we were allowed to have >2GB files on a 32-bit
machine as long as no dataset within the file was larger than
4GB (or whatever sizeof(size_t) is). That's been fixed now.
All dataset size calculations are done with `hsize_t' which is
normally defined as `unsigned long long'.
./src/H5F.c
./src/H5Ffamily.c
./src/H5Fprivate.h
./src/H5P.c
./src/H5Ppublic.h
The file family member size can now be set/queried. The
default is still 64MB, but it can be set to 1GB by saying:
H5Pset_family (plist, 30, H5P_DEFAULT);
When opening an existing file family the specified
bits-per-member is ignored and the first member of the family
determines the bits-per-member, which can be retrieved with
H5Pget_family().
./acconfig.h
./configure.in
./src/H5config.h
./src/H5public.h
Added `--disable-hsizet' so that those with old GCC compilers
(<2.8.1) can still compile the code.
./src/H5.c
./src/H5private.h
Added HDfprintf() which works just like fprintf() except you
can give `H' as a size modifier for the integer conversions
and supply an `hsize_t' or `hssize_t' argument without casting
it. For instance:
hsize_t npoints = H5Sget_npoints(space);
HDfprintf(stdout,"Dataset has %Hd (%#018Hx) points\n",
npoints, npoints);
You can now give `%a' as a format to print an address, but all
formating flags are ignored and it causes the return value of
HDfprintf() to not include the characters in the address (but
who uses the return value anyway :-). Example:
H5G_t *grp;
HDfprintf(stdout, "Group object header at %a\n",
&(grp->ent.header));
Added HDstrtoll() which works exactly like [HD]strtol() except
the result is an int64.
./src/debug.c
Large addresses can now be entered from the command-line. Use
either decimal, octal (leading `0') or hexadecimal (leading
`0x') when giving the address.
./src/h5ls.c
The printf format for dataset dimensions was changed to `%Hu'
to support large datasets.
./test/big.c [NEW]
A test for big datasets on 32-bit machines. This test is not
run by default. Don't try to run it on an nfs-mounted file
system or other file system that doesn't support holes because
it creates two 32GB datasets of all zero.
1998-04-10 04:22:11 +08:00
|
|
|
AC_ARG_ENABLE(hsizet,
|
|
|
|
[--disable-hsizet Datasets can normally be larger than memory
|
|
|
|
and/or files but some compilers are unable to
|
|
|
|
handle this (including versions of GCC before
|
|
|
|
2.8.0). Disabling the feature causes dataset
|
|
|
|
sizes to be restricted to the size of core memory,
|
|
|
|
or 'size_t'.],
|
|
|
|
HSIZET=$enableval)
|
|
|
|
AC_MSG_CHECKING(for sizeof hsize_t and hssize_t)
|
|
|
|
case $HSIZET in
|
|
|
|
no|small)
|
|
|
|
AC_MSG_RESULT(small)
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
AC_MSG_RESULT(large)
|
|
|
|
AC_DEFINE(HAVE_LARGE_HSIZET)
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
1998-07-30 00:43:59 +08:00
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl How does one figure out the local time zone? Anyone know of a
|
|
|
|
dnl Posix way to do this?
|
|
|
|
dnl
|
|
|
|
|
|
|
|
dnl First check if `struct tm' has a `tm_gmtoff' member.
|
|
|
|
AC_MSG_CHECKING(for tm_gmtoff in struct tm)
|
|
|
|
AC_TRY_COMPILE([
|
|
|
|
#include <sys/time.h>
|
|
|
|
#include <time.h>],[struct tm tm; tm.tm_gmtoff=0;],
|
|
|
|
AC_DEFINE(HAVE_TM_GMTOFF)
|
|
|
|
AC_MSG_RESULT(yes),
|
|
|
|
AC_MSG_RESULT(no))
|
|
|
|
|
|
|
|
dnl Check whether the global variable `timezone' is defined.
|
|
|
|
AC_MSG_CHECKING(for global timezone variable)
|
|
|
|
AC_TRY_LINK([
|
|
|
|
#include <sys/time.h>
|
|
|
|
#include <time.h>], [timezone=0;],
|
|
|
|
AC_DEFINE(HAVE_TIMEZONE)
|
|
|
|
AC_MSG_RESULT(yes),
|
|
|
|
AC_MSG_RESULT(no))
|
|
|
|
|
|
|
|
dnl Check whether `struct timezone' is defined.
|
|
|
|
AC_STRUCT_TIMEZONE
|
|
|
|
AC_MSG_CHECKING(for struct timezone)
|
|
|
|
AC_TRY_COMPILE([
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/time.h>
|
|
|
|
#include <time.h>],[struct timezone tz; tz.tz_minuteswest=0;],
|
|
|
|
AC_DEFINE(HAVE_STRUCT_TIMEZONE)
|
|
|
|
AC_MSG_RESULT(yes),
|
|
|
|
AC_MSG_RESULT(no))
|
|
|
|
|
1998-11-03 01:58:28 +08:00
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl Does the struct stat have the st_blocks field? This field is not Posix.
|
|
|
|
dnl
|
|
|
|
AC_MSG_CHECKING(for st_blocks in struct stat)
|
|
|
|
AC_TRY_COMPILE([
|
|
|
|
#include <sys/stat.h>],[struct stat sb; sb.st_blocks=0;],
|
|
|
|
AC_DEFINE(HAVE_STAT_ST_BLOCKS)
|
|
|
|
AC_MSG_RESULT(yes),
|
|
|
|
AC_MSG_RESULT(no))
|
[svn-r339] Changes since 19980408
----------------------
./src/H5Osdspace.c
./html/H5.format.html
In the past we were allowed to have >2GB files on a 32-bit
machine as long as no dataset within the file was larger than
4GB (or whatever sizeof(size_t) is). That's been fixed now.
All dataset size calculations are done with `hsize_t' which is
normally defined as `unsigned long long'.
./src/H5F.c
./src/H5Ffamily.c
./src/H5Fprivate.h
./src/H5P.c
./src/H5Ppublic.h
The file family member size can now be set/queried. The
default is still 64MB, but it can be set to 1GB by saying:
H5Pset_family (plist, 30, H5P_DEFAULT);
When opening an existing file family the specified
bits-per-member is ignored and the first member of the family
determines the bits-per-member, which can be retrieved with
H5Pget_family().
./acconfig.h
./configure.in
./src/H5config.h
./src/H5public.h
Added `--disable-hsizet' so that those with old GCC compilers
(<2.8.1) can still compile the code.
./src/H5.c
./src/H5private.h
Added HDfprintf() which works just like fprintf() except you
can give `H' as a size modifier for the integer conversions
and supply an `hsize_t' or `hssize_t' argument without casting
it. For instance:
hsize_t npoints = H5Sget_npoints(space);
HDfprintf(stdout,"Dataset has %Hd (%#018Hx) points\n",
npoints, npoints);
You can now give `%a' as a format to print an address, but all
formating flags are ignored and it causes the return value of
HDfprintf() to not include the characters in the address (but
who uses the return value anyway :-). Example:
H5G_t *grp;
HDfprintf(stdout, "Group object header at %a\n",
&(grp->ent.header));
Added HDstrtoll() which works exactly like [HD]strtol() except
the result is an int64.
./src/debug.c
Large addresses can now be entered from the command-line. Use
either decimal, octal (leading `0') or hexadecimal (leading
`0x') when giving the address.
./src/h5ls.c
The printf format for dataset dimensions was changed to `%Hu'
to support large datasets.
./test/big.c [NEW]
A test for big datasets on 32-bit machines. This test is not
run by default. Don't try to run it on an nfs-mounted file
system or other file system that doesn't support holes because
it creates two 32GB datasets of all zero.
1998-04-10 04:22:11 +08:00
|
|
|
|
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl Check for functions.
|
|
|
|
dnl
|
1998-07-13 23:35:21 +08:00
|
|
|
AC_CHECK_FUNCS(getpwuid gethostname system getrusage fork waitpid)
|
1998-09-08 21:38:29 +08:00
|
|
|
AC_CHECK_FUNCS(gettimeofday BSDgettimeofday difftime sigaction)
|
[svn-r339] Changes since 19980408
----------------------
./src/H5Osdspace.c
./html/H5.format.html
In the past we were allowed to have >2GB files on a 32-bit
machine as long as no dataset within the file was larger than
4GB (or whatever sizeof(size_t) is). That's been fixed now.
All dataset size calculations are done with `hsize_t' which is
normally defined as `unsigned long long'.
./src/H5F.c
./src/H5Ffamily.c
./src/H5Fprivate.h
./src/H5P.c
./src/H5Ppublic.h
The file family member size can now be set/queried. The
default is still 64MB, but it can be set to 1GB by saying:
H5Pset_family (plist, 30, H5P_DEFAULT);
When opening an existing file family the specified
bits-per-member is ignored and the first member of the family
determines the bits-per-member, which can be retrieved with
H5Pget_family().
./acconfig.h
./configure.in
./src/H5config.h
./src/H5public.h
Added `--disable-hsizet' so that those with old GCC compilers
(<2.8.1) can still compile the code.
./src/H5.c
./src/H5private.h
Added HDfprintf() which works just like fprintf() except you
can give `H' as a size modifier for the integer conversions
and supply an `hsize_t' or `hssize_t' argument without casting
it. For instance:
hsize_t npoints = H5Sget_npoints(space);
HDfprintf(stdout,"Dataset has %Hd (%#018Hx) points\n",
npoints, npoints);
You can now give `%a' as a format to print an address, but all
formating flags are ignored and it causes the return value of
HDfprintf() to not include the characters in the address (but
who uses the return value anyway :-). Example:
H5G_t *grp;
HDfprintf(stdout, "Group object header at %a\n",
&(grp->ent.header));
Added HDstrtoll() which works exactly like [HD]strtol() except
the result is an int64.
./src/debug.c
Large addresses can now be entered from the command-line. Use
either decimal, octal (leading `0') or hexadecimal (leading
`0x') when giving the address.
./src/h5ls.c
The printf format for dataset dimensions was changed to `%Hu'
to support large datasets.
./test/big.c [NEW]
A test for big datasets on 32-bit machines. This test is not
run by default. Don't try to run it on an nfs-mounted file
system or other file system that doesn't support holes because
it creates two 32GB datasets of all zero.
1998-04-10 04:22:11 +08:00
|
|
|
|
|
|
|
AC_TRY_COMPILE([#include<sys/types.h>],
|
|
|
|
[off64_t n = 0;],
|
|
|
|
AC_CHECK_FUNCS(lseek64 fseek64),
|
|
|
|
AC_MSG_RESULT([skipping test for lseek64() and fseek64()]))
|
1997-08-16 00:35:53 +08:00
|
|
|
|
|
|
|
|
|
|
|
dnl ----------------------------------------------------------------------
|
1997-10-21 07:14:35 +08:00
|
|
|
dnl Check compiler characteristics
|
|
|
|
dnl
|
|
|
|
|
|
|
|
AC_C_CONST
|
|
|
|
AC_C_INLINE
|
|
|
|
|
|
|
|
AC_MSG_CHECKING(for __attribute__ extension)
|
|
|
|
AC_TRY_COMPILE(,[int __attribute__((unused)) f(void){return 1;}],
|
1997-10-23 06:08:14 +08:00
|
|
|
AC_DEFINE(HAVE_ATTRIBUTE)
|
|
|
|
AC_MSG_RESULT(yes),
|
1997-10-21 07:14:35 +08:00
|
|
|
AC_MSG_RESULT(no))
|
|
|
|
|
|
|
|
AC_MSG_CHECKING(for __FUNCTION__ extension)
|
|
|
|
AC_TRY_COMPILE(,[int f(void){return __FUNCTION__;}],
|
1997-10-23 06:08:14 +08:00
|
|
|
AC_DEFINE(HAVE_FUNCTION)
|
|
|
|
AC_MSG_RESULT(yes),
|
1997-10-21 07:14:35 +08:00
|
|
|
AC_MSG_RESULT(no))
|
1997-08-16 00:35:53 +08:00
|
|
|
|
1998-04-25 05:26:32 +08:00
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl Try to figure out how to print `long long'. Some machines use `%lld'
|
|
|
|
dnl and others use `%qd'. There may be more! The final `l' is a
|
|
|
|
dnl default in case none of the others work.
|
|
|
|
dnl
|
[svn-r429] Changes since 19980616
----------------------
./html/tracing.html NEW
This entire update is to make it possible for the library to
print the name, arguments, and return value of every API call
without requiring any extra work from developers or app
programmers. This file describes how this all works.
./configure.in
Added the `--enable-tracing' switch. If you use it then the
library will include code to print API function names,
argument names and values, and function return values.
However, you must then turn on the tracing by setting the
HDF5_TRACE environment variable to a file descriptor number.
The default is `--disable-tracing' since enabling it causes a
slight increase in library size and a slowdown resulting from
an extra function call for each API function call (I couldn't
even measure the slowdown :-)
./bin/trace NEW
A perl script that synchronizes the H5TRACE() macro calls in
the *.c files with the function return type and formal
argument names and types. If you use GNU make and gcc then
this will be done automatically, otherwise just invoke this
script with the names of one or more .c files. You could do
it by hand to, but encoding argument types is a little tricky
at first.
./config/commence.in
Added the $(TRACE) macro, which defaults to the no-op.
Added -D_POSIX_SOURCE to the compiler command line.
./src/Makefile.in
Override the default for $(TRACE).
./config/depend.in
Automatically calls $(TRACE) to synchronize the H5TRACE()
macros in any source file that changed. As with makefile
dependencies, one way to force synchronization of all files is
to remove the `.depend' file.
./MANIFEST
Added new files.
./src/H5Eprivate.h
Modified HRETURN_ERROR() and HRETURN() for tracing.
./src/H5.c
./src/H5private.h
This is where the real tracing work really happens, in
H5_trace().
./src/H5A.c
./src/H5D.c
./src/H5G.c
./src/H5P.c
./src/H5S.c
./src/H5Z.c
Added H5TRACE() calls to all API functions. You don't really
need these changes if you don't want to merge your stuff
because they can be generated automatically by going to the
hdf5/src directory and saying ../bin/trace *.c
./src/H5T.c
Added H5TRACE() calls. Other stuff below.
./src/H5E.c
./src/H5Epublic.h
Added H5TRACE() calls. Created a type H5E_auto_t for the
`func' argument of H5Eset_auto() and H5Eget_auto() to make
those arguments easier to parse for tracing. It should also
make it clearer for users that don't know how to read
complicated ANSI data types.
./src/H5F.c
Added H5TRACE() calls. Changed a couple `uintn' argument
types in API functions to `unsigned int' since `uintn' part of
the API. Changed a few "can't" and "cant" error messages to
"unable to".
./src/H5Ipublic.h
Removed H5_DIRECTORY from the H5I_group_t enum. It wasn't
used anywhere.
./src/H5Tconv.c
Removed an unused label.
./src/H5Fistore.c
./src/H5Oattr.c
./src/H5Odtype.c
./src/H5T.c
./test/dsets.c
./test/dtypes.c
Fixed a warning about a variable possibly used before it's
initialized. Added __unused__ to turn off some unused
argument warnings that pop up when debugging is turned off and
optimizations are turned on.
1998-06-18 04:46:29 +08:00
|
|
|
AC_MSG_CHECKING(how to print long long)
|
1998-04-25 05:26:32 +08:00
|
|
|
AC_CACHE_VAL(hdf5_cv_printf_ll,
|
|
|
|
for hdf5_cv_printf_ll in ll q l; do
|
|
|
|
AC_TRY_RUN([
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
|
|
|
main() {char *s=malloc(128);
|
|
|
|
long long x = (long long)1048576 * (long long)1048576;
|
|
|
|
sprintf(s,"%${hdf5_cv_printf_ll}d",x);
|
|
|
|
exit (strcmp(s,"1099511627776"));}],
|
|
|
|
break)
|
|
|
|
done)
|
|
|
|
AC_MSG_RESULT($hdf5_cv_printf_ll)
|
|
|
|
AC_DEFINE_UNQUOTED(PRINTF_LL_WIDTH,"$hdf5_cv_printf_ll")
|
|
|
|
|
|
|
|
|
1998-04-03 11:29:38 +08:00
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl Turn on debugging by setting compiler flags
|
|
|
|
dnl
|
[svn-r429] Changes since 19980616
----------------------
./html/tracing.html NEW
This entire update is to make it possible for the library to
print the name, arguments, and return value of every API call
without requiring any extra work from developers or app
programmers. This file describes how this all works.
./configure.in
Added the `--enable-tracing' switch. If you use it then the
library will include code to print API function names,
argument names and values, and function return values.
However, you must then turn on the tracing by setting the
HDF5_TRACE environment variable to a file descriptor number.
The default is `--disable-tracing' since enabling it causes a
slight increase in library size and a slowdown resulting from
an extra function call for each API function call (I couldn't
even measure the slowdown :-)
./bin/trace NEW
A perl script that synchronizes the H5TRACE() macro calls in
the *.c files with the function return type and formal
argument names and types. If you use GNU make and gcc then
this will be done automatically, otherwise just invoke this
script with the names of one or more .c files. You could do
it by hand to, but encoding argument types is a little tricky
at first.
./config/commence.in
Added the $(TRACE) macro, which defaults to the no-op.
Added -D_POSIX_SOURCE to the compiler command line.
./src/Makefile.in
Override the default for $(TRACE).
./config/depend.in
Automatically calls $(TRACE) to synchronize the H5TRACE()
macros in any source file that changed. As with makefile
dependencies, one way to force synchronization of all files is
to remove the `.depend' file.
./MANIFEST
Added new files.
./src/H5Eprivate.h
Modified HRETURN_ERROR() and HRETURN() for tracing.
./src/H5.c
./src/H5private.h
This is where the real tracing work really happens, in
H5_trace().
./src/H5A.c
./src/H5D.c
./src/H5G.c
./src/H5P.c
./src/H5S.c
./src/H5Z.c
Added H5TRACE() calls to all API functions. You don't really
need these changes if you don't want to merge your stuff
because they can be generated automatically by going to the
hdf5/src directory and saying ../bin/trace *.c
./src/H5T.c
Added H5TRACE() calls. Other stuff below.
./src/H5E.c
./src/H5Epublic.h
Added H5TRACE() calls. Created a type H5E_auto_t for the
`func' argument of H5Eset_auto() and H5Eget_auto() to make
those arguments easier to parse for tracing. It should also
make it clearer for users that don't know how to read
complicated ANSI data types.
./src/H5F.c
Added H5TRACE() calls. Changed a couple `uintn' argument
types in API functions to `unsigned int' since `uintn' part of
the API. Changed a few "can't" and "cant" error messages to
"unable to".
./src/H5Ipublic.h
Removed H5_DIRECTORY from the H5I_group_t enum. It wasn't
used anywhere.
./src/H5Tconv.c
Removed an unused label.
./src/H5Fistore.c
./src/H5Oattr.c
./src/H5Odtype.c
./src/H5T.c
./test/dsets.c
./test/dtypes.c
Fixed a warning about a variable possibly used before it's
initialized. Added __unused__ to turn off some unused
argument warnings that pop up when debugging is turned off and
optimizations are turned on.
1998-06-18 04:46:29 +08:00
|
|
|
AC_MSG_CHECKING(for debug flags)
|
1998-04-03 11:29:38 +08:00
|
|
|
AC_ARG_ENABLE(debug,
|
|
|
|
[--enable-debug=all Turn on debugging in all packages. One may also
|
|
|
|
specify a comma-separated list of package names
|
|
|
|
without the leading H5 or the word no. The default
|
|
|
|
is most packages.],
|
|
|
|
DEBUG_PKG=$enableval)
|
|
|
|
|
1998-04-18 05:29:43 +08:00
|
|
|
all_packages="ac,b,d,e,f,g,hg,hl,i,mf,mm,o,p,s,t,v,z"
|
1998-04-03 11:29:38 +08:00
|
|
|
if test X = "X$DEBUG_PKG" -o Xyes = "X$DEBUG_PKG"; then
|
1998-04-18 05:29:43 +08:00
|
|
|
DEBUG_PKG=ac,b,d,e,f,g,hg,i,mm,p,s,t,v,z
|
1998-04-03 11:29:38 +08:00
|
|
|
CPPFLAGS="$CPPFLAGS -UNDEBUG"
|
|
|
|
AC_MSG_RESULT(default ($DEBUG_PKG))
|
|
|
|
elif test Xall = "X$DEBUG_PKG"; then
|
|
|
|
DEBUG_PKG=$all_packages
|
|
|
|
CPPFLAGS="$CPPFLAGS -UNDEBUG"
|
|
|
|
AC_MSG_RESULT(all ($DEBUG_PKG))
|
|
|
|
elif test Xno = "X$DEBUG_PKG" -o Xnone = "X$DEBUG_PKG"; then
|
|
|
|
AC_MSG_RESULT(none)
|
|
|
|
DEBUG_PKG=
|
|
|
|
CPPFLAGS="$CPPFLAGS -DNDEBUG"
|
|
|
|
else
|
|
|
|
AC_MSG_RESULT($DEBUG_PKG)
|
|
|
|
fi
|
|
|
|
|
|
|
|
if test "X" != "X$DEBUG_PKG"; then
|
|
|
|
for pkg in `echo $DEBUG_PKG | tr 'a-z,' 'A-Z '`; do
|
|
|
|
CPPFLAGS="$CPPFLAGS -DH5${pkg}_DEBUG"
|
|
|
|
done
|
|
|
|
fi
|
1997-08-16 00:35:53 +08:00
|
|
|
|
[svn-r429] Changes since 19980616
----------------------
./html/tracing.html NEW
This entire update is to make it possible for the library to
print the name, arguments, and return value of every API call
without requiring any extra work from developers or app
programmers. This file describes how this all works.
./configure.in
Added the `--enable-tracing' switch. If you use it then the
library will include code to print API function names,
argument names and values, and function return values.
However, you must then turn on the tracing by setting the
HDF5_TRACE environment variable to a file descriptor number.
The default is `--disable-tracing' since enabling it causes a
slight increase in library size and a slowdown resulting from
an extra function call for each API function call (I couldn't
even measure the slowdown :-)
./bin/trace NEW
A perl script that synchronizes the H5TRACE() macro calls in
the *.c files with the function return type and formal
argument names and types. If you use GNU make and gcc then
this will be done automatically, otherwise just invoke this
script with the names of one or more .c files. You could do
it by hand to, but encoding argument types is a little tricky
at first.
./config/commence.in
Added the $(TRACE) macro, which defaults to the no-op.
Added -D_POSIX_SOURCE to the compiler command line.
./src/Makefile.in
Override the default for $(TRACE).
./config/depend.in
Automatically calls $(TRACE) to synchronize the H5TRACE()
macros in any source file that changed. As with makefile
dependencies, one way to force synchronization of all files is
to remove the `.depend' file.
./MANIFEST
Added new files.
./src/H5Eprivate.h
Modified HRETURN_ERROR() and HRETURN() for tracing.
./src/H5.c
./src/H5private.h
This is where the real tracing work really happens, in
H5_trace().
./src/H5A.c
./src/H5D.c
./src/H5G.c
./src/H5P.c
./src/H5S.c
./src/H5Z.c
Added H5TRACE() calls to all API functions. You don't really
need these changes if you don't want to merge your stuff
because they can be generated automatically by going to the
hdf5/src directory and saying ../bin/trace *.c
./src/H5T.c
Added H5TRACE() calls. Other stuff below.
./src/H5E.c
./src/H5Epublic.h
Added H5TRACE() calls. Created a type H5E_auto_t for the
`func' argument of H5Eset_auto() and H5Eget_auto() to make
those arguments easier to parse for tracing. It should also
make it clearer for users that don't know how to read
complicated ANSI data types.
./src/H5F.c
Added H5TRACE() calls. Changed a couple `uintn' argument
types in API functions to `unsigned int' since `uintn' part of
the API. Changed a few "can't" and "cant" error messages to
"unable to".
./src/H5Ipublic.h
Removed H5_DIRECTORY from the H5I_group_t enum. It wasn't
used anywhere.
./src/H5Tconv.c
Removed an unused label.
./src/H5Fistore.c
./src/H5Oattr.c
./src/H5Odtype.c
./src/H5T.c
./test/dsets.c
./test/dtypes.c
Fixed a warning about a variable possibly used before it's
initialized. Added __unused__ to turn off some unused
argument warnings that pop up when debugging is turned off and
optimizations are turned on.
1998-06-18 04:46:29 +08:00
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl Enable tracing of the API
|
|
|
|
dnl
|
|
|
|
AC_MSG_CHECKING(for API tracing);
|
1998-07-09 02:41:04 +08:00
|
|
|
AC_ARG_ENABLE(trace,
|
|
|
|
[--disable-trace Disable API tracing capability],
|
|
|
|
TRACE=$enableval)
|
|
|
|
|
|
|
|
if test X = "X$TRACE" -o Xyes = "X$TRACE"; then
|
|
|
|
AC_MSG_RESULT(yes)
|
|
|
|
CPPFLAGS="$CPPFLAGS -DH5_DEBUG_API"
|
|
|
|
else
|
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
CPPFLAGS="$CPPFLAGS -UH5_DEBUG_API"
|
|
|
|
fi
|
[svn-r429] Changes since 19980616
----------------------
./html/tracing.html NEW
This entire update is to make it possible for the library to
print the name, arguments, and return value of every API call
without requiring any extra work from developers or app
programmers. This file describes how this all works.
./configure.in
Added the `--enable-tracing' switch. If you use it then the
library will include code to print API function names,
argument names and values, and function return values.
However, you must then turn on the tracing by setting the
HDF5_TRACE environment variable to a file descriptor number.
The default is `--disable-tracing' since enabling it causes a
slight increase in library size and a slowdown resulting from
an extra function call for each API function call (I couldn't
even measure the slowdown :-)
./bin/trace NEW
A perl script that synchronizes the H5TRACE() macro calls in
the *.c files with the function return type and formal
argument names and types. If you use GNU make and gcc then
this will be done automatically, otherwise just invoke this
script with the names of one or more .c files. You could do
it by hand to, but encoding argument types is a little tricky
at first.
./config/commence.in
Added the $(TRACE) macro, which defaults to the no-op.
Added -D_POSIX_SOURCE to the compiler command line.
./src/Makefile.in
Override the default for $(TRACE).
./config/depend.in
Automatically calls $(TRACE) to synchronize the H5TRACE()
macros in any source file that changed. As with makefile
dependencies, one way to force synchronization of all files is
to remove the `.depend' file.
./MANIFEST
Added new files.
./src/H5Eprivate.h
Modified HRETURN_ERROR() and HRETURN() for tracing.
./src/H5.c
./src/H5private.h
This is where the real tracing work really happens, in
H5_trace().
./src/H5A.c
./src/H5D.c
./src/H5G.c
./src/H5P.c
./src/H5S.c
./src/H5Z.c
Added H5TRACE() calls to all API functions. You don't really
need these changes if you don't want to merge your stuff
because they can be generated automatically by going to the
hdf5/src directory and saying ../bin/trace *.c
./src/H5T.c
Added H5TRACE() calls. Other stuff below.
./src/H5E.c
./src/H5Epublic.h
Added H5TRACE() calls. Created a type H5E_auto_t for the
`func' argument of H5Eset_auto() and H5Eget_auto() to make
those arguments easier to parse for tracing. It should also
make it clearer for users that don't know how to read
complicated ANSI data types.
./src/H5F.c
Added H5TRACE() calls. Changed a couple `uintn' argument
types in API functions to `unsigned int' since `uintn' part of
the API. Changed a few "can't" and "cant" error messages to
"unable to".
./src/H5Ipublic.h
Removed H5_DIRECTORY from the H5I_group_t enum. It wasn't
used anywhere.
./src/H5Tconv.c
Removed an unused label.
./src/H5Fistore.c
./src/H5Oattr.c
./src/H5Odtype.c
./src/H5T.c
./test/dsets.c
./test/dtypes.c
Fixed a warning about a variable possibly used before it's
initialized. Added __unused__ to turn off some unused
argument warnings that pop up when debugging is turned off and
optimizations are turned on.
1998-06-18 04:46:29 +08:00
|
|
|
|
1998-02-04 01:03:13 +08:00
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl Check for parallel support
|
|
|
|
dnl
|
|
|
|
AC_ARG_ENABLE(parallel,
|
|
|
|
--enable-parallel=mpio Enable parallel support with MPIO,
|
|
|
|
PARALLEL=$enableval)
|
|
|
|
AC_MSG_CHECKING(for parallel support);
|
1998-03-24 10:16:03 +08:00
|
|
|
AC_SUBST(RUNTEST)
|
1998-02-04 01:03:13 +08:00
|
|
|
|
|
|
|
case "X-$PARALLEL" in
|
|
|
|
|
|
|
|
X-|X-no)
|
|
|
|
# Parallel support is not enabled
|
|
|
|
AC_MSG_RESULT(disabled)
|
|
|
|
;;
|
|
|
|
|
|
|
|
X-mpio|X-yes)
|
1998-02-26 04:31:17 +08:00
|
|
|
# Use MPIO. Define HAVE_PARALLEL in src/H5config.h (comes from
|
|
|
|
# ./acconfig.h) and augment the include and library search paths
|
|
|
|
# (it doesn't hurt to have extra paths). Then check for header
|
|
|
|
# files and libraries. Some extra source files are added to the
|
|
|
|
# list also so we don't have to ifdef out the whole file.
|
1998-02-04 01:03:13 +08:00
|
|
|
AC_MSG_RESULT(mpio)
|
|
|
|
AC_DEFINE(HAVE_PARALLEL)
|
1998-02-20 02:19:48 +08:00
|
|
|
CPPFLAGS="$CPPFLAGS $MPI_INC"
|
1998-02-11 14:00:36 +08:00
|
|
|
CFLAGS="$CFLAGS $MPI_LIB"
|
1998-04-17 07:06:30 +08:00
|
|
|
RUNTEST="$RUNTEST"
|
1998-02-04 01:03:13 +08:00
|
|
|
AC_CHECK_LIB(mpi,main) dnl Replace `main' with some function
|
|
|
|
AC_CHECK_LIB(mpio,main) dnl Replace `main' with some function
|
|
|
|
;;
|
|
|
|
|
|
|
|
*)
|
|
|
|
AC_MSG_ERROR(unknown parallel support: $PARALLEL)
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
|
1997-08-16 00:35:53 +08:00
|
|
|
|
|
|
|
dnl ----------------------------------------------------------------------
|
|
|
|
dnl Build the Makefiles. Almost every Makefile.in will begin with the line
|
|
|
|
dnl `@COMMENCE@' and end with the line `@CONCLUDE@'. These lines insert
|
|
|
|
dnl various files from the config directory into the Makefile.
|
|
|
|
dnl
|
|
|
|
AC_SUBST_FILE(COMMENCE) COMMENCE=config/commence
|
|
|
|
AC_SUBST_FILE(CONCLUDE) CONCLUDE=config/conclude
|
|
|
|
|
|
|
|
if test "X$GCC" = "Xyes" && test "X$GMAKE" = "Xyes"; then
|
1998-03-19 02:09:16 +08:00
|
|
|
AC_SUBST_FILE(DEPEND1) DEPEND1=config/depend
|
|
|
|
AC_SUBST_FILE(DEPEND2) DEPEND2=/dev/null
|
1997-08-16 00:35:53 +08:00
|
|
|
else
|
1998-03-19 02:09:16 +08:00
|
|
|
AC_SUBST_FILE(DEPEND1) DEPEND1=src/.distdep
|
|
|
|
AC_SUBST_FILE(DEPEND2) DEPEND2=test/.distdep
|
1997-08-16 00:35:53 +08:00
|
|
|
fi
|
|
|
|
|
|
|
|
dnl We don't need to say when we're entering directories if we're using
|
|
|
|
dnl GNU make becuase make does it for us.
|
|
|
|
if test "X$GMAKE" = "Xyes"; then
|
|
|
|
AC_SUBST(SETX) SETX=":"
|
|
|
|
else
|
|
|
|
AC_SUBST(SETX) SETX="set -x"
|
|
|
|
fi
|
|
|
|
|
1997-08-29 00:36:57 +08:00
|
|
|
dnl Where is the root of the source tree. Give an absolute address so
|
|
|
|
dnl we can find it no matter which directory of the distribution is our
|
|
|
|
dnl current directory. The built-in pwd fails on some systems, but the
|
|
|
|
dnl /bin/pwd version works OK.
|
|
|
|
if test -x /bin/pwd; then
|
|
|
|
pwd=/bin/pwd
|
|
|
|
else
|
|
|
|
pwd=pwd
|
|
|
|
fi
|
|
|
|
AC_SUBST(ROOT) ROOT=`$pwd`
|
|
|
|
|
|
|
|
dnl Touch the time-stamp files for src/H5config.h.in and src/H5config.h
|
|
|
|
dnl before we generate them or the Makefiles.
|
|
|
|
touch ./config/stamp1 ./config/stamp2
|
|
|
|
|
|
|
|
AC_OUTPUT(config/depend config/commence config/conclude \
|
1998-07-13 23:35:21 +08:00
|
|
|
Makefile src/Makefile test/Makefile tools/Makefile examples/Makefile)
|