mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-03-31 17:10:47 +08:00
Merge branch 'develop' into hdf5_1_10
This commit is contained in:
commit
8d462d5102
14
MANIFEST
14
MANIFEST
@ -753,6 +753,7 @@
|
||||
./src/H5Oflush.c
|
||||
./src/H5Ofsinfo.c
|
||||
./src/H5Oginfo.c
|
||||
./src/H5Oint.c
|
||||
./src/H5Olayout.c
|
||||
./src/H5Olinfo.c
|
||||
./src/H5Olink.c
|
||||
@ -810,6 +811,7 @@
|
||||
./src/H5PLextern.h
|
||||
./src/H5R.c
|
||||
./src/H5Rdeprec.c
|
||||
./src/H5Rint.c
|
||||
./src/H5Rmodule.h
|
||||
./src/H5Rpkg.h
|
||||
./src/H5Rprivate.h
|
||||
@ -936,10 +938,6 @@
|
||||
./test/dt_arith.c
|
||||
./test/dtypes.c
|
||||
./test/dtransform.c
|
||||
./test/dynlib1.c
|
||||
./test/dynlib2.c
|
||||
./test/dynlib3.c
|
||||
./test/dynlib4.c
|
||||
./test/earray.c
|
||||
./test/efc.c
|
||||
./test/enc_dec_plist.c
|
||||
@ -967,6 +965,11 @@
|
||||
./test/fill_old.h5
|
||||
./test/fillval.c
|
||||
./test/filter_fail.c
|
||||
./test/filter_plugin.c
|
||||
./test/filter_plugin1_dsets.c
|
||||
./test/filter_plugin2_dsets.c
|
||||
./test/filter_plugin3_dsets.c
|
||||
./test/filter_plugin4_groups.c
|
||||
./test/flush1.c
|
||||
./test/flush2.c
|
||||
./test/flushrefresh.c
|
||||
@ -1030,7 +1033,6 @@
|
||||
./test/page_buffer.c
|
||||
./test/paged_nopersist.h5
|
||||
./test/paged_persist.h5
|
||||
./test/plugin.c
|
||||
./test/reserved.c
|
||||
./test/pool.c
|
||||
./test/set_extent.c
|
||||
@ -1065,12 +1067,12 @@
|
||||
./test/testerror.sh.in
|
||||
./test/testlinks_env.sh.in
|
||||
./test/test_filenotclosed.sh.in
|
||||
./test/test_filter_plugin.sh.in
|
||||
./test/testflushrefresh.sh.in
|
||||
./test/testframe.c
|
||||
./test/testhdf5.c
|
||||
./test/testhdf5.h
|
||||
./test/testlibinfo.sh.in
|
||||
./test/test_plugin.sh.in
|
||||
./test/test_usecases.sh.in
|
||||
./test/testmeta.c
|
||||
./test/testswmr.sh.in
|
||||
|
@ -16,27 +16,25 @@
|
||||
## Textually included at the end of most HDF5 Makefiles.am.
|
||||
## Contains build rules.
|
||||
|
||||
# Automake needs to be taught how to build lib, dyn, progs and tests targets.
|
||||
# Automake needs to be taught how to build lib, progs and tests targets.
|
||||
# These will be filled in automatically for the most part (e.g.,
|
||||
# lib_LIBRARIES are built for lib target), but EXTRA_LIB, EXTRA_PROG, and
|
||||
# EXTRA_TEST variables are supplied to allow the user to force targets to
|
||||
# be built at certain times.
|
||||
LIB = $(lib_LIBRARIES) $(lib_LTLIBRARIES) $(noinst_LIBRARIES) \
|
||||
$(noinst_LTLIBRARIES) $(check_LIBRARIES) $(check_LTLIBRARIES) $(EXTRA_LIB)
|
||||
DYN = $(dyn_LTLIBRARIES)
|
||||
PROGS = $(bin_PROGRAMS) $(bin_SCRIPTS) $(noinst_PROGRAMS) $(noinst_SCRIPTS) \
|
||||
$(EXTRA_PROG)
|
||||
chk_TESTS = $(check_PROGRAMS) $(check_SCRIPTS) $(EXTRA_TEST)
|
||||
TESTS = $(TEST_PROG) $(TEST_SCRIPT) $(EXTRA_TEST)
|
||||
dyndir=$(libdir)
|
||||
|
||||
TEST_EXTENSIONS = .sh
|
||||
SH_LOG_COMPILER = $(SHELL)
|
||||
AM_SH_LOG_FLAGS =
|
||||
REALTIMEOUTPUT = $(realtimeOutput)
|
||||
|
||||
# lib/progs/tests targets recurse into subdirectories. build-* targets
|
||||
# build files in this directory.
|
||||
build-dyn: $(DYN)
|
||||
build-lib: $(LIB)
|
||||
build-progs: $(LIB) $(PROGS)
|
||||
build-tests: $(LIB) $(PROGS) $(chk_TESTS)
|
||||
@ -44,7 +42,7 @@ build-tests: $(LIB) $(PROGS) $(chk_TESTS)
|
||||
# General rule for recursive building targets.
|
||||
# BUILT_SOURCES contain targets that need to be built before anything else
|
||||
# in the directory (e.g., for Fortran type detection)
|
||||
lib dyn progs tests check-s check-p :: $(BUILT_SOURCES)
|
||||
lib progs tests check-s check-p :: $(BUILT_SOURCES)
|
||||
@$(MAKE) $(AM_MAKEFLAGS) build-$@ || exit 1;
|
||||
@for d in X $(SUBDIRS); do \
|
||||
if test $$d != X && test $$d != .; then \
|
||||
@ -127,28 +125,62 @@ $(TEST_PROG_CHKEXE) $(TEST_PROG_PARA_CHKEXE) dummy.chkexe_:
|
||||
if $(top_srcdir)/bin/newer $(@:.chkexe_=.chkexe) $${tname}; then \
|
||||
echo "No need to test $${tname} again."; \
|
||||
else \
|
||||
echo "============================" > $${log}; \
|
||||
if test "X$(FORTRAN_API)" = "Xyes"; then \
|
||||
echo "Fortran API: Testing $(HDF5_DRIVER) $${tname} $(TEST_FLAGS)"; \
|
||||
echo "Fortran API: $(HDF5_DRIVER) $${tname} $(TEST_FLAGS) Test Log" >> $${log}; \
|
||||
elif test "X$(CXX_API)" = "Xyes"; then \
|
||||
echo "C++ API: Testing $(HDF5_DRIVER) $${tname} $(TEST_FLAGS)"; \
|
||||
echo "C++ API: $(HDF5_DRIVER) $${tname} $(TEST_FLAGS) Test Log" >> $${log};\
|
||||
else \
|
||||
echo "Testing $(HDF5_DRIVER) $${tname} $(TEST_FLAGS)"; \
|
||||
echo "$(HDF5_DRIVER) $${tname} $(TEST_FLAGS) Test Log" >> $${log}; \
|
||||
fi; \
|
||||
echo "============================" >> $${log}; \
|
||||
srcdir="$(srcdir)" \
|
||||
$(TIME) $(RUNEXEC) ./$${tname} $(TEST_FLAGS) >> $${log} 2>&1 \
|
||||
&& touch $(@:.chkexe_=.chkexe) || \
|
||||
(test $$HDF5_Make_Ignore && echo "*** Error ignored") || \
|
||||
(cat $${log} && false) || exit 1; \
|
||||
if test -n "$(REALTIMEOUTPUT)"; then \
|
||||
echo "============================" | tee $${log}; \
|
||||
else \
|
||||
echo "============================" > $${log}; \
|
||||
fi; \
|
||||
if test "X$(FORTRAN_API)" = "Xyes"; then \
|
||||
echo "Fortran API: Testing $(HDF5_DRIVER) $${tname} $(TEST_FLAGS)"; \
|
||||
if test -n "$(REALTIMEOUTPUT)"; then \
|
||||
echo "Fortran API: $(HDF5_DRIVER) $${tname} $(TEST_FLAGS) Test Log" | tee -a $${log}; \
|
||||
else \
|
||||
echo "Fortran API: $(HDF5_DRIVER) $${tname} $(TEST_FLAGS) Test Log" >> $${log}; \
|
||||
fi; \
|
||||
elif test "X$(CXX_API)" = "Xyes"; then \
|
||||
echo "C++ API: Testing $(HDF5_DRIVER) $${tname} $(TEST_FLAGS)"; \
|
||||
if test -n "$(REALTIMEOUTPUT)"; then \
|
||||
echo "C++ API: $(HDF5_DRIVER) $${tname} $(TEST_FLAGS) Test Log" | tee -a $${log};\
|
||||
else \
|
||||
echo "C++ API: $(HDF5_DRIVER) $${tname} $(TEST_FLAGS) Test Log" >> $${log};\
|
||||
fi; \
|
||||
else \
|
||||
echo "Testing $(HDF5_DRIVER) $${tname} $(TEST_FLAGS)"; \
|
||||
if test -n "$(REALTIMEOUTPUT)"; then \
|
||||
echo "$(HDF5_DRIVER) $${tname} $(TEST_FLAGS) Test Log" | tee -a $${log}; \
|
||||
else \
|
||||
echo "$(HDF5_DRIVER) $${tname} $(TEST_FLAGS) Test Log" >> $${log}; \
|
||||
fi; \
|
||||
fi; \
|
||||
if test -n "$(REALTIMEOUTPUT)"; then \
|
||||
echo "============================" | tee -a $${log}; \
|
||||
else \
|
||||
echo "============================" >> $${log}; \
|
||||
fi; \
|
||||
if test -n "$(REALTIMEOUTPUT)"; then \
|
||||
srcdir="$(srcdir)" \
|
||||
$(TIME) $(RUNEXEC) ./$${tname} $(TEST_FLAGS) | tee -a $${log} 2>&1 \
|
||||
&& touch $(@:.chkexe_=.chkexe) || \
|
||||
(test $$HDF5_Make_Ignore && echo "*** Error ignored") || \
|
||||
(cat $${log} && false) || exit 1; \
|
||||
else \
|
||||
srcdir="$(srcdir)" \
|
||||
$(TIME) $(RUNEXEC) ./$${tname} $(TEST_FLAGS) >> $${log} 2>&1 \
|
||||
&& touch $(@:.chkexe_=.chkexe) || \
|
||||
(test $$HDF5_Make_Ignore && echo "*** Error ignored") || \
|
||||
(cat $${log} && false) || exit 1; \
|
||||
fi; \
|
||||
echo "" >> $${log}; \
|
||||
echo "Finished testing $${tname} $(TEST_FLAGS)" >> $${log}; \
|
||||
echo "============================" >> $${log}; \
|
||||
echo "Finished testing $${tname} $(TEST_FLAGS)"; \
|
||||
cat $${log}; \
|
||||
if test -n "$(REALTIMEOUTPUT)"; then \
|
||||
echo "Finished testing $${tname} $(TEST_FLAGS)" | tee -a $${log}; \
|
||||
echo "============================" | tee -a $${log}; \
|
||||
else \
|
||||
echo "Finished testing $${tname} $(TEST_FLAGS)" >> $${log}; \
|
||||
echo "============================" >> $${log}; \
|
||||
fi; \
|
||||
if test -z "$(REALTIMEOUTPUT)"; then \
|
||||
cat $${log}; \
|
||||
fi; \
|
||||
fi; \
|
||||
fi
|
||||
|
||||
|
17
configure.ac
17
configure.ac
@ -99,6 +99,7 @@ AC_CONFIG_COMMANDS([pubconf], [
|
||||
AC_CANONICAL_HOST
|
||||
AC_SUBST([CPPFLAGS])
|
||||
AC_SUBST([JNIFLAGS])
|
||||
AC_SUBST([AR_FLAGS])
|
||||
|
||||
## H5_CFLAGS (and company) are for CFLAGS that should be used on HDF5, but
|
||||
## not exported to h5cc (or h5fc, etc.)
|
||||
@ -139,6 +140,7 @@ JNIFLAGS="${JNIFLAGS}"
|
||||
JAVACFLAGS="${JAVACFLAGS}"
|
||||
JAVAFLAGS="${JAVAFLAGS}"
|
||||
LDFLAGS="${LDFLAGS}"
|
||||
AR_FLAGS="${AR_FLAGS}"
|
||||
|
||||
## Configure may need to alter any of the *FLAGS variables in order for
|
||||
## various checks to work correctly. Save the user's value here so it
|
||||
@ -757,12 +759,17 @@ fi
|
||||
## Check which archiving tool to use. This needs to be done before
|
||||
## the AM_PROG_LIBTOOL macro.
|
||||
##
|
||||
|
||||
if test -z "$AR"; then
|
||||
AC_CHECK_PROGS([AR], [ar xar], [:], [$PATH])
|
||||
fi
|
||||
AC_SUBST([AR])
|
||||
|
||||
# Set the default ar flags to cr
|
||||
# The Automake default is to use cru and the 'u' causes ar
|
||||
# to emit warnings on some platforms.
|
||||
AR_FLAGS=cr
|
||||
|
||||
|
||||
## Export the AR macro so that it will be placed in the libtool file
|
||||
## correctly.
|
||||
export AR
|
||||
@ -3369,17 +3376,17 @@ AC_CONFIG_FILES([src/libhdf5.settings
|
||||
Makefile
|
||||
src/Makefile
|
||||
test/Makefile
|
||||
test/H5srcdir_str.h
|
||||
test/testcheck_version.sh
|
||||
test/testerror.sh
|
||||
test/testflushrefresh.sh
|
||||
test/H5srcdir_str.h
|
||||
test/testlibinfo.sh
|
||||
test/testlinks_env.sh
|
||||
test/test_filenotclosed.sh
|
||||
test/testswmr.sh
|
||||
test/test_plugin.sh
|
||||
test/test_usecases.sh
|
||||
test/testvdsswmr.sh
|
||||
test/test_filenotclosed.sh
|
||||
test/test_filter_plugin.sh
|
||||
test/test_usecases.sh
|
||||
testpar/Makefile
|
||||
tools/Makefile
|
||||
tools/lib/Makefile
|
||||
|
@ -36,7 +36,6 @@ int main () {
|
||||
hsize_t dims[2];
|
||||
hsize_t cdims[2];
|
||||
|
||||
int idx;
|
||||
int i,j, numfilt;
|
||||
int buf[DIM0][DIM1];
|
||||
int rbuf [DIM0][DIM1];
|
||||
|
@ -704,6 +704,7 @@ parse_command_line(int argc, const char *argv[])
|
||||
case 'h': /* --help */
|
||||
usage(h5tools_getprogname());
|
||||
leave(EXIT_SUCCESS);
|
||||
break;
|
||||
|
||||
case 'V': /* --version */
|
||||
print_version(progname);
|
||||
|
@ -316,6 +316,21 @@ Bug Fixes since HDF5-1.10.1 release
|
||||
|
||||
(RAW - 2017/11/08, HDFFV-10301)
|
||||
|
||||
- An uninitialized struct could cause a memory access error when using
|
||||
variable-length or reference types in a compressed, chunked dataset.
|
||||
|
||||
A struct containing a callback function pointer and a pointer to some
|
||||
associated data was used before initialization. This could cause a
|
||||
memory access error and system crash. This could only occur under
|
||||
unusual conditions when using variable-lenth and reference types in
|
||||
a compressed, chunked dataset.
|
||||
|
||||
On recent versions of Visual Studio, when built in debug mode, the
|
||||
debug heap will complain and cause a crash if the code in question
|
||||
is executed (this will cause the objcopy test to fail).
|
||||
|
||||
(DER - 2017/11/21, HDFFV-10330)
|
||||
|
||||
Configuration
|
||||
-------------
|
||||
- cmake
|
||||
|
@ -454,6 +454,7 @@ set (H5O_SOURCES
|
||||
${HDF5_SRC_DIR}/H5Oflush.c
|
||||
${HDF5_SRC_DIR}/H5Ofsinfo.c
|
||||
${HDF5_SRC_DIR}/H5Oginfo.c
|
||||
${HDF5_SRC_DIR}/H5Oint.c
|
||||
${HDF5_SRC_DIR}/H5Olayout.c
|
||||
${HDF5_SRC_DIR}/H5Olinfo.c
|
||||
${HDF5_SRC_DIR}/H5Olink.c
|
||||
@ -532,6 +533,7 @@ IDE_GENERATED_PROPERTIES ("H5PL" "${H5PL_HDRS}" "${H5PL_SOURCES}" )
|
||||
set (H5R_SOURCES
|
||||
${HDF5_SRC_DIR}/H5R.c
|
||||
${HDF5_SRC_DIR}/H5Rdeprec.c
|
||||
${HDF5_SRC_DIR}/H5Rint.c
|
||||
)
|
||||
set (H5R_HDRS
|
||||
${HDF5_SRC_DIR}/H5Rpkg.h
|
||||
|
@ -5661,7 +5661,7 @@ H5D__chunk_copy_cb(const H5D_chunk_rec_t *chunk_rec, void *_udata)
|
||||
/* needed for commpressed variable length data */
|
||||
hbool_t must_filter = FALSE; /* Whether chunk must be filtered during copy */
|
||||
size_t nbytes; /* Size of chunk in file (in bytes) */
|
||||
H5Z_cb_t cb_struct; /* Filter failure callback struct */
|
||||
H5Z_cb_t filter_cb; /* Filter failure callback struct */
|
||||
int ret_value = H5_ITER_CONT; /* Return value */
|
||||
|
||||
|
||||
@ -5670,6 +5670,10 @@ H5D__chunk_copy_cb(const H5D_chunk_rec_t *chunk_rec, void *_udata)
|
||||
/* Get 'size_t' local value for number of bytes in chunk */
|
||||
H5_CHECKED_ASSIGN(nbytes, size_t, chunk_rec->nbytes, uint32_t);
|
||||
|
||||
/* Initialize the filter callback struct */
|
||||
filter_cb.op_data = NULL;
|
||||
filter_cb.func = NULL; /* no callback function when failed */
|
||||
|
||||
/* Check for filtered chunks */
|
||||
/* Check for an edge chunk that is not filtered */
|
||||
if(pline && pline->nused) {
|
||||
@ -5716,11 +5720,12 @@ H5D__chunk_copy_cb(const H5D_chunk_rec_t *chunk_rec, void *_udata)
|
||||
HDassert(!H5F_addr_defined(chunk_rec->chunk_addr));
|
||||
HDmemcpy(buf, udata->chunk, nbytes);
|
||||
udata->chunk = NULL;
|
||||
} else {
|
||||
}
|
||||
else {
|
||||
H5D_rdcc_ent_t *ent = NULL; /* Cache entry */
|
||||
unsigned idx; /* Index of chunk in cache, if present */
|
||||
unsigned u; /* Counter */
|
||||
H5D_shared_t *shared_fo = udata->cpy_info->shared_fo;
|
||||
H5D_shared_t *shared_fo = (H5D_shared_t *)udata->cpy_info->shared_fo;
|
||||
|
||||
/* See if the written chunk is in the chunk cache */
|
||||
if(shared_fo && shared_fo->cache.chunk.nslots > 0) {
|
||||
@ -5748,7 +5753,8 @@ H5D__chunk_copy_cb(const H5D_chunk_rec_t *chunk_rec, void *_udata)
|
||||
|
||||
H5_CHECKED_ASSIGN(nbytes, size_t, shared_fo->layout.u.chunk.size, uint32_t);
|
||||
HDmemcpy(buf, ent->chunk, nbytes);
|
||||
} else {
|
||||
}
|
||||
else {
|
||||
/* read chunk data from the source file */
|
||||
if(H5F_block_read(udata->file_src, H5FD_MEM_DRAW, chunk_rec->chunk_addr, nbytes, H5AC_rawdata_dxpl_id, buf) < 0)
|
||||
HGOTO_ERROR(H5E_IO, H5E_READERROR, H5_ITER_ERROR, "unable to read raw data chunk")
|
||||
@ -5759,8 +5765,7 @@ H5D__chunk_copy_cb(const H5D_chunk_rec_t *chunk_rec, void *_udata)
|
||||
if(must_filter && (is_vlen || fix_ref) && !udata->chunk_in_cache) {
|
||||
unsigned filter_mask = chunk_rec->filter_mask;
|
||||
|
||||
cb_struct.func = NULL; /* no callback function when failed */
|
||||
if(H5Z_pipeline(pline, H5Z_FLAG_REVERSE, &filter_mask, H5Z_NO_EDC, cb_struct, &nbytes, &buf_size, &buf) < 0)
|
||||
if(H5Z_pipeline(pline, H5Z_FLAG_REVERSE, &filter_mask, H5Z_NO_EDC, filter_cb, &nbytes, &buf_size, &buf) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTFILTER, H5_ITER_ERROR, "data pipeline read failed")
|
||||
} /* end if */
|
||||
|
||||
@ -5822,7 +5827,7 @@ H5D__chunk_copy_cb(const H5D_chunk_rec_t *chunk_rec, void *_udata)
|
||||
|
||||
/* Need to compress variable-length or reference data elements or a chunk found in cache before writing to file */
|
||||
if(must_filter && (is_vlen || fix_ref || udata->chunk_in_cache) ) {
|
||||
if(H5Z_pipeline(pline, 0, &(udata_dst.filter_mask), H5Z_NO_EDC, cb_struct, &nbytes, &buf_size, &buf) < 0)
|
||||
if(H5Z_pipeline(pline, 0, &(udata_dst.filter_mask), H5Z_NO_EDC, filter_cb, &nbytes, &buf_size, &buf) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTFILTER, H5_ITER_ERROR, "output pipeline failed")
|
||||
#if H5_SIZEOF_SIZE_T > 4
|
||||
/* Check for the chunk expanding too much to encode in a 32-bit value */
|
||||
@ -6707,46 +6712,49 @@ H5D__chunk_format_convert_cb(const H5D_chunk_rec_t *chunk_rec, void *_udata)
|
||||
H5_CHECKED_ASSIGN(nbytes, size_t, chunk_rec->nbytes, uint32_t);
|
||||
chunk_addr = chunk_rec->chunk_addr;
|
||||
|
||||
if(new_idx_info->pline->nused &&
|
||||
if (new_idx_info->pline->nused &&
|
||||
(new_idx_info->layout->flags & H5O_LAYOUT_CHUNK_DONT_FILTER_PARTIAL_BOUND_CHUNKS) &&
|
||||
(H5D__chunk_is_partial_edge_chunk(udata->dset_ndims, new_idx_info->layout->dim, chunk_rec->scaled, udata->dset_dims))) {
|
||||
/* This is a partial non-filtered edge chunk */
|
||||
/* Convert the chunk to a filtered edge chunk for v1 B-tree chunk index */
|
||||
|
||||
unsigned filter_mask = chunk_rec->filter_mask;
|
||||
H5Z_cb_t cb_struct; /* Filter failure callback struct */
|
||||
size_t read_size = nbytes; /* Bytes to read */
|
||||
/* This is a partial non-filtered edge chunk */
|
||||
/* Convert the chunk to a filtered edge chunk for v1 B-tree chunk index */
|
||||
|
||||
HDassert(read_size == new_idx_info->layout->size);
|
||||
unsigned filter_mask = chunk_rec->filter_mask;
|
||||
H5Z_cb_t filter_cb; /* Filter failure callback struct */
|
||||
size_t read_size = nbytes; /* Bytes to read */
|
||||
|
||||
cb_struct.func = NULL; /* no callback function when failed */
|
||||
HDassert(read_size == new_idx_info->layout->size);
|
||||
|
||||
/* Allocate buffer for chunk data */
|
||||
if(NULL == (buf = H5MM_malloc(read_size)))
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, H5_ITER_ERROR, "memory allocation failed for raw data chunk")
|
||||
/* Initialize the filter callback struct */
|
||||
filter_cb.op_data = NULL;
|
||||
filter_cb.func = NULL; /* no callback function when failed */
|
||||
|
||||
/* Read the non-filtered edge chunk */
|
||||
if(H5F_block_read(new_idx_info->f, H5FD_MEM_DRAW, chunk_addr, read_size, H5AC_rawdata_dxpl_id, buf) < 0)
|
||||
HGOTO_ERROR(H5E_IO, H5E_READERROR, H5_ITER_ERROR, "unable to read raw data chunk")
|
||||
/* Allocate buffer for chunk data */
|
||||
if (NULL == (buf = H5MM_malloc(read_size)))
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, H5_ITER_ERROR, "memory allocation failed for raw data chunk")
|
||||
|
||||
/* Pass the chunk through the pipeline */
|
||||
if(H5Z_pipeline(new_idx_info->pline, 0, &filter_mask, H5Z_NO_EDC, cb_struct, &nbytes, &read_size, &buf) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTFILTER, H5_ITER_ERROR, "output pipeline failed")
|
||||
/* Read the non-filtered edge chunk */
|
||||
if (H5F_block_read(new_idx_info->f, H5FD_MEM_DRAW, chunk_addr, read_size, H5AC_rawdata_dxpl_id, buf) < 0)
|
||||
HGOTO_ERROR(H5E_IO, H5E_READERROR, H5_ITER_ERROR, "unable to read raw data chunk")
|
||||
|
||||
/* Pass the chunk through the pipeline */
|
||||
if (H5Z_pipeline(new_idx_info->pline, 0, &filter_mask, H5Z_NO_EDC, filter_cb, &nbytes, &read_size, &buf) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTFILTER, H5_ITER_ERROR, "output pipeline failed")
|
||||
|
||||
#if H5_SIZEOF_SIZE_T > 4
|
||||
/* Check for the chunk expanding too much to encode in a 32-bit value */
|
||||
if(nbytes > ((size_t)0xffffffff))
|
||||
HGOTO_ERROR(H5E_DATASET, H5E_BADRANGE, H5_ITER_ERROR, "chunk too large for 32-bit length")
|
||||
if (nbytes > ((size_t)0xffffffff))
|
||||
HGOTO_ERROR(H5E_DATASET, H5E_BADRANGE, H5_ITER_ERROR, "chunk too large for 32-bit length")
|
||||
#endif /* H5_SIZEOF_SIZE_T > 4 */
|
||||
|
||||
/* Allocate space for the filtered chunk */
|
||||
if((chunk_addr = H5MF_alloc(new_idx_info->f, H5FD_MEM_DRAW, new_idx_info->dxpl_id, (hsize_t)nbytes)) == HADDR_UNDEF)
|
||||
HGOTO_ERROR(H5E_DATASET, H5E_NOSPACE, H5_ITER_ERROR, "file allocation failed for filtered chunk")
|
||||
HDassert(H5F_addr_defined(chunk_addr));
|
||||
/* Allocate space for the filtered chunk */
|
||||
if ((chunk_addr = H5MF_alloc(new_idx_info->f, H5FD_MEM_DRAW, new_idx_info->dxpl_id, (hsize_t)nbytes)) == HADDR_UNDEF)
|
||||
HGOTO_ERROR(H5E_DATASET, H5E_NOSPACE, H5_ITER_ERROR, "file allocation failed for filtered chunk")
|
||||
HDassert(H5F_addr_defined(chunk_addr));
|
||||
|
||||
/* Write the filtered chunk to disk */
|
||||
if(H5F_block_write(new_idx_info->f, H5FD_MEM_DRAW, chunk_addr, nbytes, H5AC_rawdata_dxpl_id, buf) < 0)
|
||||
HGOTO_ERROR(H5E_DATASET, H5E_WRITEERROR, H5_ITER_ERROR, "unable to write raw data to file")
|
||||
/* Write the filtered chunk to disk */
|
||||
if (H5F_block_write(new_idx_info->f, H5FD_MEM_DRAW, chunk_addr, nbytes, H5AC_rawdata_dxpl_id, buf) < 0)
|
||||
HGOTO_ERROR(H5E_DATASET, H5E_WRITEERROR, H5_ITER_ERROR, "unable to write raw data to file")
|
||||
} /* end if */
|
||||
|
||||
/* Set up chunk information for insertion to chunk index */
|
||||
@ -6758,11 +6766,11 @@ H5D__chunk_format_convert_cb(const H5D_chunk_rec_t *chunk_rec, void *_udata)
|
||||
insert_udata.common.storage = new_idx_info->storage;
|
||||
|
||||
/* Insert chunk into the v1 B-tree chunk index */
|
||||
if((new_idx_info->storage->ops->insert)(new_idx_info, &insert_udata, NULL) < 0)
|
||||
if ((new_idx_info->storage->ops->insert)(new_idx_info, &insert_udata, NULL) < 0)
|
||||
HGOTO_ERROR(H5E_DATASET, H5E_CANTINSERT, H5_ITER_ERROR, "unable to insert chunk addr into index")
|
||||
|
||||
done:
|
||||
if(buf)
|
||||
if (buf)
|
||||
H5MM_xfree(buf);
|
||||
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
|
@ -431,7 +431,7 @@ H5D__compact_copy(H5F_t *f_src, H5O_storage_compact_t *_storage_src, H5F_t *f_ds
|
||||
void *bkg = NULL; /* Temporary buffer for copying data */
|
||||
void *reclaim_buf = NULL; /* Buffer for reclaiming data */
|
||||
hid_t buf_sid = -1; /* ID for buffer dataspace */
|
||||
H5D_shared_t *shared_fo = cpy_info->shared_fo; /* Pointer to the shared struct for dataset object */
|
||||
H5D_shared_t *shared_fo = (H5D_shared_t *)cpy_info->shared_fo; /* Pointer to the shared struct for dataset object */
|
||||
H5O_storage_compact_t *storage_src = _storage_src; /* Pointer to storage_src */
|
||||
herr_t ret_value = SUCCEED; /* Return value */
|
||||
|
||||
|
@ -1363,7 +1363,7 @@ H5D__contig_copy(H5F_t *f_src, const H5O_storage_contig_t *storage_src,
|
||||
hsize_t buf_dim[1] = {0}; /* Dimension for buffer */
|
||||
hbool_t is_vlen = FALSE; /* Flag to indicate that VL type conversion should occur */
|
||||
hbool_t fix_ref = FALSE; /* Flag to indicate that ref values should be fixed */
|
||||
H5D_shared_t *shared_fo = cpy_info->shared_fo; /* Pointer to the shared struct for dataset object */
|
||||
H5D_shared_t *shared_fo = (H5D_shared_t *)cpy_info->shared_fo; /* Pointer to the shared struct for dataset object */
|
||||
hbool_t try_sieve = FALSE; /* Try to get data from the sieve buffer */
|
||||
haddr_t sieve_start = HADDR_UNDEF; /* Start location of sieve buffer */
|
||||
haddr_t sieve_end = HADDR_UNDEF; /* End locations of sieve buffer */
|
||||
|
@ -962,7 +962,9 @@ const
|
||||
io_info->using_mpi_vfd = H5F_HAS_FEATURE(dset->oloc.file, H5FD_FEAT_HAS_MPI);
|
||||
#endif /* H5_HAVE_PARALLEL */
|
||||
|
||||
done:
|
||||
#ifdef H5_DEBUG_BUILD
|
||||
done:
|
||||
#endif /* H5_DEBUG_BUILD */
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5D__ioinfo_init() */
|
||||
|
||||
|
@ -96,10 +96,9 @@ H5FS_init(void)
|
||||
{
|
||||
herr_t ret_value = SUCCEED; /* Return value */
|
||||
|
||||
FUNC_ENTER_NOAPI(FAIL)
|
||||
FUNC_ENTER_NOAPI_NOERR
|
||||
/* FUNC_ENTER() does all the work */
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5FS_init() */
|
||||
|
||||
|
@ -640,7 +640,7 @@ H5G_node_insert(H5F_t *f, hid_t dxpl_id, haddr_t addr,
|
||||
while(lt < rt) {
|
||||
idx = (int)((lt + rt) / 2);
|
||||
if((s = (const char *)H5HL_offset_into(udata->common.heap, sn->entry[idx].name_off)) == NULL)
|
||||
HGOTO_ERROR(H5E_SYM, H5E_CANTGET, FAIL, "unable to get symbol table name")
|
||||
HGOTO_ERROR(H5E_SYM, H5E_CANTGET, H5B_INS_ERROR, "unable to get symbol table name")
|
||||
|
||||
/* Check if symbol is already present */
|
||||
if(0 == (cmp = HDstrcmp(udata->common.name, s)))
|
||||
@ -802,8 +802,8 @@ H5G_node_remove(H5F_t *f, hid_t dxpl_id, haddr_t addr, void *_lt_key/*in,out*/,
|
||||
const char *s; /* Pointer to string in local heap */
|
||||
|
||||
idx = (lt + rt) / 2;
|
||||
if((s = H5HL_offset_into(udata->common.heap, sn->entry[idx].name_off)) == NULL)
|
||||
HGOTO_ERROR(H5E_SYM, H5E_CANTGET, FAIL, "unable to get symbol table name")
|
||||
if((s = (const char *)H5HL_offset_into(udata->common.heap, sn->entry[idx].name_off)) == NULL)
|
||||
HGOTO_ERROR(H5E_SYM, H5E_CANTGET, H5B_INS_ERROR, "unable to get symbol table name")
|
||||
cmp = HDstrcmp(udata->common.name, s);
|
||||
if(cmp < 0)
|
||||
rt = idx;
|
||||
|
@ -1671,9 +1671,13 @@ H5HF__cache_dblock_verify_chksum(const void *_image, size_t len, void *_udata)
|
||||
HGOTO_DONE(TRUE);
|
||||
|
||||
if(hdr->filter_len > 0) {
|
||||
size_t nbytes; /* Number of bytes used in buffer, after applying reverse filters */
|
||||
unsigned filter_mask; /* Excluded filters for direct block */
|
||||
H5Z_cb_t filter_cb = {NULL, NULL}; /* Filter callback structure */
|
||||
size_t nbytes; /* Number of bytes used in buffer, after applying reverse filters */
|
||||
unsigned filter_mask; /* Excluded filters for direct block */
|
||||
H5Z_cb_t filter_cb; /* Filter callback structure */
|
||||
|
||||
/* Initialize the filter callback struct */
|
||||
filter_cb.op_data = NULL;
|
||||
filter_cb.func = NULL; /* no callback function when failed */
|
||||
|
||||
/* Allocate buffer to perform I/O filtering on and copy image into
|
||||
* it. Must do this as H5Z_pipeline() may re-size the buffer
|
||||
@ -1682,17 +1686,17 @@ H5HF__cache_dblock_verify_chksum(const void *_image, size_t len, void *_udata)
|
||||
if(NULL == (read_buf = H5MM_malloc(len)))
|
||||
HGOTO_ERROR(H5E_HEAP, H5E_NOSPACE, FAIL, "memory allocation failed for pipeline buffer")
|
||||
|
||||
/* Set up parameters for filter pipeline */
|
||||
nbytes = len;
|
||||
filter_mask = udata->filter_mask;
|
||||
/* Set up parameters for filter pipeline */
|
||||
nbytes = len;
|
||||
filter_mask = udata->filter_mask;
|
||||
HDmemcpy(read_buf, image, len);
|
||||
|
||||
/* Push direct block data through I/O filter pipeline */
|
||||
if(H5Z_pipeline(&(hdr->pline), H5Z_FLAG_REVERSE, &filter_mask, H5Z_ENABLE_EDC, filter_cb, &nbytes, &len, &read_buf) < 0)
|
||||
HGOTO_ERROR(H5E_HEAP, H5E_CANTFILTER, FAIL, "output pipeline failed")
|
||||
/* Push direct block data through I/O filter pipeline */
|
||||
if(H5Z_pipeline(&(hdr->pline), H5Z_FLAG_REVERSE, &filter_mask, H5Z_ENABLE_EDC, filter_cb, &nbytes, &len, &read_buf) < 0)
|
||||
HGOTO_ERROR(H5E_HEAP, H5E_CANTFILTER, FAIL, "output pipeline failed")
|
||||
|
||||
/* Update info about direct block */
|
||||
udata->decompressed = TRUE;
|
||||
udata->decompressed = TRUE;
|
||||
len = nbytes;
|
||||
} /* end if */
|
||||
else
|
||||
@ -1818,45 +1822,49 @@ H5HF__cache_dblock_deserialize(const void *_image, size_t len, void *_udata,
|
||||
udata->dblk = NULL;
|
||||
} /* end if */
|
||||
else {
|
||||
H5Z_cb_t filter_cb = {NULL, NULL}; /* Filter callback structure */
|
||||
H5Z_cb_t filter_cb; /* Filter callback structure */
|
||||
size_t nbytes; /* Number of bytes used in buffer, after applying reverse filters */
|
||||
unsigned filter_mask; /* Excluded filters for direct block */
|
||||
|
||||
/* Sanity check */
|
||||
HDassert(udata->dblk == NULL);
|
||||
HDassert(udata->dblk == NULL);
|
||||
|
||||
/* Allocate buffer to perform I/O filtering on and copy image into
|
||||
* it. Must do this as H5Z_pipeline() may resize the buffer
|
||||
* provided to it.
|
||||
*/
|
||||
if(NULL == (read_buf = H5MM_malloc(len)))
|
||||
HGOTO_ERROR(H5E_HEAP, H5E_NOSPACE, NULL, "memory allocation failed for pipeline buffer")
|
||||
/* Initialize the filter callback struct */
|
||||
filter_cb.op_data = NULL;
|
||||
filter_cb.func = NULL; /* no callback function when failed */
|
||||
|
||||
/* Allocate buffer to perform I/O filtering on and copy image into
|
||||
* it. Must do this as H5Z_pipeline() may resize the buffer
|
||||
* provided to it.
|
||||
*/
|
||||
if (NULL == (read_buf = H5MM_malloc(len)))
|
||||
HGOTO_ERROR(H5E_HEAP, H5E_NOSPACE, NULL, "memory allocation failed for pipeline buffer")
|
||||
|
||||
/* Copy compressed image into buffer */
|
||||
HDmemcpy(read_buf, image, len);
|
||||
HDmemcpy(read_buf, image, len);
|
||||
|
||||
/* Push direct block data through I/O filter pipeline */
|
||||
nbytes = len;
|
||||
filter_mask = udata->filter_mask;
|
||||
if(H5Z_pipeline(&(hdr->pline), H5Z_FLAG_REVERSE, &filter_mask, H5Z_ENABLE_EDC, filter_cb, &nbytes, &len, &read_buf) < 0)
|
||||
HGOTO_ERROR(H5E_HEAP, H5E_CANTFILTER, NULL, "output pipeline failed")
|
||||
/* Push direct block data through I/O filter pipeline */
|
||||
nbytes = len;
|
||||
filter_mask = udata->filter_mask;
|
||||
if (H5Z_pipeline(&(hdr->pline), H5Z_FLAG_REVERSE, &filter_mask, H5Z_ENABLE_EDC, filter_cb, &nbytes, &len, &read_buf) < 0)
|
||||
HGOTO_ERROR(H5E_HEAP, H5E_CANTFILTER, NULL, "output pipeline failed")
|
||||
|
||||
/* Sanity check */
|
||||
HDassert(nbytes == dblock->size);
|
||||
/* Sanity check */
|
||||
HDassert(nbytes == dblock->size);
|
||||
|
||||
/* Copy un-filtered data into block's buffer */
|
||||
HDmemcpy(dblock->blk, read_buf, dblock->size);
|
||||
} /* end if */
|
||||
/* Copy un-filtered data into block's buffer */
|
||||
HDmemcpy(dblock->blk, read_buf, dblock->size);
|
||||
} /* end if */
|
||||
} /* end if */
|
||||
else {
|
||||
/* Sanity checks */
|
||||
HDassert(udata->dblk == NULL);
|
||||
HDassert(!udata->decompressed);
|
||||
HDassert(udata->dblk == NULL);
|
||||
HDassert(!udata->decompressed);
|
||||
|
||||
/* Allocate block buffer */
|
||||
/* XXX: Change to using free-list factories */
|
||||
if(NULL == (dblock->blk = H5FL_BLK_MALLOC(direct_block, (size_t)dblock->size)))
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, NULL, "memory allocation failed")
|
||||
/* Allocate block buffer */
|
||||
/* XXX: Change to using free-list factories */
|
||||
if (NULL == (dblock->blk = H5FL_BLK_MALLOC(direct_block, (size_t)dblock->size)))
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, NULL, "memory allocation failed")
|
||||
|
||||
/* Copy image to dblock->blk */
|
||||
HDassert(dblock->size == len);
|
||||
@ -1895,9 +1903,9 @@ H5HF__cache_dblock_deserialize(const void *_image, size_t len, void *_udata,
|
||||
|
||||
/* Decode checksum on direct block, if requested */
|
||||
if(hdr->checksum_dblocks) {
|
||||
uint32_t stored_chksum; /* Metadata checksum value */
|
||||
uint32_t stored_chksum; /* Metadata checksum value */
|
||||
|
||||
/* checksum verification already done in verify_chksum cb */
|
||||
/* checksum verification already done in verify_chksum cb */
|
||||
|
||||
/* Metadata checksum */
|
||||
UINT32DECODE(image, stored_chksum);
|
||||
@ -2188,10 +2196,14 @@ H5HF__cache_dblock_pre_serialize(H5F_t *f, hid_t dxpl_id, void *_thing,
|
||||
|
||||
/* Check for I/O filters on this heap */
|
||||
if(hdr->filter_len > 0) {
|
||||
H5Z_cb_t filter_cb = {NULL, NULL}; /* Filter callback structure */
|
||||
H5Z_cb_t filter_cb; /* Filter callback structure */
|
||||
size_t nbytes; /* Number of bytes used */
|
||||
unsigned filter_mask = 0; /* Filter mask for block */
|
||||
|
||||
/* Initialize the filter callback struct */
|
||||
filter_cb.op_data = NULL;
|
||||
filter_cb.func = NULL; /* no callback function when failed */
|
||||
|
||||
/* Allocate buffer to perform I/O filtering on */
|
||||
write_size = dblock->size;
|
||||
if(NULL == (write_buf = H5MM_malloc(write_size)))
|
||||
|
@ -345,9 +345,13 @@ HDfprintf(stderr, "%s: obj_size = %Zu\n", FUNC, obj_size);
|
||||
|
||||
/* Check for I/O pipeline filter on heap */
|
||||
if(hdr->filter_len > 0) {
|
||||
H5Z_cb_t filter_cb = {NULL, NULL}; /* Filter callback structure */
|
||||
H5Z_cb_t filter_cb; /* Filter callback structure */
|
||||
size_t nbytes; /* Number of bytes used */
|
||||
|
||||
/* Initialize the filter callback struct */
|
||||
filter_cb.op_data = NULL;
|
||||
filter_cb.func = NULL; /* no callback function when failed */
|
||||
|
||||
/* Allocate buffer to perform I/O filtering on */
|
||||
write_size = obj_size;
|
||||
if(NULL == (write_buf = H5MM_malloc(write_size)))
|
||||
@ -773,10 +777,14 @@ H5HF_huge_op_real(H5HF_hdr_t *hdr, hid_t dxpl_id, const uint8_t *id,
|
||||
|
||||
/* Check for I/O pipeline filter on heap */
|
||||
if(hdr->filter_len > 0) {
|
||||
H5Z_cb_t filter_cb = {NULL, NULL}; /* Filter callback structure */
|
||||
H5Z_cb_t filter_cb; /* Filter callback structure */
|
||||
size_t read_size; /* Object's size in the file */
|
||||
size_t nbytes; /* Number of bytes used */
|
||||
|
||||
/* Initialize the filter callback struct */
|
||||
filter_cb.op_data = NULL;
|
||||
filter_cb.func = NULL; /* no callback function when failed */
|
||||
|
||||
/* De-filter the object */
|
||||
read_size = nbytes = obj_size;
|
||||
if(H5Z_pipeline(&(hdr->pline), H5Z_FLAG_REVERSE, &filter_mask, H5Z_NO_EDC, filter_cb, &nbytes, &read_size, &read_buf) < 0)
|
||||
|
@ -3247,7 +3247,6 @@ H5MF_settle_meta_data_fsm(H5F_t *f, hid_t dxpl_id, hbool_t *fsm_settled)
|
||||
/* for self referential FSMs */
|
||||
haddr_t eoa_post_fsm_fsalloc; /* eoa post file space allocation */
|
||||
/* for self referential FSMs */
|
||||
H5FS_stat_t fs_stat; /* Information for hdr FSM */
|
||||
H5P_genplist_t *dxpl = NULL; /* DXPL for setting ring */
|
||||
H5AC_ring_t orig_ring = H5AC_RING_INV; /* Original ring value */
|
||||
hbool_t reset_ring = FALSE; /* Whether we set the ring */
|
||||
@ -3310,6 +3309,9 @@ H5MF_settle_meta_data_fsm(H5F_t *f, hid_t dxpl_id, hbool_t *fsm_settled)
|
||||
reset_ring = TRUE;
|
||||
|
||||
#ifndef NDEBUG
|
||||
{
|
||||
H5FS_stat_t fs_stat; /* Information for hdr FSM */
|
||||
|
||||
/* Verify that sm_hdr_fspace is floating if it exists */
|
||||
if(sm_hdr_fspace) {
|
||||
/* Query free space manager info for this type */
|
||||
@ -3357,6 +3359,7 @@ H5MF_settle_meta_data_fsm(H5F_t *f, hid_t dxpl_id, hbool_t *fsm_settled)
|
||||
HDassert(fs_stat.alloc_sect_size == 0);
|
||||
} /* end if */
|
||||
} /* end if */
|
||||
}
|
||||
#endif /* NDEBUG */
|
||||
|
||||
/* Free the space in the metadata aggregator. Do this via the
|
||||
|
@ -268,8 +268,6 @@ H5MM_malloc(size_t size)
|
||||
{
|
||||
void *ret_value = NULL;
|
||||
|
||||
HDassert(size);
|
||||
|
||||
/* Use FUNC_ENTER_NOAPI_NOINIT_NOERR here to avoid performance issues */
|
||||
FUNC_ENTER_NOAPI_NOINIT_NOERR
|
||||
|
||||
@ -357,8 +355,6 @@ H5MM_calloc(size_t size)
|
||||
{
|
||||
void *ret_value = NULL;
|
||||
|
||||
HDassert(size);
|
||||
|
||||
/* Use FUNC_ENTER_NOAPI_NOINIT_NOERR here to avoid performance issues */
|
||||
FUNC_ENTER_NOAPI_NOINIT_NOERR
|
||||
|
||||
@ -407,8 +403,6 @@ H5MM_realloc(void *mem, size_t size)
|
||||
/* Use FUNC_ENTER_NOAPI_NOINIT_NOERR here to avoid performance issues */
|
||||
FUNC_ENTER_NOAPI_NOINIT_NOERR
|
||||
|
||||
HDassert(mem || size);
|
||||
|
||||
if(NULL == mem && 0 == size)
|
||||
/* Not defined in the standard, return NULL */
|
||||
ret_value = NULL;
|
||||
@ -454,7 +448,7 @@ H5MM_realloc(void *mem, size_t size)
|
||||
* NULL is an acceptable value for the input string.
|
||||
*
|
||||
* Return: Success: Pointer to a new string (NULL if s is NULL).
|
||||
* Failure: abort()
|
||||
* Failure: NULL
|
||||
*
|
||||
* Programmer: Robb Matzke
|
||||
* Jul 10 1997
|
||||
|
2713
src/H5Oint.c
Normal file
2713
src/H5Oint.c
Normal file
File diff suppressed because it is too large
Load Diff
@ -24,6 +24,9 @@
|
||||
#ifndef _H5Oprivate_H
|
||||
#define _H5Oprivate_H
|
||||
|
||||
/* Early typedefs to avoid circular dependencies */
|
||||
typedef struct H5O_t H5O_t;
|
||||
|
||||
/* Include the public header file for this API */
|
||||
#include "H5Opublic.h" /* Object header functions */
|
||||
|
||||
@ -44,7 +47,6 @@
|
||||
/* Forward references of package typedefs */
|
||||
typedef struct H5O_msg_class_t H5O_msg_class_t;
|
||||
typedef struct H5O_mesg_t H5O_mesg_t;
|
||||
typedef struct H5O_t H5O_t;
|
||||
|
||||
/* Values used to create the shared message & attribute heaps */
|
||||
/* (Note that these parameters have been tuned so that the resulting heap ID
|
||||
@ -881,6 +883,9 @@ H5_DLL void *H5O_obj_create(H5F_t *f, H5O_type_t obj_type, void *crt_info, H5G_l
|
||||
H5_DLL haddr_t H5O_get_oh_addr(const H5O_t *oh);
|
||||
H5_DLL herr_t H5O_get_rc_and_type(const H5O_loc_t *oloc, hid_t dxpl_id, unsigned *rc, H5O_type_t *otype);
|
||||
H5_DLL H5AC_proxy_entry_t *H5O_get_proxy(const H5O_t *oh);
|
||||
H5_DLL herr_t H5O_visit(hid_t loc_id, const char *obj_name, H5_index_t idx_type,
|
||||
H5_iter_order_t order, H5O_iterate_t op, void *op_data, hid_t lapl_id,
|
||||
hid_t dxpl_id);
|
||||
|
||||
/* Object header message routines */
|
||||
H5_DLL herr_t H5O_msg_create(const H5O_loc_t *loc, unsigned type_id, unsigned mesg_flags,
|
||||
|
@ -235,11 +235,11 @@ done:
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
const void *
|
||||
H5PL_load(H5PL_type_t type, int id)
|
||||
H5PL_load(H5PL_type_t type, H5PL_key_t key)
|
||||
{
|
||||
H5PL_search_params_t search_params;
|
||||
H5PL_search_params_t search_params; /* Plugin search parameters */
|
||||
hbool_t found = FALSE; /* Whether the plugin was found */
|
||||
const void *plugin_info = NULL;
|
||||
const void *plugin_info = NULL; /* Information from the plugin */
|
||||
const void *ret_value = NULL;
|
||||
|
||||
FUNC_ENTER_NOAPI(NULL)
|
||||
@ -248,18 +248,17 @@ H5PL_load(H5PL_type_t type, int id)
|
||||
switch (type) {
|
||||
case H5PL_TYPE_FILTER:
|
||||
if ((H5PL_plugin_control_mask_g & H5PL_FILTER_PLUGIN) == 0)
|
||||
HGOTO_ERROR(H5E_PLUGIN, H5E_CANTLOAD, NULL, "required dynamically loaded plugin filter '%d' is not available", id)
|
||||
HGOTO_ERROR(H5E_PLUGIN, H5E_CANTLOAD, NULL, "filter plugins disabled")
|
||||
break;
|
||||
|
||||
case H5PL_TYPE_ERROR:
|
||||
case H5PL_TYPE_NONE:
|
||||
default:
|
||||
HGOTO_ERROR(H5E_PLUGIN, H5E_CANTLOAD, NULL, "required dynamically loaded plugin '%d' is not valid", id)
|
||||
HGOTO_ERROR(H5E_PLUGIN, H5E_CANTLOAD, NULL, "Invalid plugin type specified")
|
||||
}
|
||||
|
||||
/* Set up the search parameters */
|
||||
search_params.type = type;
|
||||
search_params.id = id;
|
||||
search_params.key.id = key.id;
|
||||
|
||||
/* Search in the table of already loaded plugin libraries */
|
||||
if(H5PL__find_plugin_in_cache(&search_params, &found, &plugin_info) < 0)
|
||||
@ -304,11 +303,11 @@ done:
|
||||
#pragma GCC diagnostic push
|
||||
#pragma GCC diagnostic ignored "-Wpedantic"
|
||||
herr_t
|
||||
H5PL__open(const char *path, H5PL_type_t type, int id, hbool_t *success, const void **plugin_info)
|
||||
H5PL__open(const char *path, H5PL_type_t type, H5PL_key_t key, hbool_t *success, const void **plugin_info)
|
||||
{
|
||||
H5PL_HANDLE handle = NULL;
|
||||
H5PL_get_plugin_info_t get_plugin_info = NULL;
|
||||
htri_t ret_value = SUCCEED;
|
||||
herr_t ret_value = SUCCEED;
|
||||
|
||||
FUNC_ENTER_PACKAGE
|
||||
|
||||
@ -326,35 +325,46 @@ H5PL__open(const char *path, H5PL_type_t type, int id, hbool_t *success, const v
|
||||
*/
|
||||
if (NULL == (handle = H5PL_OPEN_DLIB(path))) {
|
||||
H5PL_CLR_ERROR; /* clear error */
|
||||
HGOTO_DONE(SUCCEED);
|
||||
HGOTO_DONE(SUCCEED)
|
||||
}
|
||||
|
||||
/* Return a handle for the function H5PLget_plugin_info in the dynamic library.
|
||||
* The plugin library is suppose to define this function.
|
||||
*/
|
||||
if (NULL != (get_plugin_info = (H5PL_get_plugin_info_t)H5PL_GET_LIB_FUNC(handle, "H5PLget_plugin_info"))) {
|
||||
if (NULL == (get_plugin_info = (H5PL_get_plugin_info_t)H5PL_GET_LIB_FUNC(handle, "H5PLget_plugin_info")))
|
||||
HGOTO_DONE(SUCCEED)
|
||||
|
||||
const H5Z_class2_t *info;
|
||||
/* Get the plugin information */
|
||||
switch (type) {
|
||||
case H5PL_TYPE_FILTER:
|
||||
{
|
||||
const H5Z_class2_t *filter_info;
|
||||
|
||||
/* Get the plugin info */
|
||||
if (NULL == (info = (const H5Z_class2_t *)(*get_plugin_info)()))
|
||||
HGOTO_ERROR(H5E_PLUGIN, H5E_CANTGET, FAIL, "can't get plugin info")
|
||||
/* Get the plugin info */
|
||||
if (NULL == (filter_info = (const H5Z_class2_t *)(*get_plugin_info)()))
|
||||
HGOTO_ERROR(H5E_PLUGIN, H5E_CANTGET, FAIL, "can't get filter info from plugin")
|
||||
|
||||
/* Check if the filter IDs match */
|
||||
if (info->id == id) {
|
||||
/* If the filter IDs match, we're done. Set the output parameters. */
|
||||
if (filter_info->id == key.id) {
|
||||
*plugin_info = (const void *)filter_info;
|
||||
*success = TRUE;
|
||||
}
|
||||
|
||||
/* Store the plugin in the cache */
|
||||
if (H5PL__add_plugin(type, id, handle))
|
||||
HGOTO_ERROR(H5E_PLUGIN, H5E_CANTINSERT, FAIL, "unable to add new plugin to plugin cache")
|
||||
|
||||
/* Set output parameters */
|
||||
*success = TRUE;
|
||||
*plugin_info = (const void *)info;
|
||||
break;
|
||||
}
|
||||
}
|
||||
case H5PL_TYPE_ERROR:
|
||||
case H5PL_TYPE_NONE:
|
||||
default:
|
||||
HGOTO_ERROR(H5E_PLUGIN, H5E_CANTGET, FAIL, "Invalid plugin type specified")
|
||||
} /* end switch */
|
||||
|
||||
/* If we found the correct plugin, store it in the cache */
|
||||
if (*success)
|
||||
if (H5PL__add_plugin(type, key, handle))
|
||||
HGOTO_ERROR(H5E_PLUGIN, H5E_CANTINSERT, FAIL, "unable to add new plugin to plugin cache")
|
||||
|
||||
done:
|
||||
if (!success && handle)
|
||||
if (!(*success) && handle)
|
||||
if (H5PL__close(handle) < 0)
|
||||
HDONE_ERROR(H5E_PLUGIN, H5E_CLOSEERROR, FAIL, "can't close dynamic library")
|
||||
|
||||
|
@ -689,7 +689,7 @@ H5PL__find_plugin_in_path(const H5PL_search_params_t *search_params, hbool_t *fo
|
||||
continue;
|
||||
|
||||
/* attempt to open the dynamic library as a filter library */
|
||||
if (H5PL__open(path, search_params->type, search_params->id, found, plugin_info) < 0)
|
||||
if (H5PL__open(path, search_params->type, search_params->key, found, plugin_info) < 0)
|
||||
HGOTO_ERROR(H5E_PLUGIN, H5E_CANTGET, FAIL, "search in directory failed")
|
||||
if (*found)
|
||||
HGOTO_DONE(SUCCEED)
|
||||
@ -755,7 +755,7 @@ H5PL__find_plugin_in_path(const H5PL_search_params_t *search_params, hbool_t *fo
|
||||
continue;
|
||||
|
||||
/* attempt to open the dynamic library as a filter library */
|
||||
if (H5PL__open(path, search_params->type, search_params->id, found, plugin_info) < 0)
|
||||
if (H5PL__open(path, search_params->type, search_params->key, found, plugin_info) < 0)
|
||||
HGOTO_ERROR(H5E_PLUGIN, H5E_CANTGET, FAIL, "search in directory failed")
|
||||
if (*found)
|
||||
HGOTO_DONE(SUCCEED)
|
||||
|
@ -115,8 +115,8 @@
|
||||
|
||||
/* Data used to search for plugins */
|
||||
typedef struct H5PL_search_params_t {
|
||||
H5PL_type_t type;
|
||||
int id;
|
||||
H5PL_type_t type;
|
||||
H5PL_key_t key;
|
||||
} H5PL_search_params_t;
|
||||
|
||||
|
||||
@ -134,13 +134,13 @@ H5_DLL herr_t H5PL__get_plugin_control_mask(unsigned int *mask /*out*/);
|
||||
H5_DLL herr_t H5PL__set_plugin_control_mask(unsigned int mask);
|
||||
|
||||
/* Plugin search and manipulation */
|
||||
H5_DLL herr_t H5PL__open(const char *libname, H5PL_type_t type, int id, hbool_t *success /*out*/, const void **plugin_info /*out*/);
|
||||
H5_DLL herr_t H5PL__open(const char *libname, H5PL_type_t type, H5PL_key_t key, hbool_t *success /*out*/, const void **plugin_info /*out*/);
|
||||
H5_DLL herr_t H5PL__close(H5PL_HANDLE handle);
|
||||
|
||||
/* Plugin cache calls */
|
||||
H5_DLL herr_t H5PL__create_plugin_cache(void);
|
||||
H5_DLL herr_t H5PL__close_plugin_cache(hbool_t *already_closed /*out*/);
|
||||
H5_DLL herr_t H5PL__add_plugin(H5PL_type_t type, int id, H5PL_HANDLE handle);
|
||||
H5_DLL herr_t H5PL__add_plugin(H5PL_type_t type, H5PL_key_t key, H5PL_HANDLE handle);
|
||||
H5_DLL herr_t H5PL__find_plugin_in_cache(const H5PL_search_params_t *search_params, hbool_t *found /*out*/, const void **plugin_info /*out*/);
|
||||
|
||||
/* Plugin search path calls */
|
||||
|
@ -56,9 +56,9 @@
|
||||
|
||||
/* Type for the list of info for opened plugin libraries */
|
||||
typedef struct H5PL_plugin_t {
|
||||
H5PL_type_t type; /* Plugin type */
|
||||
int id; /* ID for the plugin */
|
||||
H5PL_HANDLE handle; /* Plugin handle */
|
||||
H5PL_type_t type; /* Plugin type */
|
||||
H5PL_key_t key; /* Unique key to identify the plugin */
|
||||
H5PL_HANDLE handle; /* Plugin handle */
|
||||
} H5PL_plugin_t;
|
||||
|
||||
|
||||
@ -209,14 +209,14 @@ done:
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: H5PL__add_plugin
|
||||
*
|
||||
* Purpose: Add a plugin to the plugin cached.
|
||||
* Purpose: Add a plugin to the plugin cache.
|
||||
*
|
||||
* Return: SUCCEED/FAIL
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
herr_t
|
||||
H5PL__add_plugin(H5PL_type_t type, int id, H5PL_HANDLE handle)
|
||||
H5PL__add_plugin(H5PL_type_t type, H5PL_key_t key, H5PL_HANDLE handle)
|
||||
{
|
||||
herr_t ret_value = SUCCEED;
|
||||
|
||||
@ -229,7 +229,7 @@ H5PL__add_plugin(H5PL_type_t type, int id, H5PL_HANDLE handle)
|
||||
|
||||
/* Store the plugin info and bump the # of plugins */
|
||||
H5PL_cache_g[H5PL_num_plugins_g].type = type;
|
||||
H5PL_cache_g[H5PL_num_plugins_g].id = id;
|
||||
H5PL_cache_g[H5PL_num_plugins_g].key = key;
|
||||
H5PL_cache_g[H5PL_num_plugins_g].handle = handle;
|
||||
|
||||
H5PL_num_plugins_g++;
|
||||
@ -276,7 +276,7 @@ H5PL__find_plugin_in_cache(const H5PL_search_params_t *search_params, hbool_t *f
|
||||
for (u = 0; u < H5PL_num_plugins_g; u++) {
|
||||
|
||||
/* If the plugin type (filter, etc.) and ID match, query the plugin for its info */
|
||||
if ((search_params->type == (H5PL_cache_g[u]).type) && (search_params->id == (H5PL_cache_g[u]).id)) {
|
||||
if ((search_params->type == (H5PL_cache_g[u]).type) && (search_params->key.id == (H5PL_cache_g[u]).key.id)) {
|
||||
|
||||
H5PL_get_plugin_info_t get_plugin_info_function;
|
||||
const H5Z_class2_t *filter_info;
|
||||
|
@ -33,6 +33,11 @@
|
||||
/* Library Private Typedefs */
|
||||
/****************************/
|
||||
|
||||
/* The key that will be used to find the plugin */
|
||||
typedef union H5PL_key_t {
|
||||
int id; /* filters */
|
||||
} H5PL_key_t;
|
||||
|
||||
|
||||
/*****************************/
|
||||
/* Library-private Variables */
|
||||
@ -44,7 +49,7 @@
|
||||
/***************************************/
|
||||
|
||||
/* Internal API routines */
|
||||
H5_DLL const void *H5PL_load(H5PL_type_t plugin_type, int type_id);
|
||||
H5_DLL const void *H5PL_load(H5PL_type_t plugin_type, H5PL_key_t key);
|
||||
|
||||
#endif /* _H5PLprivate_H */
|
||||
|
||||
|
@ -30,9 +30,9 @@
|
||||
|
||||
/* Plugin type used by the plugin library */
|
||||
typedef enum H5PL_type_t {
|
||||
H5PL_TYPE_ERROR = -1, /* Error */
|
||||
H5PL_TYPE_FILTER = 0, /* Filter */
|
||||
H5PL_TYPE_NONE = 1 /* This must be last! */
|
||||
H5PL_TYPE_ERROR = -1, /* Error */
|
||||
H5PL_TYPE_FILTER = 0, /* Filter */
|
||||
H5PL_TYPE_NONE = 1 /* This must be last! */
|
||||
} H5PL_type_t;
|
||||
|
||||
/* Common dynamic plugin type flags used by the set/get_loading_state functions */
|
||||
|
765
src/H5R.c
765
src/H5R.c
@ -21,16 +21,13 @@
|
||||
/***********/
|
||||
/* Headers */
|
||||
/***********/
|
||||
#include "H5private.h" /* Generic Functions */
|
||||
#include "H5ACprivate.h" /* Metadata cache */
|
||||
#include "H5Dprivate.h" /* Datasets */
|
||||
#include "H5Eprivate.h" /* Error handling */
|
||||
#include "H5Gprivate.h" /* Groups */
|
||||
#include "H5HGprivate.h" /* Global Heaps */
|
||||
#include "H5Iprivate.h" /* IDs */
|
||||
#include "H5MMprivate.h" /* Memory management */
|
||||
#include "H5Rpkg.h" /* References */
|
||||
#include "H5Sprivate.h" /* Dataspaces */
|
||||
#include "H5private.h" /* Generic Functions */
|
||||
#include "H5ACprivate.h" /* Metadata cache */
|
||||
#include "H5Eprivate.h" /* Error handling */
|
||||
#include "H5Gprivate.h" /* Groups */
|
||||
#include "H5Iprivate.h" /* IDs */
|
||||
#include "H5Rpkg.h" /* References */
|
||||
#include "H5Sprivate.h" /* Dataspaces */
|
||||
|
||||
|
||||
/****************/
|
||||
@ -47,20 +44,11 @@
|
||||
/* Local Prototypes */
|
||||
/********************/
|
||||
|
||||
static herr_t H5R_create(void *ref, H5G_loc_t *loc, const char *name,
|
||||
H5R_type_t ref_type, H5S_t *space, hid_t dxpl_id);
|
||||
static H5S_t * H5R_get_region(H5F_t *file, hid_t dxpl_id, const void *_ref);
|
||||
static ssize_t H5R_get_name(H5F_t *file, hid_t lapl_id, hid_t dxpl_id, hid_t id,
|
||||
H5R_type_t ref_type, const void *_ref, char *name, size_t size);
|
||||
|
||||
|
||||
/*********************/
|
||||
/* Package Variables */
|
||||
/*********************/
|
||||
|
||||
/* Package initialization variable */
|
||||
hbool_t H5_PKG_INIT_VAR = FALSE;
|
||||
|
||||
|
||||
/*****************************/
|
||||
/* Library Private Variables */
|
||||
@ -71,274 +59,6 @@ hbool_t H5_PKG_INIT_VAR = FALSE;
|
||||
/* Local Variables */
|
||||
/*******************/
|
||||
|
||||
/* Reference ID class */
|
||||
static const H5I_class_t H5I_REFERENCE_CLS[1] = {{
|
||||
H5I_REFERENCE, /* ID class value */
|
||||
0, /* Class flags */
|
||||
0, /* # of reserved IDs for class */
|
||||
NULL /* Callback routine for closing objects of this class */
|
||||
}};
|
||||
|
||||
/* Flag indicating "top" of interface has been initialized */
|
||||
static hbool_t H5R_top_package_initialize_s = FALSE;
|
||||
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R__init_package -- Initialize interface-specific information
|
||||
USAGE
|
||||
herr_t H5R__init_package()
|
||||
|
||||
RETURNS
|
||||
Non-negative on success/Negative on failure
|
||||
DESCRIPTION
|
||||
Initializes any interface-specific data or routines.
|
||||
|
||||
--------------------------------------------------------------------------*/
|
||||
herr_t
|
||||
H5R__init_package(void)
|
||||
{
|
||||
herr_t ret_value = SUCCEED; /* Return value */
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT
|
||||
|
||||
/* Initialize the atom group for the file IDs */
|
||||
if(H5I_register_type(H5I_REFERENCE_CLS) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTINIT, FAIL, "unable to initialize interface")
|
||||
|
||||
/* Mark "top" of interface as initialized, too */
|
||||
H5R_top_package_initialize_s = TRUE;
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5R__init_package() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R_top_term_package
|
||||
PURPOSE
|
||||
Terminate various H5R objects
|
||||
USAGE
|
||||
void H5R_top_term_package()
|
||||
RETURNS
|
||||
void
|
||||
DESCRIPTION
|
||||
Release IDs for the atom group, deferring full interface shutdown
|
||||
until later (in H5R_term_package).
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
Can't report errors...
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
--------------------------------------------------------------------------*/
|
||||
int
|
||||
H5R_top_term_package(void)
|
||||
{
|
||||
int n = 0;
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT_NOERR
|
||||
|
||||
if(H5R_top_package_initialize_s) {
|
||||
if(H5I_nmembers(H5I_REFERENCE) > 0) {
|
||||
(void)H5I_clear_type(H5I_REFERENCE, FALSE, FALSE);
|
||||
n++; /*H5I*/
|
||||
} /* end if */
|
||||
|
||||
/* Mark closed */
|
||||
if(0 == n)
|
||||
H5R_top_package_initialize_s = FALSE;
|
||||
} /* end if */
|
||||
|
||||
FUNC_LEAVE_NOAPI(n)
|
||||
} /* end H5R_top_term_package() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R_term_package
|
||||
PURPOSE
|
||||
Terminate various H5R objects
|
||||
USAGE
|
||||
void H5R_term_package()
|
||||
RETURNS
|
||||
void
|
||||
DESCRIPTION
|
||||
Release the atom group and any other resources allocated.
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
Can't report errors...
|
||||
|
||||
Finishes shutting down the interface, after H5R_top_term_package()
|
||||
is called
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
--------------------------------------------------------------------------*/
|
||||
int
|
||||
H5R_term_package(void)
|
||||
{
|
||||
int n = 0;
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT_NOERR
|
||||
|
||||
if(H5_PKG_INIT_VAR) {
|
||||
/* Sanity checks */
|
||||
HDassert(0 == H5I_nmembers(H5I_REFERENCE));
|
||||
HDassert(FALSE == H5R_top_package_initialize_s);
|
||||
|
||||
/* Destroy the reference id group */
|
||||
n += (H5I_dec_type_ref(H5I_REFERENCE) > 0);
|
||||
|
||||
/* Mark closed */
|
||||
if(0 == n)
|
||||
H5_PKG_INIT_VAR = FALSE;
|
||||
} /* end if */
|
||||
|
||||
FUNC_LEAVE_NOAPI(n)
|
||||
} /* end H5R_term_package() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R_create
|
||||
PURPOSE
|
||||
Creates a particular kind of reference for the user
|
||||
USAGE
|
||||
herr_t H5R_create(ref, loc, name, ref_type, space)
|
||||
void *ref; OUT: Reference created
|
||||
H5G_loc_t *loc; IN: File location used to locate object pointed to
|
||||
const char *name; IN: Name of object at location LOC_ID of object
|
||||
pointed to
|
||||
H5R_type_t ref_type; IN: Type of reference to create
|
||||
H5S_t *space; IN: Dataspace ID with selection, used for Dataset
|
||||
Region references.
|
||||
|
||||
RETURNS
|
||||
Non-negative on success/Negative on failure
|
||||
DESCRIPTION
|
||||
Creates a particular type of reference specified with REF_TYPE, in the
|
||||
space pointed to by REF. The LOC_ID and NAME are used to locate the object
|
||||
pointed to and the SPACE_ID is used to choose the region pointed to (for
|
||||
Dataset Region references).
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
--------------------------------------------------------------------------*/
|
||||
static herr_t
|
||||
H5R_create(void *_ref, H5G_loc_t *loc, const char *name, H5R_type_t ref_type, H5S_t *space, hid_t dxpl_id)
|
||||
{
|
||||
H5G_loc_t obj_loc; /* Group hier. location of object */
|
||||
H5G_name_t path; /* Object group hier. path */
|
||||
H5O_loc_t oloc; /* Object object location */
|
||||
hbool_t obj_found = FALSE; /* Object location found */
|
||||
herr_t ret_value = SUCCEED; /* Return value */
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT
|
||||
|
||||
HDassert(_ref);
|
||||
HDassert(loc);
|
||||
HDassert(name);
|
||||
HDassert(ref_type > H5R_BADTYPE && ref_type < H5R_MAXTYPE);
|
||||
|
||||
/* Set up object location to fill in */
|
||||
obj_loc.oloc = &oloc;
|
||||
obj_loc.path = &path;
|
||||
H5G_loc_reset(&obj_loc);
|
||||
|
||||
/* Find the object */
|
||||
if(H5G_loc_find(loc, name, &obj_loc, H5P_DEFAULT, dxpl_id) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_NOTFOUND, FAIL, "object not found")
|
||||
obj_found = TRUE;
|
||||
|
||||
switch(ref_type) {
|
||||
case H5R_OBJECT:
|
||||
{
|
||||
hobj_ref_t *ref = (hobj_ref_t *)_ref; /* Get pointer to correct type of reference struct */
|
||||
|
||||
*ref = obj_loc.oloc->addr;
|
||||
break;
|
||||
}
|
||||
|
||||
case H5R_DATASET_REGION:
|
||||
{
|
||||
H5HG_t hobjid; /* Heap object ID */
|
||||
hdset_reg_ref_t *ref = (hdset_reg_ref_t *)_ref; /* Get pointer to correct type of reference struct */
|
||||
hssize_t buf_size; /* Size of buffer needed to serialize selection */
|
||||
uint8_t *p; /* Pointer to OID to store */
|
||||
uint8_t *buf; /* Buffer to store serialized selection in */
|
||||
unsigned heapid_found; /* Flag for non-zero heap ID found */
|
||||
unsigned u; /* local index */
|
||||
|
||||
/* Set up information for dataset region */
|
||||
|
||||
/* Return any previous heap block to the free list if we are garbage collecting */
|
||||
if(H5F_GC_REF(loc->oloc->file)) {
|
||||
/* Check for an existing heap ID in the reference */
|
||||
for(u = 0, heapid_found = 0, p = (uint8_t *)ref; u < H5R_DSET_REG_REF_BUF_SIZE; u++)
|
||||
if(p[u] != 0) {
|
||||
heapid_found = 1;
|
||||
break;
|
||||
} /* end if */
|
||||
|
||||
if(heapid_found != 0) {
|
||||
/* Return heap block to free list */
|
||||
} /* end if */
|
||||
} /* end if */
|
||||
|
||||
/* Zero the heap ID out, may leak heap space if user is re-using reference and doesn't have garbage collection on */
|
||||
HDmemset(ref, 0, H5R_DSET_REG_REF_BUF_SIZE);
|
||||
|
||||
/* Get the amount of space required to serialize the selection */
|
||||
if((buf_size = H5S_SELECT_SERIAL_SIZE(space)) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTINIT, FAIL, "Invalid amount of space for serializing selection")
|
||||
|
||||
/* Increase buffer size to allow for the dataset OID */
|
||||
buf_size += (hssize_t)sizeof(haddr_t);
|
||||
|
||||
/* Allocate the space to store the serialized information */
|
||||
H5_CHECK_OVERFLOW(buf_size, hssize_t, size_t);
|
||||
if(NULL == (buf = (uint8_t *)H5MM_malloc((size_t)buf_size)))
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, FAIL, "memory allocation failed")
|
||||
|
||||
/* Serialize information for dataset OID into heap buffer */
|
||||
p = (uint8_t *)buf;
|
||||
H5F_addr_encode(loc->oloc->file, &p, obj_loc.oloc->addr);
|
||||
|
||||
/* Serialize the selection into heap buffer */
|
||||
if(H5S_SELECT_SERIALIZE(space, &p) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTCOPY, FAIL, "Unable to serialize selection")
|
||||
|
||||
/* Save the serialized buffer for later */
|
||||
H5_CHECK_OVERFLOW(buf_size, hssize_t, size_t);
|
||||
if(H5HG_insert(loc->oloc->file, dxpl_id, (size_t)buf_size, buf, &hobjid) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_WRITEERROR, FAIL, "Unable to serialize selection")
|
||||
|
||||
/* Serialize the heap ID and index for storage in the file */
|
||||
p = (uint8_t *)ref;
|
||||
H5F_addr_encode(loc->oloc->file, &p, hobjid.addr);
|
||||
UINT32ENCODE(p, hobjid.idx);
|
||||
|
||||
/* Free the buffer we serialized data in */
|
||||
H5MM_xfree(buf);
|
||||
break;
|
||||
}
|
||||
|
||||
case H5R_BADTYPE:
|
||||
case H5R_MAXTYPE:
|
||||
default:
|
||||
HDassert("unknown reference type" && 0);
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_UNSUPPORTED, FAIL, "internal error (unknown reference type)")
|
||||
} /* end switch */
|
||||
|
||||
done:
|
||||
if(obj_found)
|
||||
H5G_loc_free(&obj_loc);
|
||||
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5R_create() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
@ -378,189 +98,29 @@ H5Rcreate(void *ref, hid_t loc_id, const char *name, H5R_type_t ref_type, hid_t
|
||||
H5TRACE5("e", "*xi*sRti", ref, loc_id, name, ref_type, space_id);
|
||||
|
||||
/* Check args */
|
||||
if(ref == NULL)
|
||||
if (ref == NULL)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid reference pointer")
|
||||
if(H5G_loc(loc_id, &loc) < 0)
|
||||
if (H5G_loc(loc_id, &loc) < 0)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, FAIL, "not a location")
|
||||
if(!name || !*name)
|
||||
if (!name || !*name)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "no name given")
|
||||
if(ref_type <= H5R_BADTYPE || ref_type >= H5R_MAXTYPE)
|
||||
if (ref_type <= H5R_BADTYPE || ref_type >= H5R_MAXTYPE)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid reference type")
|
||||
if(ref_type != H5R_OBJECT && ref_type != H5R_DATASET_REGION)
|
||||
if (ref_type != H5R_OBJECT && ref_type != H5R_DATASET_REGION)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_UNSUPPORTED, FAIL, "reference type not supported")
|
||||
if(space_id == (-1) && ref_type == H5R_DATASET_REGION)
|
||||
if (space_id == (-1) && ref_type == H5R_DATASET_REGION)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "reference region dataspace id must be valid")
|
||||
if(space_id != (-1) && (NULL == (space = (H5S_t *)H5I_object_verify(space_id, H5I_DATASPACE))))
|
||||
if (space_id != (-1) && (NULL == (space = (H5S_t *)H5I_object_verify(space_id, H5I_DATASPACE))))
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, FAIL, "not a dataspace")
|
||||
|
||||
/* Create reference */
|
||||
if((ret_value = H5R_create(ref, &loc, name, ref_type, space, H5AC_ind_read_dxpl_id)) < 0)
|
||||
if ((ret_value = H5R_create(ref, &loc, name, ref_type, space, H5AC_ind_read_dxpl_id)) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTINIT, FAIL, "unable to create reference")
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_API(ret_value)
|
||||
} /* end H5Rcreate() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R_dereference
|
||||
PURPOSE
|
||||
Opens the HDF5 object referenced.
|
||||
USAGE
|
||||
hid_t H5R_dereference(ref)
|
||||
H5F_t *file; IN: File the object being dereferenced is within
|
||||
H5R_type_t ref_type; IN: Type of reference
|
||||
void *ref; IN: Reference to open.
|
||||
|
||||
RETURNS
|
||||
Valid ID on success, Negative on failure
|
||||
DESCRIPTION
|
||||
Given a reference to some object, open that object and return an ID for
|
||||
that object.
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
Currently only set up to work with references to datasets
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
Raymond Lu
|
||||
13 July 2011
|
||||
I added the OAPL_ID parameter for the object being referenced. It only
|
||||
supports dataset access property list currently.
|
||||
|
||||
M. Scot Breitenfeld
|
||||
3 March 2015
|
||||
Added a check for undefined reference pointer.
|
||||
--------------------------------------------------------------------------*/
|
||||
hid_t
|
||||
H5R_dereference(H5F_t *file, hid_t oapl_id, hid_t dxpl_id, H5R_type_t ref_type, const void *_ref, hbool_t app_ref)
|
||||
{
|
||||
H5O_loc_t oloc; /* Object location */
|
||||
H5G_name_t path; /* Path of object */
|
||||
H5G_loc_t loc; /* Group location */
|
||||
unsigned rc; /* Reference count of object */
|
||||
H5O_type_t obj_type; /* Type of object */
|
||||
hid_t ret_value = H5I_INVALID_HID; /* Return value */
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT
|
||||
|
||||
HDassert(_ref);
|
||||
HDassert(ref_type > H5R_BADTYPE && ref_type < H5R_MAXTYPE);
|
||||
HDassert(file);
|
||||
|
||||
/* Initialize the object location */
|
||||
H5O_loc_reset(&oloc);
|
||||
oloc.file = file;
|
||||
|
||||
switch(ref_type) {
|
||||
case H5R_OBJECT:
|
||||
oloc.addr = *(const hobj_ref_t *)_ref; /* Only object references currently supported */
|
||||
if(!H5F_addr_defined(oloc.addr) || oloc.addr == 0)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "Undefined reference pointer")
|
||||
break;
|
||||
|
||||
case H5R_DATASET_REGION:
|
||||
{
|
||||
H5HG_t hobjid; /* Heap object ID */
|
||||
uint8_t *buf; /* Buffer to store serialized selection in */
|
||||
const uint8_t *p; /* Pointer to OID to store */
|
||||
|
||||
/* Get the heap ID for the dataset region */
|
||||
p = (const uint8_t *)_ref;
|
||||
H5F_addr_decode(oloc.file, &p, &(hobjid.addr));
|
||||
UINT32DECODE(p, hobjid.idx);
|
||||
|
||||
if(!H5F_addr_defined(hobjid.addr) || hobjid.addr == 0)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "Undefined reference pointer")
|
||||
|
||||
/* Get the dataset region from the heap (allocate inside routine) */
|
||||
if(NULL == (buf = (uint8_t *)H5HG_read(oloc.file, dxpl_id, &hobjid, NULL, NULL)))
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_READERROR, FAIL, "Unable to read dataset region information")
|
||||
|
||||
/* Get the object oid for the dataset */
|
||||
p = buf;
|
||||
H5F_addr_decode(oloc.file, &p, &(oloc.addr));
|
||||
|
||||
/* Free the buffer allocated in H5HG_read() */
|
||||
H5MM_xfree(buf);
|
||||
} /* end case */
|
||||
break;
|
||||
|
||||
case H5R_BADTYPE:
|
||||
case H5R_MAXTYPE:
|
||||
default:
|
||||
HDassert("unknown reference type" && 0);
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_UNSUPPORTED, FAIL, "internal error (unknown reference type)")
|
||||
} /* end switch */
|
||||
|
||||
/* Get the # of links for object, and its type */
|
||||
/* (To check to make certain that this object hasn't been deleted since the reference was created) */
|
||||
if(H5O_get_rc_and_type(&oloc, dxpl_id, &rc, &obj_type) < 0 || 0 == rc)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_LINKCOUNT, FAIL, "dereferencing deleted object")
|
||||
|
||||
/* Construct a group location for opening the object */
|
||||
H5G_name_reset(&path);
|
||||
loc.oloc = &oloc;
|
||||
loc.path = &path;
|
||||
|
||||
/* Open the object */
|
||||
switch(obj_type) {
|
||||
case H5O_TYPE_GROUP:
|
||||
{
|
||||
H5G_t *group; /* Pointer to group to open */
|
||||
|
||||
if(NULL == (group = H5G_open(&loc, dxpl_id)))
|
||||
HGOTO_ERROR(H5E_SYM, H5E_NOTFOUND, FAIL, "not found")
|
||||
|
||||
/* Create an atom for the group */
|
||||
if((ret_value = H5I_register(H5I_GROUP, group, app_ref)) < 0) {
|
||||
H5G_close(group);
|
||||
HGOTO_ERROR(H5E_SYM, H5E_CANTREGISTER, FAIL, "can't register group")
|
||||
} /* end if */
|
||||
} /* end case */
|
||||
break;
|
||||
|
||||
case H5O_TYPE_NAMED_DATATYPE:
|
||||
{
|
||||
H5T_t *type; /* Pointer to datatype to open */
|
||||
|
||||
if(NULL == (type = H5T_open(&loc, dxpl_id)))
|
||||
HGOTO_ERROR(H5E_DATATYPE, H5E_NOTFOUND, FAIL, "not found")
|
||||
|
||||
/* Create an atom for the datatype */
|
||||
if((ret_value = H5I_register(H5I_DATATYPE, type, app_ref)) < 0) {
|
||||
H5T_close(type);
|
||||
HGOTO_ERROR(H5E_DATATYPE, H5E_CANTREGISTER, FAIL, "can't register datatype")
|
||||
} /* end if */
|
||||
} /* end case */
|
||||
break;
|
||||
|
||||
case H5O_TYPE_DATASET:
|
||||
{
|
||||
H5D_t *dset; /* Pointer to dataset to open */
|
||||
|
||||
/* Open the dataset */
|
||||
if(NULL == (dset = H5D_open(&loc, oapl_id, dxpl_id)))
|
||||
HGOTO_ERROR(H5E_DATASET, H5E_NOTFOUND, FAIL, "not found")
|
||||
|
||||
/* Create an atom for the dataset */
|
||||
if((ret_value = H5I_register(H5I_DATASET, dset, app_ref)) < 0) {
|
||||
H5D_close(dset);
|
||||
HGOTO_ERROR(H5E_DATASET, H5E_CANTREGISTER, FAIL, "can't register dataset")
|
||||
} /* end if */
|
||||
} /* end case */
|
||||
break;
|
||||
|
||||
case H5O_TYPE_UNKNOWN:
|
||||
case H5O_TYPE_NTYPES:
|
||||
default:
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_BADTYPE, FAIL, "can't identify type of object referenced")
|
||||
} /* end switch */
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5R_dereference() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
@ -601,99 +161,30 @@ H5Rdereference2(hid_t obj_id, hid_t oapl_id, H5R_type_t ref_type, const void *_r
|
||||
H5TRACE4("i", "iiRt*x", obj_id, oapl_id, ref_type, _ref);
|
||||
|
||||
/* Check args */
|
||||
if(H5G_loc(obj_id, &loc) < 0)
|
||||
if (H5G_loc(obj_id, &loc) < 0)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, FAIL, "not a location")
|
||||
if(oapl_id < 0)
|
||||
if (oapl_id < 0)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, FAIL, "not a property list")
|
||||
if(ref_type <= H5R_BADTYPE || ref_type >= H5R_MAXTYPE)
|
||||
if (ref_type <= H5R_BADTYPE || ref_type >= H5R_MAXTYPE)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid reference type")
|
||||
if(_ref == NULL)
|
||||
if (_ref == NULL)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid reference pointer")
|
||||
|
||||
/* Verify access property list and get correct dxpl */
|
||||
if(H5P_verify_apl_and_dxpl(&oapl_id, H5P_CLS_DACC, &dxpl_id, obj_id, FALSE) < 0)
|
||||
if (H5P_verify_apl_and_dxpl(&oapl_id, H5P_CLS_DACC, &dxpl_id, obj_id, FALSE) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTSET, FAIL, "can't set access and transfer property lists")
|
||||
|
||||
/* Get the file pointer from the entry */
|
||||
file = loc.oloc->file;
|
||||
|
||||
/* Create reference */
|
||||
if((ret_value = H5R_dereference(file, oapl_id, dxpl_id, ref_type, _ref, TRUE)) < 0)
|
||||
if ((ret_value = H5R_dereference(file, oapl_id, dxpl_id, ref_type, _ref, TRUE)) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTINIT, FAIL, "unable to dereference object")
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_API(ret_value)
|
||||
} /* end H5Rdereference2() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R_get_region
|
||||
PURPOSE
|
||||
Retrieves a dataspace with the region pointed to selected.
|
||||
USAGE
|
||||
H5S_t *H5R_get_region(file, ref_type, ref)
|
||||
H5F_t *file; IN: File the object being dereferenced is within
|
||||
void *ref; IN: Reference to open.
|
||||
|
||||
RETURNS
|
||||
Pointer to the dataspace on success, NULL on failure
|
||||
DESCRIPTION
|
||||
Given a reference to some object, creates a copy of the dataset pointed
|
||||
to's dataspace and defines a selection in the copy which is the region
|
||||
pointed to.
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
--------------------------------------------------------------------------*/
|
||||
static H5S_t *
|
||||
H5R_get_region(H5F_t *file, hid_t dxpl_id, const void *_ref)
|
||||
{
|
||||
H5O_loc_t oloc; /* Object location */
|
||||
const uint8_t *p; /* Pointer to OID to store */
|
||||
H5HG_t hobjid; /* Heap object ID */
|
||||
uint8_t *buf = NULL; /* Buffer to store serialized selection in */
|
||||
H5S_t *ret_value;
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT
|
||||
|
||||
HDassert(_ref);
|
||||
HDassert(file);
|
||||
|
||||
/* Initialize the object location */
|
||||
H5O_loc_reset(&oloc);
|
||||
oloc.file = file;
|
||||
|
||||
/* Get the heap ID for the dataset region */
|
||||
p = (const uint8_t *)_ref;
|
||||
H5F_addr_decode(oloc.file, &p, &(hobjid.addr));
|
||||
UINT32DECODE(p, hobjid.idx);
|
||||
|
||||
/* Get the dataset region from the heap (allocate inside routine) */
|
||||
if((buf = (uint8_t *)H5HG_read(oloc.file, dxpl_id, &hobjid, NULL, NULL)) == NULL)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_READERROR, NULL, "Unable to read dataset region information")
|
||||
|
||||
/* Get the object oid for the dataset */
|
||||
p = buf;
|
||||
H5F_addr_decode(oloc.file, &p, &(oloc.addr));
|
||||
|
||||
/* Open and copy the dataset's dataspace */
|
||||
if((ret_value = H5S_read(&oloc, dxpl_id)) == NULL)
|
||||
HGOTO_ERROR(H5E_DATASPACE, H5E_NOTFOUND, NULL, "not found")
|
||||
|
||||
/* Unserialize the selection */
|
||||
if(H5S_SELECT_DESERIALIZE(&ret_value, &p) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTDECODE, NULL, "can't deserialize selection")
|
||||
|
||||
done:
|
||||
/* Free the buffer allocated in H5HG_read() */
|
||||
if(buf)
|
||||
H5MM_xfree(buf);
|
||||
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5R_get_region() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
@ -729,111 +220,25 @@ H5Rget_region(hid_t id, H5R_type_t ref_type, const void *ref)
|
||||
H5TRACE3("i", "iRt*x", id, ref_type, ref);
|
||||
|
||||
/* Check args */
|
||||
if(H5G_loc(id, &loc) < 0)
|
||||
if (H5G_loc(id, &loc) < 0)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, FAIL, "not a location")
|
||||
if(ref_type != H5R_DATASET_REGION)
|
||||
if (ref_type != H5R_DATASET_REGION)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid reference type")
|
||||
if(ref == NULL)
|
||||
if (ref == NULL)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid reference pointer")
|
||||
|
||||
/* Get the dataspace with the correct region selected */
|
||||
if((space = H5R_get_region(loc.oloc->file, H5AC_ind_read_dxpl_id, ref)) == NULL)
|
||||
if ((space = H5R_get_region(loc.oloc->file, H5AC_ind_read_dxpl_id, ref)) == NULL)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTCREATE, FAIL, "unable to create dataspace")
|
||||
|
||||
/* Atomize */
|
||||
if((ret_value = H5I_register(H5I_DATASPACE, space, TRUE)) < 0)
|
||||
if ((ret_value = H5I_register(H5I_DATASPACE, space, TRUE)) < 0)
|
||||
HGOTO_ERROR(H5E_ATOM, H5E_CANTREGISTER, FAIL, "unable to register dataspace atom")
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_API(ret_value)
|
||||
} /* end H5Rget_region() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R_get_obj_type
|
||||
PURPOSE
|
||||
Retrieves the type of object that an object reference points to
|
||||
USAGE
|
||||
H5O_type_t H5R_get_obj_type(file, ref_type, ref)
|
||||
H5F_t *file; IN: File the object being dereferenced is within
|
||||
H5R_type_t ref_type; IN: Type of reference to query
|
||||
void *ref; IN: Reference to query.
|
||||
|
||||
RETURNS
|
||||
Success: An object type defined in H5Gpublic.h
|
||||
Failure: H5G_UNKNOWN
|
||||
DESCRIPTION
|
||||
Given a reference to some object, this function returns the type of object
|
||||
pointed to.
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
--------------------------------------------------------------------------*/
|
||||
herr_t
|
||||
H5R_get_obj_type(H5F_t *file, hid_t dxpl_id, H5R_type_t ref_type,
|
||||
const void *_ref, H5O_type_t *obj_type)
|
||||
{
|
||||
H5O_loc_t oloc; /* Object location */
|
||||
unsigned rc; /* Reference count of object */
|
||||
herr_t ret_value = SUCCEED; /* Return value */
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT
|
||||
|
||||
HDassert(file);
|
||||
HDassert(_ref);
|
||||
|
||||
/* Initialize the symbol table entry */
|
||||
H5O_loc_reset(&oloc);
|
||||
oloc.file = file;
|
||||
|
||||
switch(ref_type) {
|
||||
case H5R_OBJECT:
|
||||
/* Get the object oid */
|
||||
oloc.addr = *(const hobj_ref_t *)_ref; /* Only object references currently supported */
|
||||
break;
|
||||
|
||||
case H5R_DATASET_REGION:
|
||||
{
|
||||
H5HG_t hobjid; /* Heap object ID */
|
||||
const uint8_t *p; /* Pointer to reference to decode */
|
||||
uint8_t *buf; /* Buffer to store serialized selection in */
|
||||
|
||||
/* Get the heap ID for the dataset region */
|
||||
p = (const uint8_t *)_ref;
|
||||
H5F_addr_decode(oloc.file, &p, &(hobjid.addr));
|
||||
UINT32DECODE(p, hobjid.idx);
|
||||
|
||||
/* Get the dataset region from the heap (allocate inside routine) */
|
||||
if((buf = (uint8_t *)H5HG_read(oloc.file, dxpl_id, &hobjid, NULL, NULL)) == NULL)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_READERROR, FAIL, "Unable to read dataset region information")
|
||||
|
||||
/* Get the object oid for the dataset */
|
||||
p = buf;
|
||||
H5F_addr_decode(oloc.file, &p, &(oloc.addr));
|
||||
|
||||
/* Free the buffer allocated in H5HG_read() */
|
||||
H5MM_xfree(buf);
|
||||
} /* end case */
|
||||
break;
|
||||
|
||||
case H5R_BADTYPE:
|
||||
case H5R_MAXTYPE:
|
||||
default:
|
||||
HDassert("unknown reference type" && 0);
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_UNSUPPORTED, FAIL, "internal error (unknown reference type)")
|
||||
} /* end switch */
|
||||
|
||||
/* Get the # of links for object, and its type */
|
||||
/* (To check to make certain that this object hasn't been deleted since the reference was created) */
|
||||
if(H5O_get_rc_and_type(&oloc, dxpl_id, &rc, obj_type) < 0 || 0 == rc)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_LINKCOUNT, FAIL, "dereferencing deleted object")
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5R_get_obj_type() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
@ -869,121 +274,21 @@ H5Rget_obj_type2(hid_t id, H5R_type_t ref_type, const void *ref,
|
||||
H5TRACE4("e", "iRt*x*Ot", id, ref_type, ref, obj_type);
|
||||
|
||||
/* Check args */
|
||||
if(H5G_loc(id, &loc) < 0)
|
||||
if (H5G_loc(id, &loc) < 0)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, FAIL, "not a location")
|
||||
if(ref_type <= H5R_BADTYPE || ref_type >= H5R_MAXTYPE)
|
||||
if (ref_type <= H5R_BADTYPE || ref_type >= H5R_MAXTYPE)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid reference type")
|
||||
if(ref == NULL)
|
||||
if (ref == NULL)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid reference pointer")
|
||||
|
||||
/* Get the object information */
|
||||
if(H5R_get_obj_type(loc.oloc->file, H5AC_ind_read_dxpl_id, ref_type, ref, obj_type) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTINIT, FAIL, "unable to determine object type")
|
||||
if (H5R_get_obj_type(loc.oloc->file, H5AC_ind_read_dxpl_id, ref_type, ref, obj_type) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTINIT, FAIL, "unable to determine object type")
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_API(ret_value)
|
||||
} /* end H5Rget_obj_type2() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R_get_name
|
||||
PURPOSE
|
||||
Internal routine to determine a name for the object referenced
|
||||
USAGE
|
||||
ssize_t H5R_get_name(f, dxpl_id, ref_type, ref, name, size)
|
||||
H5F_t *f; IN: Pointer to the file that the reference is pointing
|
||||
into
|
||||
hid_t lapl_id; IN: LAPL to use for operation
|
||||
hid_t dxpl_id; IN: DXPL to use for operation
|
||||
hid_t id; IN: Location ID given for reference
|
||||
H5R_type_t ref_type; IN: Type of reference
|
||||
void *ref; IN: Reference to query.
|
||||
char *name; OUT: Buffer to place name of object referenced
|
||||
size_t size; IN: Size of name buffer
|
||||
|
||||
RETURNS
|
||||
Non-negative length of the path on success, Negative on failure
|
||||
DESCRIPTION
|
||||
Given a reference to some object, determine a path to the object
|
||||
referenced in the file.
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
This may not be the only path to that object.
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
--------------------------------------------------------------------------*/
|
||||
static ssize_t
|
||||
H5R_get_name(H5F_t *f, hid_t lapl_id, hid_t dxpl_id, hid_t id, H5R_type_t ref_type,
|
||||
const void *_ref, char *name, size_t size)
|
||||
{
|
||||
hid_t file_id = H5I_INVALID_HID; /* ID for file that the reference is in */
|
||||
H5O_loc_t oloc; /* Object location describing object for reference */
|
||||
ssize_t ret_value = -1; /* Return value */
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT
|
||||
|
||||
/* Check args */
|
||||
HDassert(f);
|
||||
HDassert(_ref);
|
||||
|
||||
/* Initialize the object location */
|
||||
H5O_loc_reset(&oloc);
|
||||
oloc.file = f;
|
||||
|
||||
/* Get address for reference */
|
||||
switch(ref_type) {
|
||||
case H5R_OBJECT:
|
||||
oloc.addr = *(const hobj_ref_t *)_ref;
|
||||
break;
|
||||
|
||||
case H5R_DATASET_REGION:
|
||||
{
|
||||
H5HG_t hobjid; /* Heap object ID */
|
||||
uint8_t *buf; /* Buffer to store serialized selection in */
|
||||
const uint8_t *p; /* Pointer to OID to store */
|
||||
|
||||
/* Get the heap ID for the dataset region */
|
||||
p = (const uint8_t *)_ref;
|
||||
H5F_addr_decode(oloc.file, &p, &(hobjid.addr));
|
||||
UINT32DECODE(p, hobjid.idx);
|
||||
|
||||
/* Get the dataset region from the heap (allocate inside routine) */
|
||||
if((buf = (uint8_t *)H5HG_read(oloc.file, dxpl_id, &hobjid, NULL, NULL)) == NULL)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_READERROR, FAIL, "Unable to read dataset region information")
|
||||
|
||||
/* Get the object oid for the dataset */
|
||||
p = buf;
|
||||
H5F_addr_decode(oloc.file, &p, &(oloc.addr));
|
||||
|
||||
/* Free the buffer allocated in H5HG_read() */
|
||||
H5MM_xfree(buf);
|
||||
} /* end case */
|
||||
break;
|
||||
|
||||
case H5R_BADTYPE:
|
||||
case H5R_MAXTYPE:
|
||||
default:
|
||||
HDassert("unknown reference type" && 0);
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_UNSUPPORTED, FAIL, "internal error (unknown reference type)")
|
||||
} /* end switch */
|
||||
|
||||
/* Retrieve file ID for name search */
|
||||
if((file_id = H5I_get_file_id(id, FALSE)) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTGET, FAIL, "can't retrieve file ID")
|
||||
|
||||
/* Get name, length, etc. */
|
||||
if((ret_value = H5G_get_name_by_addr(file_id, lapl_id, dxpl_id, &oloc, name, size)) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTGET, FAIL, "can't determine name")
|
||||
|
||||
done:
|
||||
/* Close file ID used for search */
|
||||
if(file_id > 0 && H5I_dec_ref(file_id) < 0)
|
||||
HDONE_ERROR(H5E_REFERENCE, H5E_CANTDEC, FAIL, "can't decrement ref count of temp ID")
|
||||
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5R_get_name() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
@ -1030,18 +335,18 @@ H5Rget_name(hid_t id, H5R_type_t ref_type, const void *_ref, char *name,
|
||||
H5TRACE5("Zs", "iRt*x*sz", id, ref_type, _ref, name, size);
|
||||
|
||||
/* Check args */
|
||||
if(H5G_loc(id, &loc) < 0)
|
||||
if (H5G_loc(id, &loc) < 0)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, FAIL, "not a location")
|
||||
if(ref_type <= H5R_BADTYPE || ref_type >= H5R_MAXTYPE)
|
||||
if (ref_type <= H5R_BADTYPE || ref_type >= H5R_MAXTYPE)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid reference type")
|
||||
if(_ref == NULL)
|
||||
if (_ref == NULL)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid reference pointer")
|
||||
|
||||
/* Get the file pointer from the entry */
|
||||
file = loc.oloc->file;
|
||||
|
||||
/* Get name */
|
||||
if((ret_value = H5R_get_name(file, H5P_DEFAULT, H5AC_ind_read_dxpl_id, id, ref_type, _ref, name, size)) < 0)
|
||||
if ((ret_value = H5R_get_name(file, H5P_DEFAULT, H5AC_ind_read_dxpl_id, id, ref_type, _ref, name, size)) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTINIT, FAIL, "unable to determine object path")
|
||||
|
||||
done:
|
||||
|
118
src/H5Rdeprec.c
118
src/H5Rdeprec.c
@ -13,11 +13,9 @@
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
*
|
||||
* Created: H5Rdeprec.c
|
||||
* September 13 2007
|
||||
* Quincey Koziol <koziol@hdfgroup.org>
|
||||
* Created: H5Rdeprec.c
|
||||
*
|
||||
* Purpose: Deprecated functions from the H5R interface. These
|
||||
* Purpose: Deprecated functions from the H5R interface. These
|
||||
* functions are here for compatibility purposes and may be
|
||||
* removed in the future. Applications should switch to the
|
||||
* newer APIs.
|
||||
@ -35,13 +33,16 @@
|
||||
/***********/
|
||||
/* Headers */
|
||||
/***********/
|
||||
#include "H5private.h" /* Generic Functions */
|
||||
#include "H5ACprivate.h" /* Metadata cache */
|
||||
#include "H5Eprivate.h" /* Error handling */
|
||||
#include "H5Gprivate.h" /* Groups */
|
||||
#include "H5Oprivate.h" /* Object headers */
|
||||
#include "H5Rpkg.h" /* References */
|
||||
#include "H5Ppublic.h" /* for using H5P_DATASET_ACCESS_DEFAULT */
|
||||
/* Public headers needed by this file */
|
||||
#include "H5Ppublic.h" /* Property lists */
|
||||
|
||||
/* Private headers needed by this file */
|
||||
#include "H5private.h" /* Generic Functions */
|
||||
#include "H5ACprivate.h" /* Metadata cache */
|
||||
#include "H5Eprivate.h" /* Error handling */
|
||||
#include "H5Gprivate.h" /* Groups */
|
||||
#include "H5Oprivate.h" /* Object headers */
|
||||
#include "H5Rpkg.h" /* References */
|
||||
|
||||
|
||||
/****************/
|
||||
@ -81,29 +82,22 @@
|
||||
|
||||
#ifndef H5_NO_DEPRECATED_SYMBOLS
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5Rget_obj_type1
|
||||
PURPOSE
|
||||
Retrieves the type of object that an object reference points to
|
||||
USAGE
|
||||
H5G_obj_t H5Rget_obj_type1(id, ref_type, ref)
|
||||
hid_t id; IN: Dataset reference object is in or location ID of
|
||||
object that the dataset is located within.
|
||||
H5R_type_t ref_type; IN: Type of reference to query
|
||||
void *ref; IN: Reference to query.
|
||||
|
||||
RETURNS
|
||||
Success: An object type defined in H5Gpublic.h
|
||||
Failure: H5G_UNKNOWN
|
||||
DESCRIPTION
|
||||
Given a reference to some object, this function returns the type of object
|
||||
pointed to.
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
--------------------------------------------------------------------------*/
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: H5Rget_obj_type1
|
||||
*
|
||||
* Purpose: Retrieves the type of the object that an object points to.
|
||||
*
|
||||
* Parameters:
|
||||
* id IN: Dataset reference object is in or location ID of
|
||||
* object that the dataset is located within
|
||||
* ref_type IN: Type of reference to query
|
||||
* ref IN: Reference to query
|
||||
*
|
||||
* Return: Success: An object type (as defined in H5Gpublic.h)
|
||||
* Failure: H5G_UNKNOWN
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
H5G_obj_t
|
||||
H5Rget_obj_type1(hid_t id, H5R_type_t ref_type, const void *ref)
|
||||
{
|
||||
@ -115,16 +109,16 @@ H5Rget_obj_type1(hid_t id, H5R_type_t ref_type, const void *ref)
|
||||
H5TRACE3("Go", "iRt*x", id, ref_type, ref);
|
||||
|
||||
/* Check args */
|
||||
if(H5G_loc(id, &loc) < 0)
|
||||
if (H5G_loc(id, &loc) < 0)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, H5G_UNKNOWN, "not a location")
|
||||
if(ref_type <= H5R_BADTYPE || ref_type >= H5R_MAXTYPE)
|
||||
if (ref_type <= H5R_BADTYPE || ref_type >= H5R_MAXTYPE)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, H5G_UNKNOWN, "invalid reference type")
|
||||
if(ref == NULL)
|
||||
if (ref == NULL)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, H5G_UNKNOWN, "invalid reference pointer")
|
||||
|
||||
/* Get the object information */
|
||||
if(H5R_get_obj_type(loc.oloc->file, H5AC_ind_read_dxpl_id, ref_type, ref, &obj_type) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTINIT, H5G_UNKNOWN, "unable to determine object type")
|
||||
if (H5R_get_obj_type(loc.oloc->file, H5AC_ind_read_dxpl_id, ref_type, ref, &obj_type) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTINIT, H5G_UNKNOWN, "unable to determine object type")
|
||||
|
||||
/* Set return value */
|
||||
ret_value = H5G_map_obj_type(obj_type);
|
||||
@ -134,28 +128,22 @@ done:
|
||||
} /* end H5Rget_obj_type1() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5Rdereference1
|
||||
PURPOSE
|
||||
Opens the HDF5 object referenced.
|
||||
USAGE
|
||||
hid_t H5Rdereference1(ref)
|
||||
hid_t id; IN: Dataset reference object is in or location ID of
|
||||
object that the dataset is located within.
|
||||
H5R_type_t ref_type; IN: Type of reference to create
|
||||
void *ref; IN: Reference to open.
|
||||
|
||||
RETURNS
|
||||
Valid ID on success, Negative on failure
|
||||
DESCRIPTION
|
||||
Given a reference to some object, open that object and return an ID for
|
||||
that object.
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
--------------------------------------------------------------------------*/
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: H5Rdereference1
|
||||
*
|
||||
* Purpose: Opens the HDF5 object referenced.
|
||||
*
|
||||
* Parameters:
|
||||
* id IN: Dataset reference object is in or location ID of
|
||||
* object that the dataset is located within
|
||||
* ref_type IN: Type of reference to create
|
||||
* ref IN: Reference to open
|
||||
*
|
||||
* Return: Success: Valid HDF5 ID
|
||||
* Failure: Negative
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
hid_t
|
||||
H5Rdereference1(hid_t obj_id, H5R_type_t ref_type, const void *_ref)
|
||||
{
|
||||
@ -167,18 +155,18 @@ H5Rdereference1(hid_t obj_id, H5R_type_t ref_type, const void *_ref)
|
||||
H5TRACE3("i", "iRt*x", obj_id, ref_type, _ref);
|
||||
|
||||
/* Check args */
|
||||
if(H5G_loc(obj_id, &loc) < 0)
|
||||
if (H5G_loc(obj_id, &loc) < 0)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, FAIL, "not a location")
|
||||
if(ref_type <= H5R_BADTYPE || ref_type >= H5R_MAXTYPE)
|
||||
if (ref_type <= H5R_BADTYPE || ref_type >= H5R_MAXTYPE)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid reference type")
|
||||
if(_ref == NULL)
|
||||
if (_ref == NULL)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid reference pointer")
|
||||
|
||||
/* Get the file pointer from the entry */
|
||||
file = loc.oloc->file;
|
||||
|
||||
/* Create reference */
|
||||
if((ret_value = H5R_dereference(file, H5P_DATASET_ACCESS_DEFAULT, H5AC_ind_read_dxpl_id, ref_type, _ref, TRUE)) < 0)
|
||||
if ((ret_value = H5R_dereference(file, H5P_DATASET_ACCESS_DEFAULT, H5AC_ind_read_dxpl_id, ref_type, _ref, TRUE)) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTINIT, FAIL, "unable dereference object")
|
||||
|
||||
done:
|
||||
|
767
src/H5Rint.c
Normal file
767
src/H5Rint.c
Normal file
@ -0,0 +1,767 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* Copyright by The HDF Group. *
|
||||
* Copyright by the Board of Trustees of the University of Illinois. *
|
||||
* All rights reserved. *
|
||||
* *
|
||||
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
||||
* terms governing use, modification, and redistribution, is contained in *
|
||||
* the COPYING file, which can be found at the root of the source code *
|
||||
* distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases. *
|
||||
* If you do not have access to either file, you may request a copy from *
|
||||
* help@hdfgroup.org. *
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
/****************/
|
||||
/* Module Setup */
|
||||
/****************/
|
||||
|
||||
#include "H5Rmodule.h" /* This source code file is part of the H5R module */
|
||||
|
||||
|
||||
/***********/
|
||||
/* Headers */
|
||||
/***********/
|
||||
#include "H5private.h" /* Generic Functions */
|
||||
#include "H5ACprivate.h" /* Metadata cache */
|
||||
#include "H5Dprivate.h" /* Datasets */
|
||||
#include "H5Eprivate.h" /* Error handling */
|
||||
#include "H5Gprivate.h" /* Groups */
|
||||
#include "H5HGprivate.h" /* Global Heaps */
|
||||
#include "H5Iprivate.h" /* IDs */
|
||||
#include "H5MMprivate.h" /* Memory management */
|
||||
#include "H5Oprivate.h" /* Object headers */
|
||||
#include "H5Rpkg.h" /* References */
|
||||
#include "H5Sprivate.h" /* Dataspaces */
|
||||
#include "H5Tprivate.h" /* Datatypes */
|
||||
|
||||
|
||||
/****************/
|
||||
/* Local Macros */
|
||||
/****************/
|
||||
|
||||
/******************/
|
||||
/* Local Typedefs */
|
||||
/******************/
|
||||
|
||||
/********************/
|
||||
/* Local Prototypes */
|
||||
/********************/
|
||||
|
||||
/*********************/
|
||||
/* Package Variables */
|
||||
/*********************/
|
||||
|
||||
/* Package initialization variable */
|
||||
hbool_t H5_PKG_INIT_VAR = FALSE;
|
||||
|
||||
/*****************************/
|
||||
/* Library Private Variables */
|
||||
/*****************************/
|
||||
|
||||
/*******************/
|
||||
/* Local Variables */
|
||||
/*******************/
|
||||
|
||||
/* Reference ID class
|
||||
*
|
||||
* NOTE: H5I_REFERENCE is not used by the library and has been deprecated
|
||||
* with a tentative removal version of 1.12.0. (DER, July 2017)
|
||||
*/
|
||||
static const H5I_class_t H5I_REFERENCE_CLS[1] = {{
|
||||
H5I_REFERENCE, /* ID class value */
|
||||
0, /* Class flags */
|
||||
0, /* # of reserved IDs for class */
|
||||
NULL /* Callback routine for closing objects of this class */
|
||||
}};
|
||||
|
||||
/* Flag indicating "top" of interface has been initialized */
|
||||
static hbool_t H5R_top_package_initialize_s = FALSE;
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R__init_package -- Initialize interface-specific information
|
||||
USAGE
|
||||
herr_t H5R__init_package()
|
||||
|
||||
RETURNS
|
||||
Non-negative on success/Negative on failure
|
||||
DESCRIPTION
|
||||
Initializes any interface-specific data or routines.
|
||||
|
||||
--------------------------------------------------------------------------*/
|
||||
herr_t
|
||||
H5R__init_package(void)
|
||||
{
|
||||
herr_t ret_value = SUCCEED; /* Return value */
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT
|
||||
|
||||
/* Initialize the atom group for the file IDs */
|
||||
if (H5I_register_type(H5I_REFERENCE_CLS) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTINIT, FAIL, "unable to initialize interface")
|
||||
|
||||
/* Mark "top" of interface as initialized, too */
|
||||
H5R_top_package_initialize_s = TRUE;
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5R__init_package() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R_top_term_package
|
||||
PURPOSE
|
||||
Terminate various H5R objects
|
||||
USAGE
|
||||
void H5R_top_term_package()
|
||||
RETURNS
|
||||
void
|
||||
DESCRIPTION
|
||||
Release IDs for the atom group, deferring full interface shutdown
|
||||
until later (in H5R_term_package).
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
Can't report errors...
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
--------------------------------------------------------------------------*/
|
||||
int
|
||||
H5R_top_term_package(void)
|
||||
{
|
||||
int n = 0;
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT_NOERR
|
||||
|
||||
if (H5R_top_package_initialize_s) {
|
||||
if (H5I_nmembers(H5I_REFERENCE) > 0) {
|
||||
(void)H5I_clear_type(H5I_REFERENCE, FALSE, FALSE);
|
||||
n++;
|
||||
}
|
||||
|
||||
/* Mark closed */
|
||||
if (0 == n)
|
||||
H5R_top_package_initialize_s = FALSE;
|
||||
}
|
||||
|
||||
FUNC_LEAVE_NOAPI(n)
|
||||
} /* end H5R_top_term_package() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R_term_package
|
||||
PURPOSE
|
||||
Terminate various H5R objects
|
||||
USAGE
|
||||
void H5R_term_package()
|
||||
RETURNS
|
||||
void
|
||||
DESCRIPTION
|
||||
Release the atom group and any other resources allocated.
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
Can't report errors...
|
||||
|
||||
Finishes shutting down the interface, after H5R_top_term_package()
|
||||
is called
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
--------------------------------------------------------------------------*/
|
||||
int
|
||||
H5R_term_package(void)
|
||||
{
|
||||
int n = 0;
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT_NOERR
|
||||
|
||||
if (H5_PKG_INIT_VAR) {
|
||||
/* Sanity checks */
|
||||
HDassert(0 == H5I_nmembers(H5I_REFERENCE));
|
||||
HDassert(FALSE == H5R_top_package_initialize_s);
|
||||
|
||||
/* Destroy the reference id group */
|
||||
n += (H5I_dec_type_ref(H5I_REFERENCE) > 0);
|
||||
|
||||
/* Mark closed */
|
||||
if (0 == n)
|
||||
H5_PKG_INIT_VAR = FALSE;
|
||||
}
|
||||
|
||||
FUNC_LEAVE_NOAPI(n)
|
||||
} /* end H5R_term_package() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R_create
|
||||
PURPOSE
|
||||
Creates a particular kind of reference for the user
|
||||
USAGE
|
||||
herr_t H5R_create(ref, loc, name, ref_type, space)
|
||||
void *ref; OUT: Reference created
|
||||
H5G_loc_t *loc; IN: File location used to locate object pointed to
|
||||
const char *name; IN: Name of object at location LOC_ID of object
|
||||
pointed to
|
||||
H5R_type_t ref_type; IN: Type of reference to create
|
||||
H5S_t *space; IN: Dataspace ID with selection, used for Dataset
|
||||
Region references.
|
||||
|
||||
RETURNS
|
||||
Non-negative on success/Negative on failure
|
||||
DESCRIPTION
|
||||
Creates a particular type of reference specified with REF_TYPE, in the
|
||||
space pointed to by REF. The LOC_ID and NAME are used to locate the object
|
||||
pointed to and the SPACE_ID is used to choose the region pointed to (for
|
||||
Dataset Region references).
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
--------------------------------------------------------------------------*/
|
||||
herr_t
|
||||
H5R_create(void *_ref, H5G_loc_t *loc, const char *name, H5R_type_t ref_type, H5S_t *space, hid_t dxpl_id)
|
||||
{
|
||||
H5G_loc_t obj_loc; /* Group hier. location of object */
|
||||
H5G_name_t path; /* Object group hier. path */
|
||||
H5O_loc_t oloc; /* Object object location */
|
||||
hbool_t obj_found = FALSE; /* Object location found */
|
||||
herr_t ret_value = SUCCEED; /* Return value */
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT
|
||||
|
||||
HDassert(_ref);
|
||||
HDassert(loc);
|
||||
HDassert(name);
|
||||
HDassert(ref_type > H5R_BADTYPE && ref_type < H5R_MAXTYPE);
|
||||
|
||||
/* Set up object location to fill in */
|
||||
obj_loc.oloc = &oloc;
|
||||
obj_loc.path = &path;
|
||||
H5G_loc_reset(&obj_loc);
|
||||
|
||||
/* Find the object */
|
||||
if (H5G_loc_find(loc, name, &obj_loc, H5P_DEFAULT, dxpl_id) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_NOTFOUND, FAIL, "object not found")
|
||||
obj_found = TRUE;
|
||||
|
||||
switch (ref_type) {
|
||||
case H5R_OBJECT:
|
||||
{
|
||||
hobj_ref_t *ref = (hobj_ref_t *)_ref; /* Get pointer to correct type of reference struct */
|
||||
|
||||
*ref = obj_loc.oloc->addr;
|
||||
break;
|
||||
}
|
||||
|
||||
case H5R_DATASET_REGION:
|
||||
{
|
||||
H5HG_t hobjid; /* Heap object ID */
|
||||
hdset_reg_ref_t *ref = (hdset_reg_ref_t *)_ref; /* Get pointer to correct type of reference struct */
|
||||
hssize_t buf_size; /* Size of buffer needed to serialize selection */
|
||||
uint8_t *p; /* Pointer to OID to store */
|
||||
uint8_t *buf; /* Buffer to store serialized selection in */
|
||||
unsigned heapid_found; /* Flag for non-zero heap ID found */
|
||||
unsigned u; /* local index */
|
||||
|
||||
/* Set up information for dataset region */
|
||||
|
||||
/* Return any previous heap block to the free list if we are
|
||||
* garbage collecting
|
||||
*/
|
||||
if (H5F_GC_REF(loc->oloc->file)) {
|
||||
/* Check for an existing heap ID in the reference */
|
||||
for (u = 0, heapid_found = 0, p = (uint8_t *)ref; u < H5R_DSET_REG_REF_BUF_SIZE; u++)
|
||||
if (p[u] != 0) {
|
||||
heapid_found = 1;
|
||||
break;
|
||||
}
|
||||
|
||||
if (heapid_found != 0) {
|
||||
/* Return heap block to free list */
|
||||
}
|
||||
}
|
||||
|
||||
/* Zero the heap ID out, may leak heap space if user is re-using
|
||||
* reference and doesn't have garbage collection turned on
|
||||
*/
|
||||
HDmemset(ref, 0, H5R_DSET_REG_REF_BUF_SIZE);
|
||||
|
||||
/* Get the amount of space required to serialize the selection */
|
||||
if ((buf_size = H5S_SELECT_SERIAL_SIZE(space)) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTINIT, FAIL, "Invalid amount of space for serializing selection")
|
||||
|
||||
/* Increase buffer size to allow for the dataset OID */
|
||||
buf_size += (hssize_t)sizeof(haddr_t);
|
||||
|
||||
/* Allocate the space to store the serialized information */
|
||||
H5_CHECK_OVERFLOW(buf_size, hssize_t, size_t);
|
||||
if (NULL == (buf = (uint8_t *)H5MM_malloc((size_t)buf_size)))
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, FAIL, "memory allocation failed")
|
||||
|
||||
/* Serialize information for dataset OID into heap buffer */
|
||||
p = (uint8_t *)buf;
|
||||
H5F_addr_encode(loc->oloc->file, &p, obj_loc.oloc->addr);
|
||||
|
||||
/* Serialize the selection into heap buffer */
|
||||
if (H5S_SELECT_SERIALIZE(space, &p) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTCOPY, FAIL, "Unable to serialize selection")
|
||||
|
||||
/* Save the serialized buffer for later */
|
||||
H5_CHECK_OVERFLOW(buf_size, hssize_t, size_t);
|
||||
if (H5HG_insert(loc->oloc->file, dxpl_id, (size_t)buf_size, buf, &hobjid) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_WRITEERROR, FAIL, "Unable to serialize selection")
|
||||
|
||||
/* Serialize the heap ID and index for storage in the file */
|
||||
p = (uint8_t *)ref;
|
||||
H5F_addr_encode(loc->oloc->file, &p, hobjid.addr);
|
||||
UINT32ENCODE(p, hobjid.idx);
|
||||
|
||||
/* Free the buffer we serialized data in */
|
||||
H5MM_xfree(buf);
|
||||
break;
|
||||
} /* end case H5R_DATASET_REGION */
|
||||
|
||||
case H5R_BADTYPE:
|
||||
case H5R_MAXTYPE:
|
||||
default:
|
||||
HDassert("unknown reference type" && 0);
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_UNSUPPORTED, FAIL, "internal error (unknown reference type)")
|
||||
} /* end switch */
|
||||
|
||||
done:
|
||||
if (obj_found)
|
||||
H5G_loc_free(&obj_loc);
|
||||
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5R_create() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R_dereference
|
||||
PURPOSE
|
||||
Opens the HDF5 object referenced.
|
||||
USAGE
|
||||
hid_t H5R_dereference(ref)
|
||||
H5F_t *file; IN: File the object being dereferenced is within
|
||||
H5R_type_t ref_type; IN: Type of reference
|
||||
void *ref; IN: Reference to open.
|
||||
|
||||
RETURNS
|
||||
Valid ID on success, Negative on failure
|
||||
DESCRIPTION
|
||||
Given a reference to some object, open that object and return an ID for
|
||||
that object.
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
Currently only set up to work with references to datasets
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
Raymond Lu
|
||||
13 July 2011
|
||||
I added the OAPL_ID parameter for the object being referenced. It only
|
||||
supports dataset access property list currently.
|
||||
|
||||
M. Scot Breitenfeld
|
||||
3 March 2015
|
||||
Added a check for undefined reference pointer.
|
||||
--------------------------------------------------------------------------*/
|
||||
hid_t
|
||||
H5R_dereference(H5F_t *file, hid_t oapl_id, hid_t dxpl_id, H5R_type_t ref_type, const void *_ref, hbool_t app_ref)
|
||||
{
|
||||
H5O_loc_t oloc; /* Object location */
|
||||
H5G_name_t path; /* Path of object */
|
||||
H5G_loc_t loc; /* Group location */
|
||||
unsigned rc; /* Reference count of object */
|
||||
H5O_type_t obj_type; /* Type of object */
|
||||
hid_t ret_value = H5I_INVALID_HID; /* Return value */
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT
|
||||
|
||||
HDassert(_ref);
|
||||
HDassert(ref_type > H5R_BADTYPE && ref_type < H5R_MAXTYPE);
|
||||
HDassert(file);
|
||||
|
||||
/* Initialize the object location */
|
||||
H5O_loc_reset(&oloc);
|
||||
oloc.file = file;
|
||||
|
||||
switch (ref_type) {
|
||||
case H5R_OBJECT:
|
||||
{
|
||||
oloc.addr = *(const hobj_ref_t *)_ref; /* Only object references currently supported */
|
||||
if (!H5F_addr_defined(oloc.addr) || oloc.addr == 0)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "Undefined reference pointer")
|
||||
break;
|
||||
}
|
||||
|
||||
case H5R_DATASET_REGION:
|
||||
{
|
||||
H5HG_t hobjid; /* Heap object ID */
|
||||
uint8_t *buf; /* Buffer to store serialized selection in */
|
||||
const uint8_t *p; /* Pointer to OID to store */
|
||||
|
||||
/* Get the heap ID for the dataset region */
|
||||
p = (const uint8_t *)_ref;
|
||||
H5F_addr_decode(oloc.file, &p, &(hobjid.addr));
|
||||
UINT32DECODE(p, hobjid.idx);
|
||||
|
||||
if (!H5F_addr_defined(hobjid.addr) || hobjid.addr == 0)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "Undefined reference pointer")
|
||||
|
||||
/* Get the dataset region from the heap (allocate inside routine) */
|
||||
if (NULL == (buf = (uint8_t *)H5HG_read(oloc.file, dxpl_id, &hobjid, NULL, NULL)))
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_READERROR, FAIL, "Unable to read dataset region information")
|
||||
|
||||
/* Get the object oid for the dataset */
|
||||
p = buf;
|
||||
H5F_addr_decode(oloc.file, &p, &(oloc.addr));
|
||||
|
||||
/* Free the buffer allocated in H5HG_read() */
|
||||
H5MM_xfree(buf);
|
||||
break;
|
||||
} /* end case H5R_DATASET_REGION */
|
||||
|
||||
case H5R_BADTYPE:
|
||||
case H5R_MAXTYPE:
|
||||
default:
|
||||
HDassert("unknown reference type" && 0);
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_UNSUPPORTED, FAIL, "internal error (unknown reference type)")
|
||||
} /* end switch */
|
||||
|
||||
/* Get the # of links for object, and its type
|
||||
* (To check to make certain that this object hasn't been deleted
|
||||
* since the reference was created)
|
||||
*/
|
||||
if (H5O_get_rc_and_type(&oloc, dxpl_id, &rc, &obj_type) < 0 || 0 == rc)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_LINKCOUNT, FAIL, "dereferencing deleted object")
|
||||
|
||||
/* Construct a group location for opening the object */
|
||||
H5G_name_reset(&path);
|
||||
loc.oloc = &oloc;
|
||||
loc.path = &path;
|
||||
|
||||
/* Open the object */
|
||||
switch (obj_type) {
|
||||
case H5O_TYPE_GROUP:
|
||||
{
|
||||
H5G_t *group; /* Pointer to group to open */
|
||||
|
||||
if (NULL == (group = H5G_open(&loc, dxpl_id)))
|
||||
HGOTO_ERROR(H5E_SYM, H5E_NOTFOUND, FAIL, "not found")
|
||||
|
||||
/* Create an atom for the group */
|
||||
if ((ret_value = H5I_register(H5I_GROUP, group, app_ref)) < 0) {
|
||||
H5G_close(group);
|
||||
HGOTO_ERROR(H5E_SYM, H5E_CANTREGISTER, FAIL, "can't register group")
|
||||
}
|
||||
|
||||
break;
|
||||
}
|
||||
|
||||
case H5O_TYPE_NAMED_DATATYPE:
|
||||
{
|
||||
H5T_t *type; /* Pointer to datatype to open */
|
||||
|
||||
if (NULL == (type = H5T_open(&loc, dxpl_id)))
|
||||
HGOTO_ERROR(H5E_DATATYPE, H5E_NOTFOUND, FAIL, "not found")
|
||||
|
||||
/* Create an atom for the datatype */
|
||||
if ((ret_value = H5I_register(H5I_DATATYPE, type, app_ref)) < 0) {
|
||||
H5T_close(type);
|
||||
HGOTO_ERROR(H5E_DATATYPE, H5E_CANTREGISTER, FAIL, "can't register datatype")
|
||||
}
|
||||
|
||||
break;
|
||||
}
|
||||
|
||||
case H5O_TYPE_DATASET:
|
||||
{
|
||||
H5D_t *dset; /* Pointer to dataset to open */
|
||||
|
||||
/* Open the dataset */
|
||||
if (NULL == (dset = H5D_open(&loc, oapl_id, dxpl_id)))
|
||||
HGOTO_ERROR(H5E_DATASET, H5E_NOTFOUND, FAIL, "not found")
|
||||
|
||||
/* Create an atom for the dataset */
|
||||
if ((ret_value = H5I_register(H5I_DATASET, dset, app_ref)) < 0) {
|
||||
H5D_close(dset);
|
||||
HGOTO_ERROR(H5E_DATASET, H5E_CANTREGISTER, FAIL, "can't register dataset")
|
||||
}
|
||||
|
||||
break;
|
||||
}
|
||||
|
||||
case H5O_TYPE_UNKNOWN:
|
||||
case H5O_TYPE_NTYPES:
|
||||
default:
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_BADTYPE, FAIL, "can't identify type of object referenced")
|
||||
} /* end switch */
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5R_dereference() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R_get_region
|
||||
PURPOSE
|
||||
Retrieves a dataspace with the region pointed to selected.
|
||||
USAGE
|
||||
H5S_t *H5R_get_region(file, ref_type, ref)
|
||||
H5F_t *file; IN: File the object being dereferenced is within
|
||||
void *ref; IN: Reference to open.
|
||||
|
||||
RETURNS
|
||||
Pointer to the dataspace on success, NULL on failure
|
||||
DESCRIPTION
|
||||
Given a reference to some object, creates a copy of the dataset pointed
|
||||
to's dataspace and defines a selection in the copy which is the region
|
||||
pointed to.
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
--------------------------------------------------------------------------*/
|
||||
H5S_t *
|
||||
H5R_get_region(H5F_t *file, hid_t dxpl_id, const void *_ref)
|
||||
{
|
||||
H5O_loc_t oloc; /* Object location */
|
||||
const uint8_t *p; /* Pointer to OID to store */
|
||||
H5HG_t hobjid; /* Heap object ID */
|
||||
uint8_t *buf = NULL; /* Buffer to store serialized selection in */
|
||||
H5S_t *ret_value;
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT
|
||||
|
||||
HDassert(_ref);
|
||||
HDassert(file);
|
||||
|
||||
/* Initialize the object location */
|
||||
H5O_loc_reset(&oloc);
|
||||
oloc.file = file;
|
||||
|
||||
/* Get the heap ID for the dataset region */
|
||||
p = (const uint8_t *)_ref;
|
||||
H5F_addr_decode(oloc.file, &p, &(hobjid.addr));
|
||||
UINT32DECODE(p, hobjid.idx);
|
||||
|
||||
/* Get the dataset region from the heap (allocate inside routine) */
|
||||
if ((buf = (uint8_t *)H5HG_read(oloc.file, dxpl_id, &hobjid, NULL, NULL)) == NULL)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_READERROR, NULL, "Unable to read dataset region information")
|
||||
|
||||
/* Get the object oid for the dataset */
|
||||
p = buf;
|
||||
H5F_addr_decode(oloc.file, &p, &(oloc.addr));
|
||||
|
||||
/* Open and copy the dataset's dataspace */
|
||||
if ((ret_value = H5S_read(&oloc, dxpl_id)) == NULL)
|
||||
HGOTO_ERROR(H5E_DATASPACE, H5E_NOTFOUND, NULL, "not found")
|
||||
|
||||
/* Unserialize the selection */
|
||||
if (H5S_SELECT_DESERIALIZE(&ret_value, &p) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTDECODE, NULL, "can't deserialize selection")
|
||||
|
||||
done:
|
||||
/* Free the buffer allocated in H5HG_read() */
|
||||
if (buf)
|
||||
H5MM_xfree(buf);
|
||||
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5R_get_region() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R_get_obj_type
|
||||
PURPOSE
|
||||
Retrieves the type of object that an object reference points to
|
||||
USAGE
|
||||
H5O_type_t H5R_get_obj_type(file, ref_type, ref)
|
||||
H5F_t *file; IN: File the object being dereferenced is within
|
||||
H5R_type_t ref_type; IN: Type of reference to query
|
||||
void *ref; IN: Reference to query.
|
||||
|
||||
RETURNS
|
||||
Success: An object type defined in H5Gpublic.h
|
||||
Failure: H5G_UNKNOWN
|
||||
DESCRIPTION
|
||||
Given a reference to some object, this function returns the type of object
|
||||
pointed to.
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
--------------------------------------------------------------------------*/
|
||||
herr_t
|
||||
H5R_get_obj_type(H5F_t *file, hid_t dxpl_id, H5R_type_t ref_type,
|
||||
const void *_ref, H5O_type_t *obj_type)
|
||||
{
|
||||
H5O_loc_t oloc; /* Object location */
|
||||
unsigned rc; /* Reference count of object */
|
||||
herr_t ret_value = SUCCEED; /* Return value */
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT
|
||||
|
||||
HDassert(file);
|
||||
HDassert(_ref);
|
||||
|
||||
/* Initialize the symbol table entry */
|
||||
H5O_loc_reset(&oloc);
|
||||
oloc.file = file;
|
||||
|
||||
switch (ref_type) {
|
||||
case H5R_OBJECT:
|
||||
{
|
||||
/* Get the object oid */
|
||||
oloc.addr = *(const hobj_ref_t *)_ref; /* Only object references currently supported */
|
||||
break;
|
||||
}
|
||||
|
||||
case H5R_DATASET_REGION:
|
||||
{
|
||||
H5HG_t hobjid; /* Heap object ID */
|
||||
const uint8_t *p; /* Pointer to reference to decode */
|
||||
uint8_t *buf; /* Buffer to store serialized selection in */
|
||||
|
||||
/* Get the heap ID for the dataset region */
|
||||
p = (const uint8_t *)_ref;
|
||||
H5F_addr_decode(oloc.file, &p, &(hobjid.addr));
|
||||
UINT32DECODE(p, hobjid.idx);
|
||||
|
||||
/* Get the dataset region from the heap (allocate inside routine) */
|
||||
if ((buf = (uint8_t *)H5HG_read(oloc.file, dxpl_id, &hobjid, NULL, NULL)) == NULL)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_READERROR, FAIL, "Unable to read dataset region information")
|
||||
|
||||
/* Get the object oid for the dataset */
|
||||
p = buf;
|
||||
H5F_addr_decode(oloc.file, &p, &(oloc.addr));
|
||||
|
||||
/* Free the buffer allocated in H5HG_read() */
|
||||
H5MM_xfree(buf);
|
||||
|
||||
break;
|
||||
}
|
||||
|
||||
case H5R_BADTYPE:
|
||||
case H5R_MAXTYPE:
|
||||
default:
|
||||
HDassert("unknown reference type" && 0);
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_UNSUPPORTED, FAIL, "internal error (unknown reference type)")
|
||||
} /* end switch */
|
||||
|
||||
/* Get the # of links for object, and its type */
|
||||
/* (To check to make certain that this object hasn't been deleted since the reference was created) */
|
||||
if (H5O_get_rc_and_type(&oloc, dxpl_id, &rc, obj_type) < 0 || 0 == rc)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_LINKCOUNT, FAIL, "dereferencing deleted object")
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5R_get_obj_type() */
|
||||
|
||||
|
||||
/*--------------------------------------------------------------------------
|
||||
NAME
|
||||
H5R_get_name
|
||||
PURPOSE
|
||||
Internal routine to determine a name for the object referenced
|
||||
USAGE
|
||||
ssize_t H5R_get_name(f, dxpl_id, ref_type, ref, name, size)
|
||||
H5F_t *f; IN: Pointer to the file that the reference is pointing
|
||||
into
|
||||
hid_t lapl_id; IN: LAPL to use for operation
|
||||
hid_t dxpl_id; IN: DXPL to use for operation
|
||||
hid_t id; IN: Location ID given for reference
|
||||
H5R_type_t ref_type; IN: Type of reference
|
||||
void *ref; IN: Reference to query.
|
||||
char *name; OUT: Buffer to place name of object referenced
|
||||
size_t size; IN: Size of name buffer
|
||||
|
||||
RETURNS
|
||||
Non-negative length of the path on success, Negative on failure
|
||||
DESCRIPTION
|
||||
Given a reference to some object, determine a path to the object
|
||||
referenced in the file.
|
||||
GLOBAL VARIABLES
|
||||
COMMENTS, BUGS, ASSUMPTIONS
|
||||
This may not be the only path to that object.
|
||||
EXAMPLES
|
||||
REVISION LOG
|
||||
--------------------------------------------------------------------------*/
|
||||
ssize_t
|
||||
H5R_get_name(H5F_t *f, hid_t lapl_id, hid_t dxpl_id, hid_t id, H5R_type_t ref_type,
|
||||
const void *_ref, char *name, size_t size)
|
||||
{
|
||||
hid_t file_id = H5I_INVALID_HID; /* ID for file that the reference is in */
|
||||
H5O_loc_t oloc; /* Object location describing object for reference */
|
||||
ssize_t ret_value = -1; /* Return value */
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT
|
||||
|
||||
/* Check args */
|
||||
HDassert(f);
|
||||
HDassert(_ref);
|
||||
|
||||
/* Initialize the object location */
|
||||
H5O_loc_reset(&oloc);
|
||||
oloc.file = f;
|
||||
|
||||
/* Get address for reference */
|
||||
switch (ref_type) {
|
||||
case H5R_OBJECT:
|
||||
{
|
||||
oloc.addr = *(const hobj_ref_t *)_ref;
|
||||
break;
|
||||
}
|
||||
|
||||
case H5R_DATASET_REGION:
|
||||
{
|
||||
H5HG_t hobjid; /* Heap object ID */
|
||||
uint8_t *buf; /* Buffer to store serialized selection in */
|
||||
const uint8_t *p; /* Pointer to OID to store */
|
||||
|
||||
/* Get the heap ID for the dataset region */
|
||||
p = (const uint8_t *)_ref;
|
||||
H5F_addr_decode(oloc.file, &p, &(hobjid.addr));
|
||||
UINT32DECODE(p, hobjid.idx);
|
||||
|
||||
/* Get the dataset region from the heap (allocate inside routine) */
|
||||
if ((buf = (uint8_t *)H5HG_read(oloc.file, dxpl_id, &hobjid, NULL, NULL)) == NULL)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_READERROR, FAIL, "Unable to read dataset region information")
|
||||
|
||||
/* Get the object oid for the dataset */
|
||||
p = buf;
|
||||
H5F_addr_decode(oloc.file, &p, &(oloc.addr));
|
||||
|
||||
/* Free the buffer allocated in H5HG_read() */
|
||||
H5MM_xfree(buf);
|
||||
|
||||
break;
|
||||
}
|
||||
|
||||
case H5R_BADTYPE:
|
||||
case H5R_MAXTYPE:
|
||||
default:
|
||||
HDassert("unknown reference type" && 0);
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_UNSUPPORTED, FAIL, "internal error (unknown reference type)")
|
||||
} /* end switch */
|
||||
|
||||
/* Retrieve file ID for name search */
|
||||
if ((file_id = H5I_get_file_id(id, FALSE)) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTGET, FAIL, "can't retrieve file ID")
|
||||
|
||||
/* Get name, length, etc. */
|
||||
if ((ret_value = H5G_get_name_by_addr(file_id, lapl_id, dxpl_id, &oloc, name, size)) < 0)
|
||||
HGOTO_ERROR(H5E_REFERENCE, H5E_CANTGET, FAIL, "can't determine name")
|
||||
|
||||
done:
|
||||
/* Close file ID used for search */
|
||||
if (file_id > 0 && H5I_dec_ref(file_id) < 0)
|
||||
HDONE_ERROR(H5E_REFERENCE, H5E_CANTDEC, FAIL, "can't decrement ref count of temp ID")
|
||||
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5R_get_name() */
|
||||
|
@ -10,13 +10,9 @@
|
||||
* help@hdfgroup.org. *
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
/*
|
||||
* Programmer: Quincey Koziol <koziol@hdfgroup.org>
|
||||
* Saturday, September 12, 2015
|
||||
*
|
||||
* Purpose: This file contains declarations which define macros for the
|
||||
* H5R package. Including this header means that the source file
|
||||
* is part of the H5R package.
|
||||
/* Purpose: This file contains declarations which define macros for the
|
||||
* H5R package. Including this header means that the source file
|
||||
* is part of the H5R package.
|
||||
*/
|
||||
#ifndef _H5Rmodule_H
|
||||
#define _H5Rmodule_H
|
||||
@ -31,4 +27,3 @@
|
||||
|
||||
#endif /* _H5Rmodule_H */
|
||||
|
||||
|
||||
|
14
src/H5Rpkg.h
14
src/H5Rpkg.h
@ -11,11 +11,7 @@
|
||||
* help@hdfgroup.org. *
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
/*
|
||||
* Programmer: Quincey Koziol <koziol@hdfgroup.org>
|
||||
* Thursday, September 13, 2007
|
||||
*
|
||||
* Purpose: This file contains declarations which are visible
|
||||
/* Purpose: This file contains declarations which are visible
|
||||
* only within the H5R package. Source files outside the
|
||||
* H5R package should include H5Rprivate.h instead.
|
||||
*/
|
||||
@ -30,7 +26,6 @@
|
||||
#include "H5Rprivate.h"
|
||||
|
||||
/* Other private headers needed by this file */
|
||||
#include "H5Fprivate.h" /* File access */
|
||||
|
||||
/**************************/
|
||||
/* Package Private Macros */
|
||||
@ -51,12 +46,5 @@
|
||||
/* Package Private Prototypes */
|
||||
/******************************/
|
||||
|
||||
/* General functions */
|
||||
H5_DLL herr_t H5R_get_obj_type(H5F_t *file, hid_t dxpl_id, H5R_type_t ref_type,
|
||||
const void *_ref, H5O_type_t *obj_type);
|
||||
H5_DLL hid_t H5R_dereference(H5F_t *file, hid_t dapl_id, hid_t dxpl_id, H5R_type_t ref_type,
|
||||
const void *_ref, hbool_t app_ref);
|
||||
|
||||
|
||||
#endif /* _H5Rpkg_H */
|
||||
|
||||
|
@ -20,10 +20,40 @@
|
||||
#include "H5Rpublic.h"
|
||||
|
||||
/* Private headers needed by this file */
|
||||
#include "H5Fprivate.h" /* Files */
|
||||
#include "H5Gprivate.h" /* Groups */
|
||||
#include "H5Oprivate.h" /* Object headers */
|
||||
#include "H5Sprivate.h" /* Dataspaces */
|
||||
|
||||
/* Internal data structures */
|
||||
|
||||
/* Private functions */
|
||||
/**************************/
|
||||
/* Library Private Macros */
|
||||
/**************************/
|
||||
|
||||
|
||||
/****************************/
|
||||
/* Library Private Typedefs */
|
||||
/****************************/
|
||||
|
||||
|
||||
/*****************************/
|
||||
/* Library Private Variables */
|
||||
/*****************************/
|
||||
|
||||
|
||||
/******************************/
|
||||
/* Library Private Prototypes */
|
||||
/******************************/
|
||||
|
||||
H5_DLL herr_t H5R_create(void *ref, H5G_loc_t *loc, const char *name,
|
||||
H5R_type_t ref_type, H5S_t *space, hid_t dxpl_id);
|
||||
H5_DLL H5S_t * H5R_get_region(H5F_t *file, hid_t dxpl_id, const void *_ref);
|
||||
H5_DLL ssize_t H5R_get_name(H5F_t *file, hid_t lapl_id, hid_t dxpl_id, hid_t id,
|
||||
H5R_type_t ref_type, const void *_ref, char *name, size_t size);
|
||||
H5_DLL herr_t H5R_get_obj_type(H5F_t *file, hid_t dxpl_id, H5R_type_t ref_type,
|
||||
const void *_ref, H5O_type_t *obj_type);
|
||||
H5_DLL hid_t H5R_dereference(H5F_t *file, hid_t dapl_id, hid_t dxpl_id, H5R_type_t ref_type,
|
||||
const void *_ref, hbool_t app_ref);
|
||||
|
||||
#endif /* _H5Rprivate_H */
|
||||
|
||||
|
@ -22,40 +22,59 @@
|
||||
#include "H5Gpublic.h"
|
||||
#include "H5Ipublic.h"
|
||||
|
||||
/*
|
||||
* Reference types allowed.
|
||||
*/
|
||||
typedef enum {
|
||||
H5R_BADTYPE = (-1), /*invalid Reference Type */
|
||||
H5R_OBJECT, /*Object reference */
|
||||
H5R_DATASET_REGION, /*Dataset Region Reference */
|
||||
H5R_MAXTYPE /*highest type (Invalid as true type) */
|
||||
} H5R_type_t;
|
||||
/*****************/
|
||||
/* Public Macros */
|
||||
/*****************/
|
||||
|
||||
/* Note! Be careful with the sizes of the references because they should really
|
||||
* depend on the run-time values in the file. Unfortunately, the arrays need
|
||||
* to be defined at compile-time, so we have to go with the worst case sizes for
|
||||
* them. -QAK
|
||||
* to be defined at compile-time, so we have to go with the worst case sizes
|
||||
* for them. -QAK
|
||||
*/
|
||||
#define H5R_OBJ_REF_BUF_SIZE sizeof(haddr_t)
|
||||
/* Object reference structure for user's code */
|
||||
typedef haddr_t hobj_ref_t; /* Needs to be large enough to store largest haddr_t in a worst case machine (ie. 8 bytes currently) */
|
||||
#define H5R_OBJ_REF_BUF_SIZE sizeof(haddr_t)
|
||||
|
||||
#define H5R_DSET_REG_REF_BUF_SIZE (sizeof(haddr_t)+4)
|
||||
/* 4 is used instead of sizeof(int) to permit portability between
|
||||
the Crays and other machines (the heap ID is always encoded as an int32 anyway)
|
||||
*/
|
||||
/* Dataset Region reference structure for user's code */
|
||||
typedef unsigned char hdset_reg_ref_t[H5R_DSET_REG_REF_BUF_SIZE];/* Buffer to store heap ID and index */
|
||||
/* Needs to be large enough to store largest haddr_t in a worst case machine (ie. 8 bytes currently) plus an int */
|
||||
/* 4 is used instead of sizeof(int) to permit portability between the Crays
|
||||
* and other machines (the heap ID is always encoded as an int32 anyway).
|
||||
*/
|
||||
#define H5R_DSET_REG_REF_BUF_SIZE (sizeof(haddr_t) + 4)
|
||||
|
||||
/* Publicly visible data structures */
|
||||
/*******************/
|
||||
/* Public Typedefs */
|
||||
/*******************/
|
||||
|
||||
/* Reference types */
|
||||
typedef enum H5R_type_t {
|
||||
H5R_BADTYPE = (-1), /* Invalid Reference Type */
|
||||
H5R_OBJECT, /* Object reference */
|
||||
H5R_DATASET_REGION, /* Dataset Region Reference */
|
||||
H5R_MAXTYPE /* Highest type (Invalid as true type) */
|
||||
} H5R_type_t;
|
||||
|
||||
/* Object reference structure for user's code
|
||||
* This needs to be large enough to store largest haddr_t on a worst case
|
||||
* machine (8 bytes currently).
|
||||
*/
|
||||
typedef haddr_t hobj_ref_t;
|
||||
|
||||
/* Dataset Region reference structure for user's code
|
||||
* (Buffer to store heap ID and index)
|
||||
* This needs to be large enough to store largest haddr_t in a worst case
|
||||
* machine (8 bytes currently) plus an int
|
||||
*/
|
||||
typedef unsigned char hdset_reg_ref_t[H5R_DSET_REG_REF_BUF_SIZE];
|
||||
|
||||
/********************/
|
||||
/* Public Variables */
|
||||
/********************/
|
||||
|
||||
/*********************/
|
||||
/* Public Prototypes */
|
||||
/*********************/
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
/* Functions in H5R.c */
|
||||
H5_DLL herr_t H5Rcreate(void *ref, hid_t loc_id, const char *name,
|
||||
H5R_type_t ref_type, hid_t space_id);
|
||||
H5_DLL hid_t H5Rdereference2(hid_t obj_id, hid_t oapl_id, H5R_type_t ref_type, const void *ref);
|
||||
@ -63,7 +82,7 @@ H5_DLL hid_t H5Rget_region(hid_t dataset, H5R_type_t ref_type, const void *ref);
|
||||
H5_DLL herr_t H5Rget_obj_type2(hid_t id, H5R_type_t ref_type, const void *_ref,
|
||||
H5O_type_t *obj_type);
|
||||
H5_DLL ssize_t H5Rget_name(hid_t loc_id, H5R_type_t ref_type, const void *ref,
|
||||
char *name/*out*/, size_t size);
|
||||
char *name /*out*/, size_t size);
|
||||
|
||||
/* Symbols defined for compatibility with previous versions of the HDF5 API.
|
||||
*
|
||||
@ -71,12 +90,6 @@ H5_DLL ssize_t H5Rget_name(hid_t loc_id, H5R_type_t ref_type, const void *ref,
|
||||
*/
|
||||
#ifndef H5_NO_DEPRECATED_SYMBOLS
|
||||
|
||||
/* Macros */
|
||||
|
||||
|
||||
/* Typedefs */
|
||||
|
||||
|
||||
/* Function prototypes */
|
||||
H5_DLL H5G_obj_t H5Rget_obj_type1(hid_t id, H5R_type_t ref_type, const void *_ref);
|
||||
H5_DLL hid_t H5Rdereference1(hid_t obj_id, H5R_type_t ref_type, const void *ref);
|
||||
|
@ -17,6 +17,9 @@
|
||||
#ifndef _H5Sprivate_H
|
||||
#define _H5Sprivate_H
|
||||
|
||||
/* Early typedefs to avoid circular dependencies */
|
||||
typedef struct H5S_t H5S_t;
|
||||
|
||||
/* Include package's public header */
|
||||
#include "H5Spublic.h"
|
||||
|
||||
@ -44,7 +47,6 @@
|
||||
#define H5S_GET_SEQ_LIST_SORTED 0x0001
|
||||
|
||||
/* Forward references of package typedefs */
|
||||
typedef struct H5S_t H5S_t;
|
||||
typedef struct H5S_extent_t H5S_extent_t;
|
||||
typedef struct H5S_pnt_node_t H5S_pnt_node_t;
|
||||
typedef struct H5S_hyper_span_t H5S_hyper_span_t;
|
||||
|
227
src/H5Tdbg.c
227
src/H5Tdbg.c
@ -32,9 +32,9 @@
|
||||
/***********/
|
||||
/* Headers */
|
||||
/***********/
|
||||
#include "H5private.h" /* Generic Functions */
|
||||
#include "H5Eprivate.h" /* Error handling */
|
||||
#include "H5Tpkg.h" /* Datatypes */
|
||||
#include "H5private.h" /* Generic Functions */
|
||||
#include "H5Eprivate.h" /* Error handling */
|
||||
#include "H5Tpkg.h" /* Datatypes */
|
||||
|
||||
|
||||
/****************/
|
||||
@ -74,28 +74,21 @@
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: H5T__print_stats
|
||||
* Function: H5T__print_stats
|
||||
*
|
||||
* Purpose: Print statistics about a conversion path. Statistics are
|
||||
* printed only if all the following conditions are true:
|
||||
* Purpose: Print statistics about a conversion path. Statistics are
|
||||
* printed only if all the following conditions are true:
|
||||
*
|
||||
* 1. The library was compiled with H5T_DEBUG defined.
|
||||
* 2. Data type debugging is turned on at run time.
|
||||
* 3. The path was called at least one time.
|
||||
* 1. The library was compiled with H5T_DEBUG defined.
|
||||
* 2. Data type debugging is turned on at run time.
|
||||
* 3. The path was called at least one time.
|
||||
*
|
||||
* The optional NPRINT argument keeps track of the number of
|
||||
* conversions paths for which statistics have been shown. If
|
||||
* its value is zero then table headers are printed before the
|
||||
* first line of output.
|
||||
* The optional NPRINT argument keeps track of the number of
|
||||
* conversions paths for which statistics have been shown. If
|
||||
* its value is zero then table headers are printed before the
|
||||
* first line of output.
|
||||
*
|
||||
* Return: Success: non-negative
|
||||
*
|
||||
* Failure: negative
|
||||
*
|
||||
* Programmer: Robb Matzke
|
||||
* Monday, December 14, 1998
|
||||
*
|
||||
* Modifications:
|
||||
* Return: SUCCEED/FAIL
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -110,34 +103,34 @@ H5T__print_stats(H5T_path_t H5_ATTR_UNUSED * path, int H5_ATTR_UNUSED * nprint/*
|
||||
FUNC_ENTER_PACKAGE_NOERR
|
||||
|
||||
#ifdef H5T_DEBUG
|
||||
if(H5DEBUG(T) && path->stats.ncalls > 0) {
|
||||
if(nprint && 0 == (*nprint)++) {
|
||||
HDfprintf(H5DEBUG(T), "H5T: type conversion statistics:\n");
|
||||
HDfprintf(H5DEBUG(T), " %-16s %10s %10s %8s %8s %8s %10s\n",
|
||||
"Conversion", "Elmts", "Calls", "User",
|
||||
"System", "Elapsed", "Bandwidth");
|
||||
HDfprintf(H5DEBUG(T), " %-16s %10s %10s %8s %8s %8s %10s\n",
|
||||
"----------", "-----", "-----", "----",
|
||||
"------", "-------", "---------");
|
||||
}
|
||||
if(path->src && path->dst)
|
||||
if (H5DEBUG(T) && path->stats.ncalls > 0) {
|
||||
if (nprint && 0 == (*nprint)++) {
|
||||
HDfprintf(H5DEBUG(T), "H5T: type conversion statistics:\n");
|
||||
HDfprintf(H5DEBUG(T), " %-16s %10s %10s %8s %8s %8s %10s\n",
|
||||
"Conversion", "Elmts", "Calls", "User",
|
||||
"System", "Elapsed", "Bandwidth");
|
||||
HDfprintf(H5DEBUG(T), " %-16s %10s %10s %8s %8s %8s %10s\n",
|
||||
"----------", "-----", "-----", "----",
|
||||
"------", "-------", "---------");
|
||||
}
|
||||
if (path->src && path->dst)
|
||||
nbytes = MAX(H5T_get_size(path->src), H5T_get_size(path->dst));
|
||||
else if(path->src)
|
||||
else if (path->src)
|
||||
nbytes = H5T_get_size(path->src);
|
||||
else if(path->dst)
|
||||
else if (path->dst)
|
||||
nbytes = H5T_get_size(path->dst);
|
||||
else
|
||||
nbytes = 0;
|
||||
nbytes *= path->stats.nelmts;
|
||||
H5_bandwidth(bandwidth, (double)nbytes, path->stats.timer.etime);
|
||||
HDfprintf(H5DEBUG(T), " %-16s %10Hd %10d %8.2f %8.2f %8.2f %10s\n",
|
||||
path->name,
|
||||
path->stats.nelmts,
|
||||
path->stats.ncalls,
|
||||
path->stats.timer.utime,
|
||||
path->stats.timer.stime,
|
||||
path->stats.timer.etime,
|
||||
bandwidth);
|
||||
nbytes *= path->stats.nelmts;
|
||||
H5_bandwidth(bandwidth, (double)nbytes, path->stats.timer.etime);
|
||||
HDfprintf(H5DEBUG(T), " %-16s %10Hd %10d %8.2f %8.2f %8.2f %10s\n",
|
||||
path->name,
|
||||
path->stats.nelmts,
|
||||
path->stats.ncalls,
|
||||
path->stats.timer.utime,
|
||||
path->stats.timer.stime,
|
||||
path->stats.timer.etime,
|
||||
bandwidth);
|
||||
}
|
||||
#endif
|
||||
FUNC_LEAVE_NOAPI(SUCCEED)
|
||||
@ -145,24 +138,20 @@ H5T__print_stats(H5T_path_t H5_ATTR_UNUSED * path, int H5_ATTR_UNUSED * nprint/*
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: H5T_debug
|
||||
* Function: H5T_debug
|
||||
*
|
||||
* Purpose: Prints information about a data type.
|
||||
* Purpose: Prints information about a data type.
|
||||
*
|
||||
* Return: Non-negative on success/Negative on failure
|
||||
*
|
||||
* Programmer: Robb Matzke
|
||||
* Wednesday, January 7, 1998
|
||||
*
|
||||
* Modifications:
|
||||
* Return: SUCCEED/FAIL
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
herr_t
|
||||
H5T_debug(const H5T_t *dt, FILE *stream)
|
||||
{
|
||||
const char *s1 = "", *s2 = "";
|
||||
unsigned i;
|
||||
const char *s1 = "";
|
||||
const char *s2 = "";
|
||||
unsigned i;
|
||||
herr_t ret_value = SUCCEED; /* Return value */
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT
|
||||
@ -171,7 +160,7 @@ H5T_debug(const H5T_t *dt, FILE *stream)
|
||||
HDassert(dt);
|
||||
HDassert(stream);
|
||||
|
||||
switch(dt->shared->type) {
|
||||
switch (dt->shared->type) {
|
||||
case H5T_NO_CLASS:
|
||||
HGOTO_ERROR(H5E_DATATYPE, H5E_BADTYPE, FAIL, "no class");
|
||||
break;
|
||||
@ -221,9 +210,9 @@ H5T_debug(const H5T_t *dt, FILE *stream)
|
||||
default:
|
||||
s1 = "";
|
||||
break;
|
||||
} /* end switch */
|
||||
} /* end switch */
|
||||
|
||||
switch(dt->shared->state) {
|
||||
switch (dt->shared->state) {
|
||||
case H5T_STATE_TRANSIENT:
|
||||
s2 = "[transient]";
|
||||
break;
|
||||
@ -245,14 +234,14 @@ H5T_debug(const H5T_t *dt, FILE *stream)
|
||||
break;
|
||||
default:
|
||||
HDassert(0 && "This Should never be executed!");
|
||||
} /* end switch */
|
||||
} /* end switch */
|
||||
|
||||
fprintf(stream, "%s%s {nbytes=%lu", s1, s2, (unsigned long)(dt->shared->size));
|
||||
HDfprintf(stream, "%s%s {nbytes=%lu", s1, s2, (unsigned long)(dt->shared->size));
|
||||
|
||||
if(H5T_IS_ATOMIC(dt->shared)) {
|
||||
uint64_t tmp;
|
||||
if (H5T_IS_ATOMIC(dt->shared)) {
|
||||
uint64_t tmp;
|
||||
|
||||
switch(dt->shared->u.atomic.order) {
|
||||
switch (dt->shared->u.atomic.order) {
|
||||
case H5T_ORDER_ERROR:
|
||||
HGOTO_ERROR(H5E_DATATYPE, H5E_BADTYPE, FAIL, "order error");
|
||||
break;
|
||||
@ -277,17 +266,16 @@ H5T_debug(const H5T_t *dt, FILE *stream)
|
||||
default:
|
||||
s1 = "order?";
|
||||
break;
|
||||
} /* end switch */
|
||||
} /* end switch */
|
||||
|
||||
fprintf(stream, ", %s", s1);
|
||||
HDfprintf(stream, ", %s", s1);
|
||||
|
||||
if(dt->shared->u.atomic.offset)
|
||||
fprintf(stream, ", offset=%lu",
|
||||
(unsigned long) (dt->shared->u.atomic.offset));
|
||||
if(dt->shared->u.atomic.prec != 8 * dt->shared->size)
|
||||
fprintf(stream, ", prec=%lu",
|
||||
(unsigned long) (dt->shared->u.atomic.prec));
|
||||
switch(dt->shared->type) {
|
||||
if (dt->shared->u.atomic.offset)
|
||||
HDfprintf(stream, ", offset=%lu", (unsigned long) (dt->shared->u.atomic.offset));
|
||||
if (dt->shared->u.atomic.prec != 8 * dt->shared->size)
|
||||
HDfprintf(stream, ", prec=%lu", (unsigned long) (dt->shared->u.atomic.prec));
|
||||
|
||||
switch (dt->shared->type) {
|
||||
case H5T_NO_CLASS:
|
||||
HGOTO_ERROR(H5E_DATATYPE, H5E_BADTYPE, FAIL, "no class");
|
||||
break;
|
||||
@ -313,7 +301,7 @@ H5T_debug(const H5T_t *dt, FILE *stream)
|
||||
|
||||
} /* end switch */
|
||||
if(s1)
|
||||
fprintf(stream, ", %s", s1);
|
||||
HDfprintf(stream, ", %s", s1);
|
||||
break;
|
||||
|
||||
case H5T_FLOAT:
|
||||
@ -339,23 +327,24 @@ H5T_debug(const H5T_t *dt, FILE *stream)
|
||||
break;
|
||||
} /* end switch */
|
||||
|
||||
fprintf(stream, ", sign=%lu+1",
|
||||
HDfprintf(stream, ", sign=%lu+1",
|
||||
(unsigned long)(dt->shared->u.atomic.u.f.sign));
|
||||
fprintf(stream, ", mant=%lu+%lu (%s)",
|
||||
HDfprintf(stream, ", mant=%lu+%lu (%s)",
|
||||
(unsigned long)(dt->shared->u.atomic.u.f.mpos),
|
||||
(unsigned long)(dt->shared->u.atomic.u.f.msize), s1);
|
||||
fprintf(stream, ", exp=%lu+%lu",
|
||||
HDfprintf(stream, ", exp=%lu+%lu",
|
||||
(unsigned long)(dt->shared->u.atomic.u.f.epos),
|
||||
(unsigned long)(dt->shared->u.atomic.u.f.esize));
|
||||
tmp = dt->shared->u.atomic.u.f.ebias >> 32;
|
||||
if(tmp) {
|
||||
if (tmp) {
|
||||
size_t hi = (size_t)tmp;
|
||||
size_t lo = (size_t)(dt->shared->u.atomic.u.f.ebias & 0xffffffff);
|
||||
fprintf(stream, " bias=0x%08lx%08lx",
|
||||
HDfprintf(stream, " bias=0x%08lx%08lx",
|
||||
(unsigned long)hi, (unsigned long)lo);
|
||||
} else {
|
||||
}
|
||||
else {
|
||||
size_t lo = (size_t)(dt->shared->u.atomic.u.f.ebias & 0xffffffff);
|
||||
fprintf(stream, " bias=0x%08lx", (unsigned long)lo);
|
||||
HDfprintf(stream, " bias=0x%08lx", (unsigned long)lo);
|
||||
}
|
||||
break;
|
||||
|
||||
@ -372,69 +361,73 @@ H5T_debug(const H5T_t *dt, FILE *stream)
|
||||
default:
|
||||
/* No additional info */
|
||||
break;
|
||||
} /* end switch */
|
||||
} else if(H5T_COMPOUND == dt->shared->type) {
|
||||
/* Compound data type */
|
||||
for(i = 0; i < dt->shared->u.compnd.nmembs; i++) {
|
||||
fprintf(stream, "\n\"%s\" @%lu",
|
||||
dt->shared->u.compnd.memb[i].name,
|
||||
(unsigned long)(dt->shared->u.compnd.memb[i].offset));
|
||||
fprintf(stream, " ");
|
||||
H5T_debug(dt->shared->u.compnd.memb[i].type, stream);
|
||||
} /* end for */
|
||||
fprintf(stream, "\n");
|
||||
} else if(H5T_VLEN == dt->shared->type) {
|
||||
switch(dt->shared->u.vlen.loc) {
|
||||
} /* end switch */
|
||||
}
|
||||
else if (H5T_COMPOUND == dt->shared->type) {
|
||||
/* Compound data type */
|
||||
for (i = 0; i < dt->shared->u.compnd.nmembs; i++) {
|
||||
HDfprintf(stream, "\n\"%s\" @%lu",
|
||||
dt->shared->u.compnd.memb[i].name,
|
||||
(unsigned long)(dt->shared->u.compnd.memb[i].offset));
|
||||
HDfprintf(stream, " ");
|
||||
H5T_debug(dt->shared->u.compnd.memb[i].type, stream);
|
||||
} /* end for */
|
||||
HDfprintf(stream, "\n");
|
||||
}
|
||||
else if (H5T_VLEN == dt->shared->type) {
|
||||
switch (dt->shared->u.vlen.loc) {
|
||||
case H5T_LOC_BADLOC:
|
||||
HGOTO_ERROR(H5E_DATATYPE, H5E_BADTYPE, FAIL, "invalid datatype location");
|
||||
break;
|
||||
|
||||
case H5T_LOC_MEMORY:
|
||||
fprintf(stream, ", loc=memory");
|
||||
HDfprintf(stream, ", loc=memory");
|
||||
break;
|
||||
|
||||
case H5T_LOC_DISK:
|
||||
fprintf(stream, ", loc=disk");
|
||||
HDfprintf(stream, ", loc=disk");
|
||||
break;
|
||||
|
||||
case H5T_LOC_MAXLOC:
|
||||
default:
|
||||
fprintf(stream, ", loc=UNKNOWN");
|
||||
HDfprintf(stream, ", loc=UNKNOWN");
|
||||
break;
|
||||
} /* end switch */
|
||||
|
||||
if(H5T_IS_VL_STRING(dt->shared))
|
||||
if (H5T_IS_VL_STRING(dt->shared))
|
||||
/* Variable length string datatype */
|
||||
fprintf(stream, ", variable-length");
|
||||
HDfprintf(stream, ", variable-length");
|
||||
else {
|
||||
/* Variable length sequence datatype */
|
||||
fprintf(stream, " VLEN ");
|
||||
HDfprintf(stream, " VLEN ");
|
||||
H5T_debug(dt->shared->parent, stream);
|
||||
fprintf(stream, "\n");
|
||||
HDfprintf(stream, "\n");
|
||||
} /* end else */
|
||||
} else if(H5T_ENUM == dt->shared->type) {
|
||||
}
|
||||
else if (H5T_ENUM == dt->shared->type) {
|
||||
size_t base_size;
|
||||
|
||||
/* Enumeration data type */
|
||||
fprintf(stream, " ");
|
||||
H5T_debug(dt->shared->parent, stream);
|
||||
base_size = dt->shared->parent->shared->size;
|
||||
for(i = 0; i < dt->shared->u.enumer.nmembs; i++) {
|
||||
/* Enumeration data type */
|
||||
HDfprintf(stream, " ");
|
||||
H5T_debug(dt->shared->parent, stream);
|
||||
base_size = dt->shared->parent->shared->size;
|
||||
for (i = 0; i < dt->shared->u.enumer.nmembs; i++) {
|
||||
size_t k;
|
||||
|
||||
fprintf(stream, "\n\"%s\" = 0x", dt->shared->u.enumer.name[i]);
|
||||
for(k = 0; k < base_size; k++)
|
||||
fprintf(stream, "%02lx",
|
||||
(unsigned long)(dt->shared->u.enumer.value + (i * base_size) + k));
|
||||
} /* end for */
|
||||
fprintf(stream, "\n");
|
||||
} else if(H5T_OPAQUE == dt->shared->type) {
|
||||
fprintf(stream, ", tag=\"%s\"", dt->shared->u.opaque.tag);
|
||||
} else {
|
||||
/* Unknown */
|
||||
fprintf(stream, "unknown class %d\n", (int)(dt->shared->type));
|
||||
HDfprintf(stream, "\n\"%s\" = 0x", dt->shared->u.enumer.name[i]);
|
||||
for (k = 0; k < base_size; k++)
|
||||
HDfprintf(stream, "%02lx", (unsigned long)(dt->shared->u.enumer.value + (i * base_size) + k));
|
||||
} /* end for */
|
||||
HDfprintf(stream, "\n");
|
||||
}
|
||||
fprintf(stream, "}");
|
||||
else if (H5T_OPAQUE == dt->shared->type) {
|
||||
HDfprintf(stream, ", tag=\"%s\"", dt->shared->u.opaque.tag);
|
||||
}
|
||||
else {
|
||||
/* Unknown */
|
||||
HDfprintf(stream, "unknown class %d\n", (int)(dt->shared->type));
|
||||
}
|
||||
HDfprintf(stream, "}");
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
|
@ -17,6 +17,9 @@
|
||||
#ifndef _H5Tprivate_H
|
||||
#define _H5Tprivate_H
|
||||
|
||||
/* Early typedefs to avoid circular dependencies */
|
||||
typedef struct H5T_t H5T_t;
|
||||
|
||||
/* Get package's public header */
|
||||
#include "H5Tpublic.h"
|
||||
|
||||
@ -45,7 +48,6 @@
|
||||
#endif /* H5T_MODULE */
|
||||
|
||||
/* Forward references of package typedefs (declared in H5Tpkg.h) */
|
||||
typedef struct H5T_t H5T_t;
|
||||
typedef struct H5T_stats_t H5T_stats_t;
|
||||
typedef struct H5T_path_t H5T_path_t;
|
||||
|
||||
|
266
src/H5Z.c
266
src/H5Z.c
@ -86,24 +86,24 @@ H5Z__init_package(void)
|
||||
FUNC_ENTER_PACKAGE
|
||||
|
||||
/* Internal filters */
|
||||
if (H5Z_register (H5Z_SHUFFLE) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register shuffle filter")
|
||||
if (H5Z_register (H5Z_FLETCHER32) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register fletcher32 filter")
|
||||
if (H5Z_register (H5Z_NBIT) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register nbit filter")
|
||||
if (H5Z_register (H5Z_SCALEOFFSET) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register scaleoffset filter")
|
||||
if (H5Z_register(H5Z_SHUFFLE) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register shuffle filter")
|
||||
if (H5Z_register(H5Z_FLETCHER32) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register fletcher32 filter")
|
||||
if (H5Z_register(H5Z_NBIT) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register nbit filter")
|
||||
if (H5Z_register(H5Z_SCALEOFFSET) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register scaleoffset filter")
|
||||
|
||||
/* External filters */
|
||||
#ifdef H5_HAVE_FILTER_DEFLATE
|
||||
if (H5Z_register (H5Z_DEFLATE) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register deflate filter")
|
||||
if (H5Z_register(H5Z_DEFLATE) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register deflate filter")
|
||||
#endif /* H5_HAVE_FILTER_DEFLATE */
|
||||
#ifdef H5_HAVE_FILTER_SZIP
|
||||
H5Z_SZIP->encoder_present = SZ_encoder_enabled();
|
||||
if (H5Z_register (H5Z_SZIP) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register szip filter")
|
||||
if (H5Z_register(H5Z_SZIP) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register szip filter")
|
||||
#endif /* H5_HAVE_FILTER_SZIP */
|
||||
|
||||
done:
|
||||
@ -180,7 +180,7 @@ H5Z_term_package(void)
|
||||
} /* end if */
|
||||
#endif /* H5Z_DEBUG */
|
||||
/* Free the table of filters */
|
||||
if(H5Z_table_g) {
|
||||
if (H5Z_table_g) {
|
||||
H5Z_table_g = (H5Z_class2_t *)H5MM_xfree(H5Z_table_g);
|
||||
#ifdef H5Z_DEBUG
|
||||
H5Z_stat_table_g = (H5Z_stats_t *)H5MM_xfree(H5Z_stat_table_g);
|
||||
@ -191,7 +191,7 @@ H5Z_term_package(void)
|
||||
} /* end if */
|
||||
|
||||
/* Mark interface as closed */
|
||||
if(0 == n)
|
||||
if (0 == n)
|
||||
H5_PKG_INIT_VAR = FALSE;
|
||||
} /* end if */
|
||||
|
||||
@ -219,7 +219,7 @@ H5Zregister(const void *cls)
|
||||
|
||||
/* Check args */
|
||||
if (cls_real==NULL)
|
||||
HGOTO_ERROR (H5E_ARGS, H5E_BADVALUE, FAIL, "invalid filter class")
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid filter class")
|
||||
|
||||
/* Check H5Z_class_t version number; this is where a function to convert
|
||||
* from an outdated version should be called.
|
||||
@ -251,20 +251,20 @@ H5Zregister(const void *cls)
|
||||
|
||||
#else /* H5_NO_DEPRECATED_SYMBOLS */
|
||||
/* Deprecated symbols not allowed, throw an error */
|
||||
HGOTO_ERROR (H5E_ARGS, H5E_BADVALUE, FAIL, "invalid H5Z_class_t version number");
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid H5Z_class_t version number");
|
||||
#endif /* H5_NO_DEPRECATED_SYMBOLS */
|
||||
} /* end if */
|
||||
|
||||
if (cls_real->id < 0 || cls_real->id > H5Z_FILTER_MAX)
|
||||
HGOTO_ERROR (H5E_ARGS, H5E_BADVALUE, FAIL, "invalid filter identification number")
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid filter identification number")
|
||||
if (cls_real->id < H5Z_FILTER_RESERVED)
|
||||
HGOTO_ERROR (H5E_ARGS, H5E_BADVALUE, FAIL, "unable to modify predefined filters")
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "unable to modify predefined filters")
|
||||
if (cls_real->filter == NULL)
|
||||
HGOTO_ERROR (H5E_ARGS, H5E_BADVALUE, FAIL, "no filter function specified")
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "no filter function specified")
|
||||
|
||||
/* Do it */
|
||||
if (H5Z_register (cls_real) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register filter")
|
||||
if (H5Z_register(cls_real) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register filter")
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_API(ret_value)
|
||||
@ -275,7 +275,7 @@ done:
|
||||
* Function: H5Z_register
|
||||
*
|
||||
* Purpose: Same as the public version except this one allows filters
|
||||
* to be set for predefined method numbers <H5Z_FILTER_RESERVED
|
||||
* to be set for predefined method numbers < H5Z_FILTER_RESERVED
|
||||
*
|
||||
* Return: Non-negative on success
|
||||
* Negative on failure
|
||||
@ -289,8 +289,8 @@ H5Z_register (const H5Z_class2_t *cls)
|
||||
|
||||
FUNC_ENTER_NOAPI(FAIL)
|
||||
|
||||
HDassert (cls);
|
||||
HDassert (cls->id >= 0 && cls->id <= H5Z_FILTER_MAX);
|
||||
HDassert(cls);
|
||||
HDassert(cls->id >= 0 && cls->id <= H5Z_FILTER_MAX);
|
||||
|
||||
/* Is the filter already registered? */
|
||||
for (i = 0; i < H5Z_table_used_g; i++)
|
||||
@ -306,11 +306,11 @@ H5Z_register (const H5Z_class2_t *cls)
|
||||
H5Z_stats_t *stat_table = (H5Z_stats_t *)H5MM_realloc(H5Z_stat_table_g, n * sizeof(H5Z_stats_t));
|
||||
#endif /* H5Z_DEBUG */
|
||||
if (!table)
|
||||
HGOTO_ERROR (H5E_RESOURCE, H5E_NOSPACE, FAIL, "unable to extend filter table")
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, FAIL, "unable to extend filter table")
|
||||
H5Z_table_g = table;
|
||||
#ifdef H5Z_DEBUG
|
||||
if (!stat_table)
|
||||
HGOTO_ERROR (H5E_RESOURCE, H5E_NOSPACE, FAIL, "unable to extend filter statistics table")
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, FAIL, "unable to extend filter statistics table")
|
||||
H5Z_stat_table_g = stat_table;
|
||||
#endif /* H5Z_DEBUG */
|
||||
H5Z_table_alloc_g = n;
|
||||
@ -318,15 +318,15 @@ H5Z_register (const H5Z_class2_t *cls)
|
||||
|
||||
/* Initialize */
|
||||
i = H5Z_table_used_g++;
|
||||
HDmemcpy (H5Z_table_g+i, cls, sizeof(H5Z_class2_t));
|
||||
HDmemcpy(H5Z_table_g+i, cls, sizeof(H5Z_class2_t));
|
||||
#ifdef H5Z_DEBUG
|
||||
HDmemset (H5Z_stat_table_g+i, 0, sizeof(H5Z_stats_t));
|
||||
HDmemset(H5Z_stat_table_g+i, 0, sizeof(H5Z_stats_t));
|
||||
#endif /* H5Z_DEBUG */
|
||||
} /* end if */
|
||||
/* Filter already registered */
|
||||
else {
|
||||
/* Replace old contents */
|
||||
HDmemcpy (H5Z_table_g+i, cls, sizeof(H5Z_class2_t));
|
||||
HDmemcpy(H5Z_table_g+i, cls, sizeof(H5Z_class2_t));
|
||||
} /* end else */
|
||||
|
||||
done:
|
||||
@ -420,9 +420,9 @@ H5Z_unregister(H5Z_filter_t filter_id)
|
||||
|
||||
/* Remove filter from table */
|
||||
/* Don't worry about shrinking table size (for now) */
|
||||
HDmemmove (&H5Z_table_g[filter_index], &H5Z_table_g[filter_index+1], sizeof(H5Z_class2_t)*((H5Z_table_used_g-1)-filter_index));
|
||||
HDmemmove(&H5Z_table_g[filter_index], &H5Z_table_g[filter_index+1], sizeof(H5Z_class2_t)*((H5Z_table_used_g-1)-filter_index));
|
||||
#ifdef H5Z_DEBUG
|
||||
HDmemmove (&H5Z_stat_table_g[filter_index], &H5Z_stat_table_g[filter_index+1], sizeof(H5Z_stats_t)*((H5Z_table_used_g-1)-filter_index));
|
||||
HDmemmove(&H5Z_stat_table_g[filter_index], &H5Z_stat_table_g[filter_index+1], sizeof(H5Z_stats_t)*((H5Z_table_used_g-1)-filter_index));
|
||||
#endif /* H5Z_DEBUG */
|
||||
H5Z_table_used_g--;
|
||||
|
||||
@ -450,11 +450,11 @@ H5Z__check_unregister(hid_t ocpl_id, H5Z_filter_t filter_id)
|
||||
|
||||
/* Get the plist structure of object creation */
|
||||
if (NULL == (plist = H5P_object_verify(ocpl_id, H5P_OBJECT_CREATE)))
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_BADATOM, FAIL, "can't find object for ID")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_BADATOM, FAIL, "can't find object for ID")
|
||||
|
||||
/* Check if the object creation property list uses the filter */
|
||||
if ((ret_value = H5P_filter_in_pline(plist, filter_id)) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTGET, FAIL, "can't check filter in pipeline")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTGET, FAIL, "can't check filter in pipeline")
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
@ -487,11 +487,11 @@ H5Z__check_unregister_group_cb(void *obj_ptr, hid_t H5_ATTR_UNUSED obj_id, void
|
||||
|
||||
/* Get the group creation property */
|
||||
if ((ocpl_id = H5G_get_create_plist((H5G_t *)obj_ptr)) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTGET, FAIL, "can't get group creation property list")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTGET, FAIL, "can't get group creation property list")
|
||||
|
||||
/* Check if the filter is in the group creation property list */
|
||||
if ((filter_in_pline = H5Z__check_unregister(ocpl_id, object->filter_id)) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTGET, FAIL, "can't check filter in pipeline")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTGET, FAIL, "can't check filter in pipeline")
|
||||
|
||||
/* H5I_iterate expects TRUE to stop the loop over objects. Stop the loop and
|
||||
* let H5Z_unregister return failure.
|
||||
@ -504,7 +504,7 @@ H5Z__check_unregister_group_cb(void *obj_ptr, hid_t H5_ATTR_UNUSED obj_id, void
|
||||
done:
|
||||
if (ocpl_id > 0)
|
||||
if (H5I_dec_app_ref(ocpl_id) < 0)
|
||||
HDONE_ERROR (H5E_PLINE, H5E_CANTDEC, FAIL, "can't release plist")
|
||||
HDONE_ERROR(H5E_PLINE, H5E_CANTDEC, FAIL, "can't release plist")
|
||||
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5Z__check_unregister_group_cb() */
|
||||
@ -532,15 +532,15 @@ H5Z__check_unregister_dset_cb(void *obj_ptr, hid_t H5_ATTR_UNUSED obj_id, void *
|
||||
|
||||
FUNC_ENTER_STATIC
|
||||
|
||||
HDassert (obj_ptr);
|
||||
HDassert(obj_ptr);
|
||||
|
||||
/* Get the dataset creation property */
|
||||
if ((ocpl_id = H5D_get_create_plist((H5D_t *)obj_ptr)) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTGET, FAIL, "can't get dataset creation property list")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTGET, FAIL, "can't get dataset creation property list")
|
||||
|
||||
/* Check if the filter is in the dataset creation property list */
|
||||
if ((filter_in_pline = H5Z__check_unregister(ocpl_id, object->filter_id)) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTGET, FAIL, "can't check filter in pipeline")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTGET, FAIL, "can't check filter in pipeline")
|
||||
|
||||
/* H5I_iterate expects TRUE to stop the loop over objects. Stop the loop and
|
||||
* let H5Z_unregister return failure.
|
||||
@ -553,7 +553,7 @@ H5Z__check_unregister_dset_cb(void *obj_ptr, hid_t H5_ATTR_UNUSED obj_id, void *
|
||||
done:
|
||||
if (ocpl_id > 0)
|
||||
if (H5I_dec_app_ref(ocpl_id) < 0)
|
||||
HDONE_ERROR (H5E_PLINE, H5E_CANTDEC, FAIL, "can't release plist")
|
||||
HDONE_ERROR(H5E_PLINE, H5E_CANTDEC, FAIL, "can't release plist")
|
||||
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5Z__check_unregister_dset_cb() */
|
||||
@ -576,13 +576,13 @@ H5Z__flush_file_cb(void *obj_ptr, hid_t H5_ATTR_UNUSED obj_id, void H5_ATTR_UNUS
|
||||
|
||||
FUNC_ENTER_STATIC
|
||||
|
||||
HDassert (obj_ptr);
|
||||
HDassert(obj_ptr);
|
||||
|
||||
/* Call the flush routine for mounted file hierarchies. Do a global flush
|
||||
* if the file is opened for write */
|
||||
if (H5F_ACC_RDWR & H5F_INTENT((H5F_t *)obj_ptr)) {
|
||||
if (H5F_flush_mounts((H5F_t *)obj_ptr, H5AC_ind_read_dxpl_id, H5AC_rawdata_dxpl_id) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTFLUSH, FAIL, "unable to flush file hierarchy")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTFLUSH, FAIL, "unable to flush file hierarchy")
|
||||
} /* end if */
|
||||
|
||||
done:
|
||||
@ -608,10 +608,10 @@ H5Zfilter_avail(H5Z_filter_t id)
|
||||
|
||||
/* Check args */
|
||||
if (id < 0 || id > H5Z_FILTER_MAX)
|
||||
HGOTO_ERROR (H5E_ARGS, H5E_BADVALUE, FAIL, "invalid filter identification number")
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FAIL, "invalid filter identification number")
|
||||
|
||||
if ((ret_value = H5Z_filter_avail(id)) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_NOTFOUND, FAIL, "unable to check the availability of the filter")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_NOTFOUND, FAIL, "unable to check the availability of the filter")
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_API(ret_value)
|
||||
@ -629,22 +629,25 @@ done:
|
||||
htri_t
|
||||
H5Z_filter_avail(H5Z_filter_t id)
|
||||
{
|
||||
size_t i; /* Local index variable */
|
||||
H5Z_class2_t *filter_info;
|
||||
htri_t ret_value = FALSE; /* Return value */
|
||||
H5PL_key_t key; /* Key for finding a plugin */
|
||||
const H5Z_class2_t *filter_info; /* Filter information */
|
||||
size_t i; /* Local index variable */
|
||||
htri_t ret_value = FALSE; /* Return value */
|
||||
|
||||
FUNC_ENTER_NOAPI(FAIL)
|
||||
|
||||
/* Is the filter already registered? */
|
||||
for (i = 0; i < H5Z_table_used_g; i++)
|
||||
if (H5Z_table_g[i].id == id)
|
||||
HGOTO_DONE (TRUE)
|
||||
HGOTO_DONE(TRUE)
|
||||
|
||||
if (NULL != (filter_info = (const H5Z_class2_t *)H5PL_load(H5PL_TYPE_FILTER, (int)id))) {
|
||||
if (H5Z_register (filter_info) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register loaded filter")
|
||||
HGOTO_DONE (TRUE)
|
||||
key.id = (int)id;
|
||||
if (NULL != (filter_info = (const H5Z_class2_t *)H5PL_load(H5PL_TYPE_FILTER, key))) {
|
||||
if (H5Z_register(filter_info) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register loaded filter")
|
||||
HGOTO_DONE(TRUE)
|
||||
}
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5Z_filter_avail() */
|
||||
@ -683,7 +686,7 @@ H5Z_prelude_callback(const H5O_pline_t *pline, hid_t dcpl_id, hid_t type_id,
|
||||
if (pline->filter[u].flags & H5Z_FLAG_OPTIONAL)
|
||||
H5E_clear_stack (NULL);
|
||||
else
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_NOTFOUND, FAIL, "required filter was not located")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_NOTFOUND, FAIL, "required filter was not located")
|
||||
} /* end if */
|
||||
else {
|
||||
/* Make correct callback */
|
||||
@ -691,7 +694,7 @@ H5Z_prelude_callback(const H5O_pline_t *pline, hid_t dcpl_id, hid_t type_id,
|
||||
case H5Z_PRELUDE_CAN_APPLY:
|
||||
/* Check if filter is configured to be able to encode */
|
||||
if (!fclass->encoder_present)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_NOENCODER, FAIL, "Filter present but encoding is disabled.");
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_NOENCODER, FAIL, "Filter present but encoding is disabled.");
|
||||
|
||||
|
||||
/* Check if there is a "can apply" callback */
|
||||
@ -716,12 +719,12 @@ H5Z_prelude_callback(const H5O_pline_t *pline, hid_t dcpl_id, hid_t type_id,
|
||||
/* Make callback to filter's "set local" function */
|
||||
if ((fclass->set_local)(dcpl_id, type_id, space_id) < 0)
|
||||
/* Indicate error during filter callback */
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_SETLOCAL, FAIL, "error during user callback")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_SETLOCAL, FAIL, "error during user callback")
|
||||
} /* end if */
|
||||
break;
|
||||
|
||||
default:
|
||||
HDassert ("invalid prelude type" && 0);
|
||||
HDassert("invalid prelude type" && 0);
|
||||
} /* end switch */
|
||||
} /* end else */
|
||||
} /* end for */
|
||||
@ -749,28 +752,32 @@ static herr_t
|
||||
H5Z_prepare_prelude_callback_dcpl(hid_t dcpl_id, hid_t type_id, H5Z_prelude_type_t prelude_type)
|
||||
{
|
||||
hid_t space_id = -1; /* ID for dataspace describing chunk */
|
||||
H5O_layout_t *dcpl_layout = NULL; /* Dataset's layout information */
|
||||
herr_t ret_value = SUCCEED; /* Return value */
|
||||
|
||||
FUNC_ENTER_NOAPI_NOINIT
|
||||
|
||||
HDassert (H5I_GENPROP_LST == H5I_get_type(dcpl_id));
|
||||
HDassert (H5I_DATATYPE == H5I_get_type(type_id));
|
||||
HDassert(H5I_GENPROP_LST == H5I_get_type(dcpl_id));
|
||||
HDassert(H5I_DATATYPE == H5I_get_type(type_id));
|
||||
|
||||
/* Check if the property list is non-default */
|
||||
if (dcpl_id != H5P_DATASET_CREATE_DEFAULT) {
|
||||
H5P_genplist_t *dc_plist; /* Dataset creation property list object */
|
||||
H5O_layout_t dcpl_layout; /* Dataset's layout information */
|
||||
H5P_genplist_t *dc_plist; /* Dataset creation property list object */
|
||||
|
||||
/* Get memory for the layout */
|
||||
if (NULL == (dcpl_layout = (H5O_layout_t *)H5MM_calloc(sizeof(H5O_layout_t))))
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, FAIL, "unable to allocate dcpl layout buffer")
|
||||
|
||||
/* Get dataset creation property list object */
|
||||
if (NULL == (dc_plist = (H5P_genplist_t *)H5I_object(dcpl_id)))
|
||||
HGOTO_ERROR (H5E_ARGS, H5E_BADTYPE, FAIL, "can't get dataset creation property list")
|
||||
|
||||
/* Peek at the layout information */
|
||||
if (H5P_peek(dc_plist, H5D_CRT_LAYOUT_NAME, &dcpl_layout) < 0)
|
||||
if (H5P_peek(dc_plist, H5D_CRT_LAYOUT_NAME, dcpl_layout) < 0)
|
||||
HGOTO_ERROR (H5E_PLIST, H5E_CANTGET, FAIL, "can't retrieve layout")
|
||||
|
||||
/* Check if the dataset is chunked */
|
||||
if (H5D_CHUNKED == dcpl_layout.type) {
|
||||
if (H5D_CHUNKED == dcpl_layout->type) {
|
||||
H5O_pline_t dcpl_pline; /* Object's I/O pipeline information */
|
||||
|
||||
/* Get I/O pipeline information */
|
||||
@ -784,28 +791,31 @@ H5Z_prepare_prelude_callback_dcpl(hid_t dcpl_id, hid_t type_id, H5Z_prelude_type
|
||||
size_t u; /* Local index variable */
|
||||
|
||||
/* Create a dataspace for a chunk & set the extent */
|
||||
for (u = 0; u < dcpl_layout.u.chunk.ndims; u++)
|
||||
chunk_dims[u] = dcpl_layout.u.chunk.dim[u];
|
||||
if (NULL == (space = H5S_create_simple(dcpl_layout.u.chunk.ndims, chunk_dims, NULL)))
|
||||
for (u = 0; u < dcpl_layout->u.chunk.ndims; u++)
|
||||
chunk_dims[u] = dcpl_layout->u.chunk.dim[u];
|
||||
if (NULL == (space = H5S_create_simple(dcpl_layout->u.chunk.ndims, chunk_dims, NULL)))
|
||||
HGOTO_ERROR (H5E_DATASPACE, H5E_CANTCREATE, FAIL, "can't create simple dataspace")
|
||||
|
||||
/* Get ID for dataspace to pass to filter routines */
|
||||
if ((space_id = H5I_register(H5I_DATASPACE, space, FALSE)) < 0) {
|
||||
(void)H5S_close (space);
|
||||
(void)H5S_close(space);
|
||||
HGOTO_ERROR (H5E_ATOM, H5E_CANTREGISTER, FAIL, "unable to register dataspace ID")
|
||||
} /* end if */
|
||||
}
|
||||
|
||||
/* Make the callbacks */
|
||||
if (H5Z_prelude_callback(&dcpl_pline, dcpl_id, type_id, space_id, prelude_type) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANAPPLY, FAIL, "unable to apply filter")
|
||||
} /* end if */
|
||||
} /* end if */
|
||||
} /* end if */
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
done:
|
||||
if (space_id > 0 && H5I_dec_ref(space_id) < 0)
|
||||
HDONE_ERROR(H5E_PLINE, H5E_CANTRELEASE, FAIL, "unable to close dataspace")
|
||||
|
||||
if (dcpl_layout)
|
||||
dcpl_layout = (H5O_layout_t *)H5MM_xfree(dcpl_layout);
|
||||
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
} /* end H5Z_prepare_prelude_callback_dcpl() */
|
||||
|
||||
@ -834,7 +844,7 @@ H5Z_can_apply(hid_t dcpl_id, hid_t type_id)
|
||||
|
||||
/* Make "can apply" callbacks for filters in pipeline */
|
||||
if (H5Z_prepare_prelude_callback_dcpl(dcpl_id, type_id, H5Z_PRELUDE_CAN_APPLY) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANAPPLY, FAIL, "unable to apply filter")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANAPPLY, FAIL, "unable to apply filter")
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
@ -865,7 +875,7 @@ H5Z_set_local(hid_t dcpl_id, hid_t type_id)
|
||||
|
||||
/* Make "set local" callbacks for filters in pipeline */
|
||||
if (H5Z_prepare_prelude_callback_dcpl(dcpl_id, type_id, H5Z_PRELUDE_SET_LOCAL) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_SETLOCAL, FAIL, "local filter parameters not set")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_SETLOCAL, FAIL, "local filter parameters not set")
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
@ -890,11 +900,11 @@ H5Z_can_apply_direct(const H5O_pline_t *pline)
|
||||
|
||||
FUNC_ENTER_NOAPI(FAIL)
|
||||
|
||||
HDassert (pline->nused > 0);
|
||||
HDassert(pline->nused > 0);
|
||||
|
||||
/* Make "can apply" callbacks for filters in pipeline */
|
||||
if (H5Z_prelude_callback(pline, (hid_t)-1, (hid_t)-1, (hid_t)-1, H5Z_PRELUDE_CAN_APPLY) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANAPPLY, FAIL, "unable to apply filter")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANAPPLY, FAIL, "unable to apply filter")
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
@ -923,11 +933,11 @@ H5Z_set_local_direct(const H5O_pline_t *pline)
|
||||
|
||||
FUNC_ENTER_NOAPI(FAIL)
|
||||
|
||||
HDassert (pline->nused > 0);
|
||||
HDassert(pline->nused > 0);
|
||||
|
||||
/* Make "set local" callbacks for filters in pipeline */
|
||||
if (H5Z_prelude_callback(pline, (hid_t)-1, (hid_t)-1, (hid_t)-1, H5Z_PRELUDE_SET_LOCAL) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_SETLOCAL, FAIL, "local filter parameters not set")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_SETLOCAL, FAIL, "local filter parameters not set")
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
@ -952,10 +962,10 @@ H5Z_modify(const H5O_pline_t *pline, H5Z_filter_t filter, unsigned flags,
|
||||
|
||||
FUNC_ENTER_NOAPI(FAIL)
|
||||
|
||||
HDassert (pline);
|
||||
HDassert (filter >= 0 && filter <= H5Z_FILTER_MAX);
|
||||
HDassert (0 == (flags & ~((unsigned)H5Z_FLAG_DEFMASK)));
|
||||
HDassert (0 == cd_nelmts || cd_values);
|
||||
HDassert(pline);
|
||||
HDassert(filter >= 0 && filter <= H5Z_FILTER_MAX);
|
||||
HDassert(0 == (flags & ~((unsigned)H5Z_FLAG_DEFMASK)));
|
||||
HDassert(0 == cd_nelmts || cd_values);
|
||||
|
||||
/* Locate the filter in the pipeline */
|
||||
for (idx = 0; idx < pline->nused; idx++)
|
||||
@ -964,7 +974,7 @@ H5Z_modify(const H5O_pline_t *pline, H5Z_filter_t filter, unsigned flags,
|
||||
|
||||
/* Check if the filter was not already in the pipeline */
|
||||
if (idx > pline->nused)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_NOTFOUND, FAIL, "filter not in pipeline")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_NOTFOUND, FAIL, "filter not in pipeline")
|
||||
|
||||
/* Change parameters for filter */
|
||||
pline->filter[idx].flags = flags;
|
||||
@ -982,7 +992,7 @@ H5Z_modify(const H5O_pline_t *pline, H5Z_filter_t filter, unsigned flags,
|
||||
if (cd_nelmts > H5Z_COMMON_CD_VALUES) {
|
||||
pline->filter[idx].cd_values = (unsigned *)H5MM_malloc(cd_nelmts * sizeof(unsigned));
|
||||
if (NULL == pline->filter[idx].cd_values)
|
||||
HGOTO_ERROR (H5E_RESOURCE, H5E_NOSPACE, FAIL, "memory allocation failed for filter parameters")
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, FAIL, "memory allocation failed for filter parameters")
|
||||
} /* end if */
|
||||
else
|
||||
pline->filter[idx].cd_values = pline->filter[idx]._cd_values;
|
||||
@ -1017,10 +1027,10 @@ H5Z_append(H5O_pline_t *pline, H5Z_filter_t filter, unsigned flags,
|
||||
|
||||
FUNC_ENTER_NOAPI(FAIL)
|
||||
|
||||
HDassert (pline);
|
||||
HDassert (filter >= 0 && filter <= H5Z_FILTER_MAX);
|
||||
HDassert (0 == (flags & ~((unsigned)H5Z_FLAG_DEFMASK)));
|
||||
HDassert (0 == cd_nelmts || cd_values);
|
||||
HDassert(pline);
|
||||
HDassert(filter >= 0 && filter <= H5Z_FILTER_MAX);
|
||||
HDassert(0 == (flags & ~((unsigned)H5Z_FLAG_DEFMASK)));
|
||||
HDassert(0 == cd_nelmts || cd_values);
|
||||
|
||||
/*
|
||||
* Check filter limit. We do it here for early warnings although we may
|
||||
@ -1052,13 +1062,13 @@ H5Z_append(H5O_pline_t *pline, H5Z_filter_t filter, unsigned flags,
|
||||
x.nalloc = MAX(H5Z_MAX_NFILTERS, 2 * pline->nalloc);
|
||||
x.filter = (H5Z_filter_info_t *)H5MM_realloc(pline->filter, x.nalloc * sizeof(x.filter[0]));
|
||||
if (NULL == x.filter)
|
||||
HGOTO_ERROR (H5E_RESOURCE, H5E_NOSPACE, FAIL, "memory allocation failed for filter pipeline")
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, FAIL, "memory allocation failed for filter pipeline")
|
||||
|
||||
/* Fix pointers in previous filters that need to point to their own
|
||||
* internal data.
|
||||
*/
|
||||
for(n = 0; n < pline->nalloc; ++n)
|
||||
if(x.filter[n].cd_values == (void *) ~((size_t) NULL))
|
||||
for (n = 0; n < pline->nalloc; ++n)
|
||||
if (x.filter[n].cd_values == (void *) ~((size_t) NULL))
|
||||
x.filter[n].cd_values = x.filter[n]._cd_values;
|
||||
|
||||
/* Point to newly allocated buffer */
|
||||
@ -1079,7 +1089,7 @@ H5Z_append(H5O_pline_t *pline, H5Z_filter_t filter, unsigned flags,
|
||||
if (cd_nelmts > H5Z_COMMON_CD_VALUES) {
|
||||
pline->filter[idx].cd_values = (unsigned *)H5MM_malloc(cd_nelmts * sizeof(unsigned));
|
||||
if (NULL == pline->filter[idx].cd_values)
|
||||
HGOTO_ERROR (H5E_RESOURCE, H5E_NOSPACE, FAIL, "memory allocation failed for filter")
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, FAIL, "memory allocation failed for filter")
|
||||
} /* end if */
|
||||
else
|
||||
pline->filter[idx].cd_values = pline->filter[idx]._cd_values;
|
||||
@ -1118,7 +1128,7 @@ H5Z_find_idx(H5Z_filter_t id)
|
||||
|
||||
for (i = 0; i < H5Z_table_used_g; i++)
|
||||
if (H5Z_table_g[i].id == id)
|
||||
HGOTO_DONE ((int)i)
|
||||
HGOTO_DONE((int)i)
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
@ -1145,10 +1155,10 @@ H5Z_find(H5Z_filter_t id)
|
||||
|
||||
/* Get the index in the global table */
|
||||
if ((idx = H5Z_find_idx(id)) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_NOTFOUND, NULL, "required filter %d is not registered", id)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_NOTFOUND, NULL, "required filter %d is not registered", id)
|
||||
|
||||
/* Set return value */
|
||||
ret_value = H5Z_table_g+idx;
|
||||
ret_value = H5Z_table_g + idx;
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
@ -1197,12 +1207,12 @@ H5Z_pipeline(const H5O_pline_t *pline, unsigned flags,
|
||||
|
||||
FUNC_ENTER_NOAPI(FAIL)
|
||||
|
||||
HDassert (0 == (flags & ~((unsigned)H5Z_FLAG_INVMASK)));
|
||||
HDassert (filter_mask);
|
||||
HDassert (nbytes && *nbytes>0);
|
||||
HDassert (buf_size && *buf_size>0);
|
||||
HDassert (buf && *buf);
|
||||
HDassert (!pline || pline->nused<H5Z_MAX_NFILTERS);
|
||||
HDassert(0 == (flags & ~((unsigned)H5Z_FLAG_INVMASK)));
|
||||
HDassert(filter_mask);
|
||||
HDassert(nbytes && *nbytes>0);
|
||||
HDassert(buf_size && *buf_size>0);
|
||||
HDassert(buf && *buf);
|
||||
HDassert(!pline || pline->nused < H5Z_MAX_NFILTERS);
|
||||
|
||||
if (pline && (flags & H5Z_FLAG_REVERSE)) { /* Read */
|
||||
for (i = pline->nused; i > 0; --i) {
|
||||
@ -1219,18 +1229,20 @@ H5Z_pipeline(const H5O_pline_t *pline, unsigned flags,
|
||||
*/
|
||||
if ((fclass_idx = H5Z_find_idx(pline->filter[idx].id)) < 0) {
|
||||
hbool_t issue_error = FALSE;
|
||||
H5PL_key_t key;
|
||||
const H5Z_class2_t *filter_info;
|
||||
|
||||
/* Try loading the filter */
|
||||
if (NULL != (filter_info = (const H5Z_class2_t *)H5PL_load(H5PL_TYPE_FILTER, (int)(pline->filter[idx].id)))) {
|
||||
key.id = (int)(pline->filter[idx].id);
|
||||
if(NULL != (filter_info = (const H5Z_class2_t *)H5PL_load(H5PL_TYPE_FILTER, key))) {
|
||||
/* Register the filter we loaded */
|
||||
if (H5Z_register(filter_info) < 0)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register filter")
|
||||
if(H5Z_register(filter_info) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTINIT, FAIL, "unable to register filter")
|
||||
|
||||
/* Search in the table of registered filters again to find the dynamic filter just loaded and registered */
|
||||
if ((fclass_idx = H5Z_find_idx(pline->filter[idx].id)) < 0)
|
||||
issue_error = TRUE;
|
||||
} /* end if */
|
||||
}
|
||||
else
|
||||
issue_error = TRUE;
|
||||
|
||||
@ -1242,7 +1254,7 @@ H5Z_pipeline(const H5O_pline_t *pline, unsigned flags,
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_READERROR, FAIL, "required filter '%s' is not registered", pline->filter[idx].name)
|
||||
else
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_READERROR, FAIL, "required filter (name unavailable) is not registered")
|
||||
} /* end if */
|
||||
}
|
||||
} /* end if */
|
||||
|
||||
fclass = &H5Z_table_g[fclass_idx];
|
||||
@ -1258,12 +1270,13 @@ H5Z_pipeline(const H5O_pline_t *pline, unsigned flags,
|
||||
#ifdef H5Z_DEBUG
|
||||
H5_timer_end (&(fstats->stats[1].timer), &timer);
|
||||
fstats->stats[1].total += MAX(*nbytes, new_nbytes);
|
||||
if (0 == new_nbytes) fstats->stats[1].errors += *nbytes;
|
||||
if (0 == new_nbytes)
|
||||
fstats->stats[1].errors += *nbytes;
|
||||
#endif
|
||||
|
||||
if (0 == new_nbytes) {
|
||||
if ((cb_struct.func && (H5Z_CB_FAIL == cb_struct.func (pline->filter[idx].id, *buf, *buf_size, cb_struct.op_data))) || !cb_struct.func)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_READERROR, FAIL, "filter returned failure during read")
|
||||
if ((cb_struct.func && (H5Z_CB_FAIL == cb_struct.func(pline->filter[idx].id, *buf, *buf_size, cb_struct.op_data))) || !cb_struct.func)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_READERROR, FAIL, "filter returned failure during read")
|
||||
|
||||
*nbytes = *buf_size;
|
||||
failed |= (unsigned)1 << idx;
|
||||
@ -1298,12 +1311,13 @@ H5Z_pipeline(const H5O_pline_t *pline, unsigned flags,
|
||||
#ifdef H5Z_DEBUG
|
||||
H5_timer_end (&(fstats->stats[0].timer), &timer);
|
||||
fstats->stats[0].total += MAX(*nbytes, new_nbytes);
|
||||
if (0 == new_nbytes) fstats->stats[0].errors += *nbytes;
|
||||
if (0 == new_nbytes)
|
||||
fstats->stats[0].errors += *nbytes;
|
||||
#endif
|
||||
if (0 == new_nbytes) {
|
||||
if (0 == (pline->filter[idx].flags & H5Z_FLAG_OPTIONAL)) {
|
||||
if ((cb_struct.func && (H5Z_CB_FAIL == cb_struct.func (pline->filter[idx].id, *buf, *nbytes, cb_struct.op_data))) || !cb_struct.func)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_WRITEERROR, FAIL, "filter returned failure")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_WRITEERROR, FAIL, "filter returned failure")
|
||||
|
||||
*nbytes = *buf_size;
|
||||
}
|
||||
@ -1340,8 +1354,8 @@ H5Z_filter_info(const H5O_pline_t *pline, H5Z_filter_t filter)
|
||||
|
||||
FUNC_ENTER_NOAPI(NULL)
|
||||
|
||||
HDassert (pline);
|
||||
HDassert (filter >= 0 && filter <= H5Z_FILTER_MAX);
|
||||
HDassert(pline);
|
||||
HDassert(filter >= 0 && filter <= H5Z_FILTER_MAX);
|
||||
|
||||
/* Locate the filter in the pipeline */
|
||||
for (idx = 0; idx < pline->nused; idx++)
|
||||
@ -1350,7 +1364,7 @@ H5Z_filter_info(const H5O_pline_t *pline, H5Z_filter_t filter)
|
||||
|
||||
/* Check if the filter was not already in the pipeline */
|
||||
if (idx >= pline->nused)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_NOTFOUND, NULL, "filter not in pipeline")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_NOTFOUND, NULL, "filter not in pipeline")
|
||||
|
||||
/* Set return value */
|
||||
ret_value = &pline->filter[idx];
|
||||
@ -1379,8 +1393,8 @@ H5Z_filter_in_pline(const H5O_pline_t *pline, H5Z_filter_t filter)
|
||||
|
||||
FUNC_ENTER_NOAPI(FAIL)
|
||||
|
||||
HDassert (pline);
|
||||
HDassert (filter >= 0 && filter <= H5Z_FILTER_MAX);
|
||||
HDassert(pline);
|
||||
HDassert(filter >= 0 && filter <= H5Z_FILTER_MAX);
|
||||
|
||||
/* Locate the filter in the pipeline */
|
||||
for (idx = 0; idx < pline->nused; idx++)
|
||||
@ -1416,7 +1430,7 @@ H5Z_all_filters_avail(const H5O_pline_t *pline)
|
||||
FUNC_ENTER_NOAPI(FAIL)
|
||||
|
||||
/* Check args */
|
||||
HDassert (pline);
|
||||
HDassert(pline);
|
||||
|
||||
/* Iterate through all the filters in pipeline */
|
||||
for (i = 0; i < pline->nused; i++) {
|
||||
@ -1427,7 +1441,7 @@ H5Z_all_filters_avail(const H5O_pline_t *pline)
|
||||
|
||||
/* Check if we didn't find the filter */
|
||||
if (j == H5Z_table_used_g)
|
||||
HGOTO_DONE (FALSE)
|
||||
HGOTO_DONE(FALSE)
|
||||
} /* end for */
|
||||
|
||||
done:
|
||||
@ -1454,8 +1468,8 @@ H5Z_delete(H5O_pline_t *pline, H5Z_filter_t filter)
|
||||
FUNC_ENTER_NOAPI(FAIL)
|
||||
|
||||
/* Check args */
|
||||
HDassert (pline);
|
||||
HDassert (filter >= 0 && filter <= H5Z_FILTER_MAX);
|
||||
HDassert(pline);
|
||||
HDassert(filter >= 0 && filter <= H5Z_FILTER_MAX);
|
||||
|
||||
/* if the pipeline has no filters, just return */
|
||||
if (pline->nused == 0)
|
||||
@ -1465,7 +1479,7 @@ H5Z_delete(H5O_pline_t *pline, H5Z_filter_t filter)
|
||||
if (H5Z_FILTER_ALL == filter) {
|
||||
if (H5O_msg_reset(H5O_PLINE_ID, pline) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTFREE, FAIL, "can't release pipeline info")
|
||||
} /* end if */
|
||||
}
|
||||
/* Delete filter */
|
||||
else {
|
||||
size_t idx; /* Index of filter in pipeline */
|
||||
@ -1476,19 +1490,19 @@ H5Z_delete(H5O_pline_t *pline, H5Z_filter_t filter)
|
||||
if (pline->filter[idx].id == filter) {
|
||||
found = TRUE;
|
||||
break;
|
||||
} /* end if */
|
||||
}
|
||||
|
||||
/* filter was not found in the pipeline */
|
||||
if (!found)
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_NOTFOUND, FAIL, "filter not in pipeline")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_NOTFOUND, FAIL, "filter not in pipeline")
|
||||
|
||||
/* Free information for deleted filter */
|
||||
if (pline->filter[idx].name && pline->filter[idx].name != pline->filter[idx]._name)
|
||||
HDassert ((HDstrlen(pline->filter[idx].name) + 1) > H5Z_COMMON_NAME_LEN);
|
||||
HDassert((HDstrlen(pline->filter[idx].name) + 1) > H5Z_COMMON_NAME_LEN);
|
||||
if (pline->filter[idx].name != pline->filter[idx]._name)
|
||||
pline->filter[idx].name = (char *)H5MM_xfree(pline->filter[idx].name);
|
||||
if (pline->filter[idx].cd_values && pline->filter[idx].cd_values != pline->filter[idx]._cd_values)
|
||||
HDassert (pline->filter[idx].cd_nelmts > H5Z_COMMON_CD_VALUES);
|
||||
HDassert(pline->filter[idx].cd_nelmts > H5Z_COMMON_CD_VALUES);
|
||||
if (pline->filter[idx].cd_values != pline->filter[idx]._cd_values)
|
||||
pline->filter[idx].cd_values = (unsigned *)H5MM_xfree(pline->filter[idx].cd_values);
|
||||
|
||||
@ -1501,8 +1515,8 @@ H5Z_delete(H5O_pline_t *pline, H5Z_filter_t filter)
|
||||
pline->filter[idx].name = pline->filter[idx]._name;
|
||||
if (pline->filter[idx].cd_nelmts <= H5Z_COMMON_CD_VALUES)
|
||||
pline->filter[idx].cd_values = pline->filter[idx]._cd_values;
|
||||
} /* end for */
|
||||
} /* end if */
|
||||
}
|
||||
}
|
||||
|
||||
/* Decrement number of used filters */
|
||||
pline->nused--;
|
||||
@ -1563,7 +1577,7 @@ H5Z_get_filter_info(H5Z_filter_t filter, unsigned int *filter_config_flags)
|
||||
|
||||
/* Look up the filter class info */
|
||||
if (NULL == (fclass = H5Z_find(filter)))
|
||||
HGOTO_ERROR (H5E_PLINE, H5E_BADVALUE, FAIL, "Filter not defined")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_BADVALUE, FAIL, "Filter not defined")
|
||||
|
||||
/* Set the filter config flags for the application */
|
||||
if (filter_config_flags != NULL) {
|
||||
|
@ -18,6 +18,9 @@
|
||||
#ifndef _H5Zprivate_H
|
||||
#define _H5Zprivate_H
|
||||
|
||||
/* Early typedefs to avoid circular dependencies */
|
||||
typedef struct H5Z_filter_info_t H5Z_filter_info_t;
|
||||
|
||||
/* Include package's public header */
|
||||
#include "H5Zpublic.h"
|
||||
|
||||
@ -49,7 +52,7 @@
|
||||
/****************************/
|
||||
|
||||
/* Structure to store information about each filter's parameters */
|
||||
typedef struct H5Z_filter_info_t {
|
||||
struct H5Z_filter_info_t {
|
||||
H5Z_filter_t id; /*filter identification number */
|
||||
unsigned flags; /*defn and invocation flags */
|
||||
char _name[H5Z_COMMON_NAME_LEN]; /*internal filter name */
|
||||
@ -57,7 +60,7 @@ typedef struct H5Z_filter_info_t {
|
||||
size_t cd_nelmts; /*number of elements in cd_values[] */
|
||||
unsigned _cd_values[H5Z_COMMON_CD_VALUES]; /*internal client data values */
|
||||
unsigned *cd_values; /*client data values */
|
||||
} H5Z_filter_info_t;
|
||||
};
|
||||
|
||||
/*****************************/
|
||||
/* Library-private Variables */
|
||||
|
@ -129,8 +129,8 @@ typedef H5Z_cb_return_t (*H5Z_filter_func_t)(H5Z_filter_t filter, void* buf,
|
||||
|
||||
/* Structure for filter callback property */
|
||||
typedef struct H5Z_cb_t {
|
||||
H5Z_filter_func_t func;
|
||||
void* op_data;
|
||||
H5Z_filter_func_t func;
|
||||
void *op_data;
|
||||
} H5Z_cb_t;
|
||||
|
||||
#ifdef __cplusplus
|
||||
@ -206,14 +206,14 @@ typedef size_t (*H5Z_func_t)(unsigned int flags, size_t cd_nelmts,
|
||||
* contain a pointers to the filter function and timing statistics.
|
||||
*/
|
||||
typedef struct H5Z_class2_t {
|
||||
int version; /* Version number of the H5Z_class_t struct */
|
||||
H5Z_filter_t id; /* Filter ID number */
|
||||
unsigned encoder_present; /* Does this filter have an encoder? */
|
||||
unsigned decoder_present; /* Does this filter have a decoder? */
|
||||
const char *name; /* Comment for debugging */
|
||||
H5Z_can_apply_func_t can_apply; /* The "can apply" callback for a filter */
|
||||
H5Z_set_local_func_t set_local; /* The "set local" callback for a filter */
|
||||
H5Z_func_t filter; /* The actual filter function */
|
||||
int version; /* Version number of the H5Z_class_t struct */
|
||||
H5Z_filter_t id; /* Filter ID number */
|
||||
unsigned encoder_present; /* Does this filter have an encoder? */
|
||||
unsigned decoder_present; /* Does this filter have a decoder? */
|
||||
const char *name; /* Comment for debugging */
|
||||
H5Z_can_apply_func_t can_apply; /* The "can apply" callback for a filter */
|
||||
H5Z_set_local_func_t set_local; /* The "set local" callback for a filter */
|
||||
H5Z_func_t filter; /* The actual filter function */
|
||||
} H5Z_class2_t;
|
||||
|
||||
H5_DLL herr_t H5Zregister(const void *cls);
|
||||
|
@ -70,8 +70,6 @@ H5Z_class2_t H5Z_SZIP[1] = {{
|
||||
* Programmer: Quincey Koziol
|
||||
* Monday, April 7, 2003
|
||||
*
|
||||
* Modifications:
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static htri_t
|
||||
@ -86,24 +84,24 @@ H5Z_can_apply_szip(hid_t H5_ATTR_UNUSED dcpl_id, hid_t type_id, hid_t H5_ATTR_UN
|
||||
|
||||
/* Get datatype */
|
||||
if(NULL == (type = (H5T_t *)H5I_object_verify(type_id, H5I_DATATYPE)))
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, FAIL, "not a datatype")
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, FAIL, "not a datatype")
|
||||
|
||||
/* Get datatype's size, for checking the "bits-per-pixel" */
|
||||
if((dtype_size = (8 * H5T_get_size(type))) == 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_BADTYPE, FAIL, "bad datatype size")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_BADTYPE, FAIL, "bad datatype size")
|
||||
|
||||
/* Range check datatype's size */
|
||||
if(dtype_size > 32 && dtype_size != 64)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FALSE, "invalid datatype size")
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FALSE, "invalid datatype size")
|
||||
|
||||
/* Get datatype's endianness order */
|
||||
if((dtype_order = H5T_get_order(type)) == H5T_ORDER_ERROR)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_BADTYPE, FAIL, "can't retrieve datatype endianness order")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_BADTYPE, FAIL, "can't retrieve datatype endianness order")
|
||||
|
||||
/* Range check datatype's endianness order */
|
||||
/* (Note: this may not handle non-atomic datatypes well) */
|
||||
if(dtype_order != H5T_ORDER_LE && dtype_order != H5T_ORDER_BE)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FALSE, "invalid datatype endianness order")
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, FALSE, "invalid datatype endianness order")
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
@ -157,19 +155,19 @@ H5Z_set_local_szip(hid_t dcpl_id, hid_t type_id, hid_t space_id)
|
||||
|
||||
/* Get datatype */
|
||||
if(NULL == (type = (H5T_t *)H5I_object_verify(type_id, H5I_DATATYPE)))
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, FAIL, "not a datatype")
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADTYPE, FAIL, "not a datatype")
|
||||
|
||||
/* Get the filter's current parameters */
|
||||
if(H5P_get_filter_by_id(dcpl_plist, H5Z_FILTER_SZIP, &flags, &cd_nelmts, cd_values, 0, NULL, NULL) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTGET, FAIL, "can't get szip parameters")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTGET, FAIL, "can't get szip parameters")
|
||||
|
||||
/* Get datatype's size, for checking the "bits-per-pixel" */
|
||||
if((dtype_size = (8 * H5T_get_size(type))) == 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_BADTYPE, FAIL, "bad datatype size");
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_BADTYPE, FAIL, "bad datatype size");
|
||||
|
||||
/* Get datatype's precision, in case is less than full bits */
|
||||
if((dtype_precision = H5T_get_precision(type)) == 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_BADTYPE, FAIL, "bad datatype precision");
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_BADTYPE, FAIL, "bad datatype precision");
|
||||
|
||||
if(dtype_precision < dtype_size) {
|
||||
dtype_offset = H5T_get_offset(type);
|
||||
@ -177,9 +175,9 @@ H5Z_set_local_szip(hid_t dcpl_id, hid_t type_id, hid_t space_id)
|
||||
dtype_precision = dtype_size;
|
||||
} /* end if */
|
||||
if(dtype_precision > 24) {
|
||||
if(dtype_precision <= 32)
|
||||
if(dtype_precision <= 32)
|
||||
dtype_precision = 32;
|
||||
else if(dtype_precision <= 64)
|
||||
else if(dtype_precision <= 64)
|
||||
dtype_precision = 64;
|
||||
} /* end if */
|
||||
|
||||
@ -227,7 +225,7 @@ H5Z_set_local_szip(hid_t dcpl_id, hid_t type_id, hid_t space_id)
|
||||
|
||||
/* Get datatype's endianness order */
|
||||
if((dtype_order = H5T_get_order(type)) == H5T_ORDER_ERROR)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_BADTYPE, FAIL, "bad datatype endianness order")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_BADTYPE, FAIL, "bad datatype endianness order")
|
||||
|
||||
/* Set the correct endianness flag for szip */
|
||||
/* (Note: this may not handle non-atomic datatypes well) */
|
||||
@ -241,13 +239,17 @@ H5Z_set_local_szip(hid_t dcpl_id, hid_t type_id, hid_t space_id)
|
||||
cd_values[H5Z_SZIP_PARM_MASK] |= SZ_MSB_OPTION_MASK;
|
||||
break;
|
||||
|
||||
case H5T_ORDER_ERROR:
|
||||
case H5T_ORDER_VAX:
|
||||
case H5T_ORDER_MIXED:
|
||||
case H5T_ORDER_NONE:
|
||||
default:
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_BADTYPE, FAIL, "bad datatype endianness order")
|
||||
} /* end switch */
|
||||
|
||||
/* Modify the filter's parameters for this dataset */
|
||||
if(H5P_modify_filter(dcpl_plist, H5Z_FILTER_SZIP, flags, H5Z_SZIP_TOTAL_NPARMS, cd_values) < 0)
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTSET, FAIL, "can't set local szip parameters")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTSET, FAIL, "can't set local szip parameters")
|
||||
|
||||
done:
|
||||
FUNC_LEAVE_NOAPI(ret_value)
|
||||
@ -266,10 +268,6 @@ done:
|
||||
* Programmer: Kent Yang
|
||||
* Tuesday, April 1, 2003
|
||||
*
|
||||
* Modifications:
|
||||
* Quincey Koziol, April 2, 2003
|
||||
* Cleaned up code.
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static size_t
|
||||
@ -296,7 +294,7 @@ H5Z_filter_szip (unsigned flags, size_t cd_nelmts, const unsigned cd_values[],
|
||||
|
||||
/* Check arguments */
|
||||
if (cd_nelmts!=4)
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, 0, "invalid number of filter parameters")
|
||||
HGOTO_ERROR(H5E_ARGS, H5E_BADVALUE, 0, "invalid number of filter parameters")
|
||||
|
||||
/* Copy the filter parameters into the szip parameter block */
|
||||
H5_CHECKED_ASSIGN(sz_param.options_mask, int, cd_values[H5Z_SZIP_PARM_MASK], unsigned);
|
||||
@ -310,12 +308,12 @@ H5Z_filter_szip (unsigned flags, size_t cd_nelmts, const unsigned cd_values[],
|
||||
size_t nalloc; /* Number of bytes the compressed block will expand into */
|
||||
|
||||
/* Get the size of the uncompressed buffer */
|
||||
newbuf = *buf;
|
||||
newbuf = (unsigned char *)(*buf);
|
||||
UINT32DECODE(newbuf,stored_nalloc);
|
||||
H5_CHECKED_ASSIGN(nalloc, size_t, stored_nalloc, uint32_t);
|
||||
|
||||
/* Allocate space for the uncompressed buffer */
|
||||
if(NULL==(outbuf = H5MM_malloc(nalloc)))
|
||||
if(NULL == (outbuf = (unsigned char *)H5MM_malloc(nalloc)))
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, 0, "memory allocation failed for szip decompression")
|
||||
|
||||
/* Decompress the buffer */
|
||||
@ -338,7 +336,7 @@ H5Z_filter_szip (unsigned flags, size_t cd_nelmts, const unsigned cd_values[],
|
||||
unsigned char *dst = NULL; /* Temporary pointer to new output buffer */
|
||||
|
||||
/* Allocate space for the compressed buffer & header (assume data won't get bigger) */
|
||||
if(NULL==(dst=outbuf = H5MM_malloc(nbytes+4)))
|
||||
if(NULL == (dst=outbuf = (unsigned char *)H5MM_malloc(nbytes+4)))
|
||||
HGOTO_ERROR(H5E_RESOURCE, H5E_NOSPACE, 0, "unable to allocate szip destination buffer")
|
||||
|
||||
/* Encode the uncompressed length */
|
||||
@ -348,7 +346,7 @@ H5Z_filter_szip (unsigned flags, size_t cd_nelmts, const unsigned cd_values[],
|
||||
/* Compress the buffer */
|
||||
size_out = nbytes;
|
||||
if(SZ_OK!= SZ_BufftoBuffCompress(dst, &size_out, *buf, nbytes, &sz_param))
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTINIT, 0, "overflow")
|
||||
HGOTO_ERROR(H5E_PLINE, H5E_CANTINIT, 0, "overflow")
|
||||
HDassert(size_out<=nbytes);
|
||||
|
||||
/* Free the input buffer */
|
||||
|
@ -977,7 +977,7 @@ Wround(double arg)
|
||||
float
|
||||
Wroundf(float arg)
|
||||
{
|
||||
return arg < 0.0F ? HDceil(arg - 0.5F) : HDfloor(arg + 0.5F);
|
||||
return (float)(arg < 0.0F ? HDceil(arg - 0.5F) : HDfloor(arg + 0.5F));
|
||||
}
|
||||
|
||||
#endif /* H5_HAVE_WIN32_API */
|
||||
|
@ -84,7 +84,7 @@ libhdf5_la_SOURCES= H5.c H5checksum.c H5dbg.c H5system.c H5timer.c H5trace.c \
|
||||
H5Ochunk.c \
|
||||
H5Ocont.c H5Ocopy.c H5Odbg.c H5Odrvinfo.c H5Odtype.c H5Oefl.c \
|
||||
H5Ofill.c H5Oflush.c H5Ofsinfo.c H5Oginfo.c \
|
||||
H5Olayout.c \
|
||||
H5Oint.c H5Olayout.c \
|
||||
H5Olinfo.c H5Olink.c H5Omessage.c H5Omtime.c \
|
||||
H5Oname.c H5Onull.c H5Opline.c H5Orefcount.c \
|
||||
H5Osdspace.c H5Oshared.c \
|
||||
@ -98,7 +98,7 @@ libhdf5_la_SOURCES= H5.c H5checksum.c H5dbg.c H5system.c H5timer.c H5trace.c \
|
||||
H5Plapl.c H5Plcpl.c H5Pocpl.c H5Pocpypl.c H5Pstrcpl.c H5Ptest.c \
|
||||
H5PB.c \
|
||||
H5PL.c H5PLint.c H5PLpath.c H5PLplugin_cache.c \
|
||||
H5R.c H5Rdeprec.c \
|
||||
H5R.c H5Rint.c H5Rdeprec.c \
|
||||
H5UC.c \
|
||||
H5RS.c \
|
||||
H5S.c H5Sall.c H5Sdbg.c H5Shyper.c H5Snone.c H5Spoint.c \
|
||||
|
@ -28,6 +28,7 @@ Linking Options:
|
||||
AM_LDFLAGS: @AM_LDFLAGS@
|
||||
Extra libraries: @LIBS@
|
||||
Archiver: @AR@
|
||||
AR_FLAGS: @AR_FLAGS@
|
||||
Ranlib: @RANLIB@
|
||||
|
||||
Languages:
|
||||
|
@ -70,73 +70,73 @@ if (BUILD_SHARED_LIBS)
|
||||
endif ()
|
||||
|
||||
#-----------------------------------------------------------------------------
|
||||
# If plugin library tests can be tested
|
||||
# If filter plugin tests can be tested
|
||||
#-----------------------------------------------------------------------------
|
||||
# make plugins dir
|
||||
file (MAKE_DIRECTORY "${CMAKE_BINARY_DIR}/testdir1")
|
||||
file (MAKE_DIRECTORY "${CMAKE_BINARY_DIR}/testdir2")
|
||||
file (MAKE_DIRECTORY "${CMAKE_BINARY_DIR}/filter_plugin_dir1")
|
||||
file (MAKE_DIRECTORY "${CMAKE_BINARY_DIR}/filter_plugin_dir2")
|
||||
|
||||
#-----------------------------------------------------------------------------
|
||||
# Define Plugin Test Sources
|
||||
# Define Filter Plugin Test Sources
|
||||
#-----------------------------------------------------------------------------
|
||||
set (TEST_PLUGIN_LIBS
|
||||
dynlib1
|
||||
dynlib3
|
||||
set (FILTER_PLUGINS_FOR_DIR1
|
||||
filter_plugin1_dsets
|
||||
filter_plugin3_dsets
|
||||
)
|
||||
set (TEST2_PLUGIN_LIBS
|
||||
dynlib2
|
||||
dynlib4
|
||||
set (FILTER_PLUGINS_FOR_DIR2
|
||||
filter_plugin2_dsets
|
||||
filter_plugin4_groups
|
||||
)
|
||||
|
||||
foreach (test_lib ${TEST_PLUGIN_LIBS})
|
||||
set (HDF5_TEST_PLUGIN_LIB_CORENAME "${test_lib}")
|
||||
set (HDF5_TEST_PLUGIN_LIB_NAME "${HDF5_EXTERNAL_LIB_PREFIX}${HDF5_TEST_PLUGIN_LIB_CORENAME}")
|
||||
set (HDF5_TEST_PLUGIN_LIB_TARGET ${HDF5_TEST_PLUGIN_LIB_CORENAME})
|
||||
foreach (plugin_name ${FILTER_PLUGINS_FOR_DIR1})
|
||||
set (HDF5_TEST_PLUGIN_CORENAME "${plugin_name}")
|
||||
set (HDF5_TEST_PLUGIN_NAME "${HDF5_EXTERNAL_LIB_PREFIX}${HDF5_TEST_PLUGIN_CORENAME}")
|
||||
set (HDF5_TEST_PLUGIN_TARGET ${HDF5_TEST_PLUGIN_CORENAME})
|
||||
add_definitions (${HDF_EXTRA_C_FLAGS})
|
||||
INCLUDE_DIRECTORIES (${HDF5_SRC_DIR})
|
||||
|
||||
add_library (${HDF5_TEST_PLUGIN_LIB_TARGET} SHARED ${HDF5_TEST_SOURCE_DIR}/${test_lib}.c)
|
||||
TARGET_C_PROPERTIES (${HDF5_TEST_PLUGIN_LIB_TARGET} SHARED " " " ")
|
||||
target_link_libraries (${HDF5_TEST_PLUGIN_LIB_TARGET} ${HDF5_TEST_LIB_TARGET})
|
||||
H5_SET_LIB_OPTIONS (${HDF5_TEST_PLUGIN_LIB_TARGET} ${HDF5_TEST_PLUGIN_LIB_NAME} SHARED ${HDF5_PACKAGE_SOVERSION})
|
||||
set_target_properties (${HDF5_TEST_PLUGIN_LIB_TARGET} PROPERTIES FOLDER libraries/TEST_PLUGIN)
|
||||
add_library (${HDF5_TEST_PLUGIN_TARGET} SHARED ${HDF5_TEST_SOURCE_DIR}/${plugin_name}.c)
|
||||
TARGET_C_PROPERTIES (${HDF5_TEST_PLUGIN_TARGET} SHARED " " " ")
|
||||
target_link_libraries (${HDF5_TEST_PLUGIN_TARGET} ${HDF5_TEST_LIB_TARGET})
|
||||
H5_SET_LIB_OPTIONS (${HDF5_TEST_PLUGIN_TARGET} ${HDF5_TEST_PLUGIN_NAME} SHARED ${HDF5_PACKAGE_SOVERSION})
|
||||
set_target_properties (${HDF5_TEST_PLUGIN_TARGET} PROPERTIES FOLDER libraries/TEST_PLUGIN)
|
||||
|
||||
#-----------------------------------------------------------------------------
|
||||
# Copy plugin library to a plugins folder
|
||||
# Copy the filter plugin to a plugins folder
|
||||
#-----------------------------------------------------------------------------
|
||||
add_custom_command (
|
||||
TARGET ${HDF5_TEST_PLUGIN_LIB_TARGET}
|
||||
TARGET ${HDF5_TEST_PLUGIN_TARGET}
|
||||
POST_BUILD
|
||||
COMMAND ${CMAKE_COMMAND}
|
||||
ARGS -E copy_if_different
|
||||
"$<TARGET_FILE:${HDF5_TEST_PLUGIN_LIB_TARGET}>"
|
||||
"${CMAKE_BINARY_DIR}/testdir1/$<TARGET_FILE_NAME:${HDF5_TEST_PLUGIN_LIB_TARGET}>"
|
||||
"$<TARGET_FILE:${HDF5_TEST_PLUGIN_TARGET}>"
|
||||
"${CMAKE_BINARY_DIR}/filter_plugin_dir1/$<TARGET_FILE_NAME:${HDF5_TEST_PLUGIN_TARGET}>"
|
||||
)
|
||||
endforeach ()
|
||||
|
||||
foreach (test_lib ${TEST2_PLUGIN_LIBS})
|
||||
set (HDF5_TEST_PLUGIN_LIB_CORENAME "${test_lib}")
|
||||
set (HDF5_TEST_PLUGIN_LIB_NAME "${HDF5_EXTERNAL_LIB_PREFIX}${HDF5_TEST_PLUGIN_LIB_CORENAME}")
|
||||
set (HDF5_TEST_PLUGIN_LIB_TARGET ${HDF5_TEST_PLUGIN_LIB_CORENAME})
|
||||
foreach ( plugin_name ${FILTER_PLUGINS_FOR_DIR2})
|
||||
set (HDF5_TEST_PLUGIN_CORENAME "${plugin_name}")
|
||||
set (HDF5_TEST_PLUGIN_NAME "${HDF5_EXTERNAL_LIB_PREFIX}${HDF5_TEST_PLUGIN_CORENAME}")
|
||||
set (HDF5_TEST_PLUGIN_TARGET ${HDF5_TEST_PLUGIN_CORENAME})
|
||||
add_definitions (${HDF_EXTRA_C_FLAGS})
|
||||
INCLUDE_DIRECTORIES (${HDF5_SRC_DIR})
|
||||
|
||||
add_library (${HDF5_TEST_PLUGIN_LIB_TARGET} SHARED ${HDF5_TEST_SOURCE_DIR}/${test_lib}.c)
|
||||
TARGET_C_PROPERTIES (${HDF5_TEST_PLUGIN_LIB_TARGET} SHARED " " " ")
|
||||
target_link_libraries (${HDF5_TEST_PLUGIN_LIB_TARGET} ${HDF5_TEST_LIB_TARGET})
|
||||
H5_SET_LIB_OPTIONS (${HDF5_TEST_PLUGIN_LIB_TARGET} ${HDF5_TEST_PLUGIN_LIB_NAME} SHARED ${HDF5_PACKAGE_SOVERSION})
|
||||
set_target_properties (${HDF5_TEST_PLUGIN_LIB_TARGET} PROPERTIES FOLDER libraries/TEST_PLUGIN)
|
||||
add_library (${HDF5_TEST_PLUGIN_TARGET} SHARED ${HDF5_TEST_SOURCE_DIR}/${plugin_name}.c)
|
||||
TARGET_C_PROPERTIES (${HDF5_TEST_PLUGIN_TARGET} SHARED " " " ")
|
||||
target_link_libraries (${HDF5_TEST_PLUGIN_TARGET} ${HDF5_TEST_LIB_TARGET})
|
||||
H5_SET_LIB_OPTIONS (${HDF5_TEST_PLUGIN_TARGET} ${HDF5_TEST_PLUGIN_NAME} SHARED ${HDF5_PACKAGE_SOVERSION})
|
||||
set_target_properties (${HDF5_TEST_PLUGIN_TARGET} PROPERTIES FOLDER libraries/TEST_PLUGIN)
|
||||
|
||||
#-----------------------------------------------------------------------------
|
||||
# Copy plugin library to a plugins folder
|
||||
# Copy the filter plugin to a plugins folder
|
||||
#-----------------------------------------------------------------------------
|
||||
add_custom_command (
|
||||
TARGET ${HDF5_TEST_PLUGIN_LIB_TARGET}
|
||||
TARGET ${HDF5_TEST_PLUGIN_TARGET}
|
||||
POST_BUILD
|
||||
COMMAND ${CMAKE_COMMAND}
|
||||
ARGS -E copy_if_different
|
||||
"$<TARGET_FILE:${HDF5_TEST_PLUGIN_LIB_TARGET}>"
|
||||
"${CMAKE_BINARY_DIR}/testdir2/$<TARGET_FILE_NAME:${HDF5_TEST_PLUGIN_LIB_TARGET}>"
|
||||
"$<TARGET_FILE:${HDF5_TEST_PLUGIN_TARGET}>"
|
||||
"${CMAKE_BINARY_DIR}/filter_plugin_dir2/$<TARGET_FILE_NAME:${HDF5_TEST_PLUGIN_TARGET}>"
|
||||
)
|
||||
endforeach ()
|
||||
|
||||
@ -411,17 +411,17 @@ endif ()
|
||||
### P L U G I N T E S T S
|
||||
##############################################################################
|
||||
if (BUILD_SHARED_LIBS)
|
||||
add_executable (plugin ${HDF5_TEST_SOURCE_DIR}/plugin.c)
|
||||
TARGET_NAMING (plugin SHARED)
|
||||
TARGET_C_PROPERTIES (plugin SHARED " " " ")
|
||||
target_link_libraries (plugin ${HDF5_TEST_LIB_TARGET})
|
||||
set_target_properties (plugin PROPERTIES FOLDER test)
|
||||
add_executable (filter_plugin ${HDF5_TEST_SOURCE_DIR}/filter_plugin.c)
|
||||
TARGET_NAMING (filter_plugin SHARED)
|
||||
TARGET_C_PROPERTIES (filter_plugin SHARED " " " ")
|
||||
target_link_libraries (filter_plugin ${HDF5_TEST_LIB_TARGET})
|
||||
set_target_properties (filter_plugin PROPERTIES FOLDER test)
|
||||
else ()
|
||||
add_executable (plugin ${HDF5_TEST_SOURCE_DIR}/plugin.c)
|
||||
TARGET_NAMING (plugin STATIC)
|
||||
TARGET_C_PROPERTIES (plugin STATIC " " " ")
|
||||
target_link_libraries (plugin ${HDF5_TEST_LIB_TARGET})
|
||||
set_target_properties (plugin PROPERTIES FOLDER test)
|
||||
add_executable (filter_plugin ${HDF5_TEST_SOURCE_DIR}/filter_plugin.c)
|
||||
TARGET_NAMING (filter_plugin STATIC)
|
||||
TARGET_C_PROPERTIES (filter_plugin STATIC " " " ")
|
||||
target_link_libraries (filter_plugin ${HDF5_TEST_LIB_TARGET})
|
||||
set_target_properties (filter_plugin PROPERTIES FOLDER test)
|
||||
endif ()
|
||||
|
||||
##############################################################################
|
||||
|
@ -1,4 +1,4 @@
|
||||
#
|
||||
|
||||
# Copyright by The HDF Group.
|
||||
# All rights reserved.
|
||||
#
|
||||
@ -520,7 +520,7 @@ set (test_CLEANFILES
|
||||
multi_file-r.h5
|
||||
multi_file-s.h5
|
||||
core_file
|
||||
plugin.h5
|
||||
filter_plugin.h5
|
||||
new_move_a.h5
|
||||
new_move_b.h5
|
||||
ntypes.h5
|
||||
@ -1013,7 +1013,7 @@ if (BUILD_SHARED_LIBS)
|
||||
endif ()
|
||||
|
||||
##############################################################################
|
||||
### P L U G I N T E S T S
|
||||
### F I L T E R P L U G I N T E S T S
|
||||
##############################################################################
|
||||
if (WIN32)
|
||||
set (CMAKE_SEP "\;")
|
||||
@ -1023,9 +1023,9 @@ else ()
|
||||
set (BIN_REL_PATH "../")
|
||||
endif ()
|
||||
|
||||
add_test (NAME H5PLUGIN-plugin COMMAND $<TARGET_FILE:plugin>)
|
||||
set_tests_properties (H5PLUGIN-plugin PROPERTIES
|
||||
ENVIRONMENT "HDF5_PLUGIN_PATH=${CMAKE_BINARY_DIR}/testdir1${CMAKE_SEP}${CMAKE_BINARY_DIR}/testdir2;srcdir=${HDF5_TEST_BINARY_DIR}"
|
||||
add_test (NAME H5PLUGIN-filter_plugin COMMAND $<TARGET_FILE:filter_plugin>)
|
||||
set_tests_properties (H5PLUGIN-filter_plugin PROPERTIES
|
||||
ENVIRONMENT "HDF5_PLUGIN_PATH=${CMAKE_BINARY_DIR}/filter_plugin_dir1${CMAKE_SEP}${CMAKE_BINARY_DIR}/filter_plugin_dir2;srcdir=${HDF5_TEST_BINARY_DIR}"
|
||||
WORKING_DIRECTORY ${HDF5_TEST_BINARY_DIR}
|
||||
)
|
||||
|
||||
|
@ -26,11 +26,12 @@ AM_CPPFLAGS+=-I$(top_srcdir)/src -I$(top_builddir)/src
|
||||
# testlibinfo.sh:
|
||||
# testcheck_version.sh: tcheck_version
|
||||
# testlinks_env.sh: links_env
|
||||
# test_filenotclosed.sh: filenotclosed.c
|
||||
# testflushrefresh.sh: flushrefresh
|
||||
# test_usecases.sh: use_append_chunk, use_append_mchunks, use_disable_mdc_flushes
|
||||
# testswmr.sh: swmr*
|
||||
# testvdsswmr.sh: vds_swmr*
|
||||
# test_filenotclosed.sh: filenotclosed.c
|
||||
# test_filter_plugin.sh: filter_plugin.c
|
||||
# test_usecases.sh: use_append_chunk, use_append_mchunks, use_disable_mdc_flushes
|
||||
TEST_SCRIPT = testerror.sh testlibinfo.sh testcheck_version.sh testlinks_env.sh test_filenotclosed.sh\
|
||||
testswmr.sh testvdsswmr.sh testflushrefresh.sh test_usecases.sh
|
||||
SCRIPT_DEPEND = error_test$(EXEEXT) err_compat$(EXEEXT) links_env$(EXEEXT) test_filenotclosed$(EXEEXT) \
|
||||
@ -40,8 +41,8 @@ SCRIPT_DEPEND = error_test$(EXEEXT) err_compat$(EXEEXT) links_env$(EXEEXT) test_
|
||||
swmr_sparse_reader$(EXEEXT) swmr_sparse_writer$(EXEEXT) swmr_start_write$(EXEEXT) \
|
||||
vds_swmr_gen$(EXEEXT) vds_swmr_reader$(EXEEXT) vds_swmr_writer$(EXEEXT)
|
||||
if HAVE_SHARED_CONDITIONAL
|
||||
TEST_SCRIPT += test_plugin.sh
|
||||
SCRIPT_DEPEND += plugin$(EXEEXT)
|
||||
TEST_SCRIPT += test_filter_plugin.sh
|
||||
SCRIPT_DEPEND += filter_plugin$(EXEEXT)
|
||||
endif
|
||||
|
||||
check_SCRIPTS = $(TEST_SCRIPT)
|
||||
@ -81,7 +82,7 @@ check_PROGRAMS=$(TEST_PROG) error_test err_compat tcheck_version \
|
||||
swmr_remove_writer swmr_addrem_writer swmr_sparse_reader swmr_sparse_writer \
|
||||
swmr_check_compat_vfd vds_swmr_gen vds_swmr_reader vds_swmr_writer
|
||||
if HAVE_SHARED_CONDITIONAL
|
||||
check_PROGRAMS+= plugin
|
||||
check_PROGRAMS+= filter_plugin
|
||||
endif
|
||||
|
||||
# These programs generate test files for the tests. They don't need to be
|
||||
@ -102,29 +103,17 @@ endif
|
||||
|
||||
if HAVE_SHARED_CONDITIONAL
|
||||
# The libh5test library provides common support code for the tests.
|
||||
# The libdynlib1, libdynlib2, libdynlib3, and libdynlib4 library for testing plugin module plugin.c.
|
||||
# Build them as shared libraries if configure is enabled for shared library.
|
||||
noinst_LTLIBRARIES=libh5test.la libdynlib1.la libdynlib2.la libdynlib3.la libdynlib4.la
|
||||
libdynlib1_la_SOURCES=dynlib1.c
|
||||
libdynlib2_la_SOURCES=dynlib2.c
|
||||
libdynlib3_la_SOURCES=dynlib3.c
|
||||
libdynlib4_la_SOURCES=dynlib4.c
|
||||
libdynlib1_la_LDFLAGS = -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
libdynlib2_la_LDFLAGS = -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
libdynlib3_la_LDFLAGS = -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
libdynlib4_la_LDFLAGS = -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
|
||||
libdynlib1.la: $(libdynlib1_la_OBJECTS) $(libdynlib1_la_DEPENDENCIES) $(EXTRA_libdynlib1_la_DEPENDENCIES)
|
||||
$(AM_V_CCLD)$(libdynlib1_la_LINK) $(am_libdynlib1_la_rpath) $(libdynlib1_la_OBJECTS) $(libdynlib1_la_LIBADD)
|
||||
|
||||
libdynlib2.la: $(libdynlib2_la_OBJECTS) $(libdynlib2_la_DEPENDENCIES) $(EXTRA_libdynlib2_la_DEPENDENCIES)
|
||||
$(AM_V_CCLD)$(libdynlib2_la_LINK) $(am_libdynlib2_la_rpath) $(libdynlib2_la_OBJECTS) $(libdynlib2_la_LIBADD)
|
||||
|
||||
libdynlib3.la: $(libdynlib3_la_OBJECTS) $(libdynlib3_la_DEPENDENCIES) $(EXTRA_libdynlib3_la_DEPENDENCIES)
|
||||
$(AM_V_CCLD)$(libdynlib3_la_LINK) $(am_libdynlib3_la_rpath) $(libdynlib3_la_OBJECTS) $(libdynlib3_la_LIBADD)
|
||||
|
||||
libdynlib4.la: $(libdynlib4_la_OBJECTS) $(libdynlib4_la_DEPENDENCIES) $(EXTRA_libdynlib4_la_DEPENDENCIES)
|
||||
$(AM_V_CCLD)$(libdynlib4_la_LINK) $(am_libdynlib4_la_rpath) $(libdynlib4_la_OBJECTS) $(libdynlib4_la_LIBADD)
|
||||
# The filter_plugin* libraries are for use in filter_plugin.c.
|
||||
# Build them as shared libraries if that option was enabled in configure.
|
||||
noinst_LTLIBRARIES=libh5test.la libfilter_plugin1_dsets.la libfilter_plugin2_dsets.la libfilter_plugin3_dsets.la libfilter_plugin4_groups.la
|
||||
libfilter_plugin1_dsets_la_SOURCES=filter_plugin1_dsets.c
|
||||
libfilter_plugin2_dsets_la_SOURCES=filter_plugin2_dsets.c
|
||||
libfilter_plugin3_dsets_la_SOURCES=filter_plugin3_dsets.c
|
||||
libfilter_plugin4_groups_la_SOURCES=filter_plugin4_groups.c
|
||||
libfilter_plugin1_dsets_la_LDFLAGS=$(AM_LDFLAGS) -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
libfilter_plugin2_dsets_la_LDFLAGS=$(AM_LDFLAGS) -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
libfilter_plugin3_dsets_la_LDFLAGS=$(AM_LDFLAGS) -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
libfilter_plugin4_groups_la_LDFLAGS=$(AM_LDFLAGS) -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
else
|
||||
# The libh5test library provides common support code for the tests.
|
||||
noinst_LTLIBRARIES=libh5test.la
|
||||
@ -185,7 +174,7 @@ CHECK_CLEANFILES+=accum.h5 cmpd_dset.h5 compact_dataset.h5 dataset.h5 dset_offse
|
||||
tmisc[0-9]*.h5 set_extent[1-5].h5 ext[12].bin \
|
||||
getname.h5 getname[1-3].h5 sec2_file.h5 direct_file.h5 \
|
||||
family_file000[0-3][0-9].h5 new_family_v16_000[0-3][0-9].h5 \
|
||||
multi_file-[rs].h5 core_file plugin.h5 \
|
||||
multi_file-[rs].h5 core_file filter_plugin.h5 \
|
||||
new_move_[ab].h5 ntypes.h5 dangle.h5 error_test.h5 err_compat.h5 \
|
||||
dtransform.h5 test_filters.h5 get_file_name.h5 tstint[1-2].h5 \
|
||||
unlink_chunked.h5 btree2.h5 btree2_tmp.h5 objcopy_src.h5 objcopy_dst.h5 \
|
||||
@ -215,7 +204,7 @@ use_append_mchunks_SOURCES=use_append_mchunks.c use_common.c
|
||||
use_disable_mdc_flushes_SOURCES=use_disable_mdc_flushes.c
|
||||
|
||||
# Temporary files.
|
||||
DISTCLEANFILES=testerror.sh testlibinfo.sh testcheck_version.sh testlinks_env.sh test_plugin.sh \
|
||||
DISTCLEANFILES=testerror.sh testlibinfo.sh testcheck_version.sh testlinks_env.sh test_filter_plugin.sh \
|
||||
testswmr.sh testvdsswmr.sh test_usecases.sh testflushrefresh.sh test_filenotclosed.sh
|
||||
|
||||
include $(top_srcdir)/config/conclude.am
|
||||
|
@ -3631,11 +3631,14 @@ error:
|
||||
static unsigned
|
||||
check_invalid_tag_application(void)
|
||||
{
|
||||
#if H5C_DO_TAGGING_SANITY_CHECKS
|
||||
/* Variables */
|
||||
H5F_t * f = NULL;
|
||||
hid_t fid, dxpl_id = -1;
|
||||
hid_t fid = -1;
|
||||
hid_t dxpl_id = -1;
|
||||
haddr_t addr;
|
||||
H5HL_t * lheap = NULL;
|
||||
#endif /* H5C_DO_TAGGING_SANITY_CHECKS */
|
||||
|
||||
/* Testing Macro */
|
||||
TESTING("failure on invalid tag application");
|
||||
@ -3683,8 +3686,8 @@ check_invalid_tag_application(void)
|
||||
PASSED();
|
||||
#else
|
||||
SKIPPED();
|
||||
printf(" test skipped because sanity checking on tag value is disabled.\n");
|
||||
#endif
|
||||
HDprintf(" test skipped because sanity checking on tag value is disabled.\n");
|
||||
#endif /* H5C_DO_TAGGING_SANITY_CHECKS */
|
||||
|
||||
return 0;
|
||||
|
||||
@ -3791,10 +3794,10 @@ main(void)
|
||||
HDremove(FILENAME2);
|
||||
|
||||
/* Return Errors */
|
||||
return(nerrs > 0);
|
||||
return nerrs > 0;
|
||||
|
||||
error:
|
||||
/* Return with Error */
|
||||
return(1);
|
||||
return 1;
|
||||
|
||||
} /* main */
|
||||
|
@ -226,7 +226,9 @@ check_file(char *filename)
|
||||
const char *pathname = H5_get_srcdir_filename(filename); /* Corrected test file name */
|
||||
hid_t fid = -1; /* file ID */
|
||||
int nerrors = 0; /* # of datasets with errors */
|
||||
#if !defined(H5_HAVE_FILTER_DEFLATE) || !defined(H5_HAVE_FILTER_SZIP)
|
||||
const char *not_supported= " filter is not enabled."; /* no filter message */
|
||||
#endif
|
||||
|
||||
/* Open the file. */
|
||||
if((fid = H5Fopen(pathname, H5F_ACC_RDONLY, H5P_DEFAULT)) < 0)
|
||||
|
@ -1,95 +0,0 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* Copyright by The HDF Group. *
|
||||
* All rights reserved. *
|
||||
* *
|
||||
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
||||
* terms governing use, modification, and redistribution, is contained in *
|
||||
* the COPYING file, which can be found at the root of the source code *
|
||||
* distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases. *
|
||||
* If you do not have access to either file, you may request a copy from *
|
||||
* help@hdfgroup.org. *
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
/*
|
||||
* Programmer: Raymond Lu
|
||||
* 13 February 2013
|
||||
*
|
||||
* Purpose: Tests the plugin module (H5PL)
|
||||
*/
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
#include "H5PLextern.h"
|
||||
|
||||
#define H5Z_FILTER_DYNLIB1 257
|
||||
|
||||
static size_t H5Z_filter_dynlib1(unsigned int flags, size_t cd_nelmts,
|
||||
const unsigned int *cd_values, size_t nbytes, size_t *buf_size, void **buf);
|
||||
|
||||
/* This message derives from H5Z */
|
||||
const H5Z_class2_t H5Z_DYNLIB1[1] = {{
|
||||
H5Z_CLASS_T_VERS, /* H5Z_class_t version */
|
||||
H5Z_FILTER_DYNLIB1, /* Filter id number */
|
||||
1, 1, /* Encoding and decoding enabled */
|
||||
"dynlib1", /* Filter name for debugging */
|
||||
NULL, /* The "can apply" callback */
|
||||
NULL, /* The "set local" callback */
|
||||
(H5Z_func_t)H5Z_filter_dynlib1, /* The actual filter function */
|
||||
}};
|
||||
|
||||
H5PL_type_t H5PLget_plugin_type(void) {return H5PL_TYPE_FILTER;}
|
||||
const void *H5PLget_plugin_info(void) {return H5Z_DYNLIB1;}
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: H5Z_filter_dynlib1
|
||||
*
|
||||
* Purpose: A dynlib1 filter method that adds on and subtract from
|
||||
* the original value with another value. It will be built
|
||||
* as a shared library. plugin.c test will load and use
|
||||
* this filter library.
|
||||
*
|
||||
* Return: Success: Data chunk size
|
||||
*
|
||||
* Failure: 0
|
||||
*
|
||||
* Programmer: Raymond Lu
|
||||
* 29 March 2013
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static size_t
|
||||
H5Z_filter_dynlib1(unsigned int flags, size_t cd_nelmts,
|
||||
const unsigned int *cd_values, size_t nbytes,
|
||||
size_t *buf_size, void **buf)
|
||||
{
|
||||
int *int_ptr = (int *)*buf; /* Pointer to the data values */
|
||||
size_t buf_left = *buf_size; /* Amount of data buffer left to process */
|
||||
int add_on = 0;
|
||||
|
||||
/* Check for the correct number of parameters */
|
||||
if(cd_nelmts == 0)
|
||||
return(0);
|
||||
|
||||
/* Check that permanent parameters are set correctly */
|
||||
if(cd_values[0] > 9)
|
||||
return(0);
|
||||
|
||||
add_on = (int)cd_values[0];
|
||||
|
||||
if(flags & H5Z_FLAG_REVERSE) { /*read*/
|
||||
/* Substract the "add on" value to all the data values */
|
||||
while(buf_left > 0) {
|
||||
*int_ptr++ -= add_on;
|
||||
buf_left -= sizeof(int);
|
||||
} /* end while */
|
||||
} /* end if */
|
||||
else { /*write*/
|
||||
/* Add the "add on" value to all the data values */
|
||||
while(buf_left > 0) {
|
||||
*int_ptr++ += add_on;
|
||||
buf_left -= sizeof(int);
|
||||
} /* end while */
|
||||
} /* end else */
|
||||
|
||||
return nbytes;
|
||||
} /* end H5Z_filter_dynlib1() */
|
||||
|
@ -1,92 +0,0 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* Copyright by The HDF Group. *
|
||||
* All rights reserved. *
|
||||
* *
|
||||
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
||||
* terms governing use, modification, and redistribution, is contained in *
|
||||
* the COPYING file, which can be found at the root of the source code *
|
||||
* distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases. *
|
||||
* If you do not have access to either file, you may request a copy from *
|
||||
* help@hdfgroup.org. *
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
/*
|
||||
* Programmer: Raymond Lu
|
||||
* 13 February 2013
|
||||
*
|
||||
* Purpose: Tests the plugin module (H5PL)
|
||||
*/
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
#include "H5PLextern.h"
|
||||
|
||||
#define H5Z_FILTER_DYNLIB2 258
|
||||
#define MULTIPLIER 3
|
||||
|
||||
static size_t H5Z_filter_dynlib2(unsigned int flags, size_t cd_nelmts,
|
||||
const unsigned int *cd_values, size_t nbytes, size_t *buf_size, void **buf);
|
||||
|
||||
/* This message derives from H5Z */
|
||||
const H5Z_class2_t H5Z_DYNLIB2[1] = {{
|
||||
H5Z_CLASS_T_VERS, /* H5Z_class_t version */
|
||||
H5Z_FILTER_DYNLIB2, /* Filter id number */
|
||||
1, 1, /* Encoding and decoding enabled */
|
||||
"dynlib2", /* Filter name for debugging */
|
||||
NULL, /* The "can apply" callback */
|
||||
NULL, /* The "set local" callback */
|
||||
(H5Z_func_t)H5Z_filter_dynlib2, /* The actual filter function */
|
||||
}};
|
||||
|
||||
H5PL_type_t H5PLget_plugin_type(void) {return H5PL_TYPE_FILTER;}
|
||||
const void *H5PLget_plugin_info(void) {return H5Z_DYNLIB2;}
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: H5Z_filter_dynlib2
|
||||
*
|
||||
* Purpose: A dynlib2 filter method that multiplies the original value
|
||||
* during write and divide the original value during read. It
|
||||
* will be built as a shared library. plugin.c test will load
|
||||
* and use this filter library.
|
||||
*
|
||||
* Return: Success: Data chunk size
|
||||
*
|
||||
* Failure: 0
|
||||
*
|
||||
* Programmer: Raymond Lu
|
||||
* 29 March 2013
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static size_t
|
||||
H5Z_filter_dynlib2(unsigned int flags, size_t cd_nelmts,
|
||||
const unsigned int *cd_values, size_t nbytes,
|
||||
size_t *buf_size, void **buf)
|
||||
{
|
||||
int *int_ptr = (int *)*buf; /* Pointer to the data values */
|
||||
size_t buf_left = *buf_size; /* Amount of data buffer left to process */
|
||||
|
||||
/* Check for the correct number of parameters */
|
||||
if(cd_nelmts > 0)
|
||||
return(0);
|
||||
|
||||
/* Assignment to eliminate unused parameter warning. */
|
||||
cd_values = cd_values;
|
||||
|
||||
if(flags & H5Z_FLAG_REVERSE) { /*read*/
|
||||
/* Divide the original value with MULTIPLIER */
|
||||
while(buf_left > 0) {
|
||||
*int_ptr++ /= MULTIPLIER;
|
||||
buf_left -= sizeof(int);
|
||||
} /* end while */
|
||||
} /* end if */
|
||||
else { /*write*/
|
||||
/* Multiply the original value with MULTIPLIER */
|
||||
while(buf_left > 0) {
|
||||
*int_ptr++ *= MULTIPLIER;
|
||||
buf_left -= sizeof(int);
|
||||
} /* end while */
|
||||
} /* end else */
|
||||
|
||||
return nbytes;
|
||||
} /* end H5Z_filter_dynlib2() */
|
||||
|
103
test/dynlib3.c
103
test/dynlib3.c
@ -1,103 +0,0 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* Copyright by The HDF Group. *
|
||||
* All rights reserved. *
|
||||
* *
|
||||
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
||||
* terms governing use, modification, and redistribution, is contained in *
|
||||
* the COPYING file, which can be found at the root of the source code *
|
||||
* distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases. *
|
||||
* If you do not have access to either file, you may request a copy from *
|
||||
* help@hdfgroup.org. *
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
/*
|
||||
* Programmer: Raymond Lu
|
||||
* 1 April 2013
|
||||
*
|
||||
* Purpose: Tests the plugin module (H5PL)
|
||||
*/
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
#include "H5PLextern.h"
|
||||
|
||||
#define H5Z_FILTER_DYNLIB3 259
|
||||
#define SUFFIX_LEN 8
|
||||
#define GROUP_SUFFIX ".h5group"
|
||||
|
||||
static size_t H5Z_filter_dynlib3(unsigned int flags, size_t cd_nelmts,
|
||||
const unsigned int *cd_values, size_t nbytes, size_t *buf_size, void **buf);
|
||||
|
||||
/* This message derives from H5Z */
|
||||
const H5Z_class2_t H5Z_DYNLIB3[1] = {{
|
||||
H5Z_CLASS_T_VERS, /* H5Z_class_t version */
|
||||
H5Z_FILTER_DYNLIB3, /* Filter id number */
|
||||
1, 1, /* Encoding and decoding enabled */
|
||||
"dynlib3", /* Filter name for debugging */
|
||||
NULL, /* The "can apply" callback */
|
||||
NULL, /* The "set local" callback */
|
||||
(H5Z_func_t)H5Z_filter_dynlib3, /* The actual filter function */
|
||||
}};
|
||||
|
||||
H5PL_type_t H5PLget_plugin_type(void) {return H5PL_TYPE_FILTER;}
|
||||
const void *H5PLget_plugin_info(void) {return H5Z_DYNLIB3;}
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: H5Z_filter_dynlib3
|
||||
*
|
||||
* Purpose: A dynlib3 filter method that is used to test groups. It
|
||||
* appends the suffix ".h5group" to each group name during
|
||||
* write and takes it out during read.
|
||||
*
|
||||
* Return: Success: Data chunk size
|
||||
*
|
||||
* Failure: 0
|
||||
*
|
||||
* Programmer: Raymond Lu
|
||||
* 1 April 2013
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static size_t
|
||||
H5Z_filter_dynlib3(unsigned int flags, size_t cd_nelmts,
|
||||
const unsigned int *cd_values, size_t nbytes,
|
||||
size_t *buf_size, void **buf)
|
||||
{
|
||||
size_t ret_value; /* Return value */
|
||||
|
||||
/* Check for the correct number of parameters */
|
||||
if(cd_nelmts > 0)
|
||||
return(0);
|
||||
|
||||
/* Assignment to eliminate unused parameter warning. */
|
||||
cd_values = cd_values;
|
||||
|
||||
if(flags & H5Z_FLAG_REVERSE) { /*read*/
|
||||
ret_value = *buf_size = nbytes - SUFFIX_LEN;
|
||||
} /* end if */
|
||||
else { /*write*/
|
||||
void *outbuf = NULL; /* Pointer to new buffer */
|
||||
unsigned char *dst; /* Temporary pointer to destination buffer */
|
||||
|
||||
dst = (unsigned char *)(outbuf = H5allocate_memory(nbytes + SUFFIX_LEN, 0));
|
||||
|
||||
/* Copy raw data */
|
||||
memcpy((void*)dst, (void*)(*buf), nbytes);
|
||||
|
||||
/* Append suffix to raw data for storage */
|
||||
dst += nbytes;
|
||||
memcpy(dst, (void*)GROUP_SUFFIX, SUFFIX_LEN);
|
||||
|
||||
/* Free input buffer */
|
||||
H5free_memory(*buf);
|
||||
|
||||
/* Set return values */
|
||||
*buf_size = nbytes + SUFFIX_LEN;
|
||||
*buf = outbuf;
|
||||
outbuf = NULL;
|
||||
ret_value = *buf_size;
|
||||
} /* end else */
|
||||
|
||||
return ret_value;
|
||||
} /* H5Z_filter_dynlib3() */
|
||||
|
102
test/dynlib4.c
102
test/dynlib4.c
@ -1,102 +0,0 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* Copyright by The HDF Group. *
|
||||
* All rights reserved. *
|
||||
* *
|
||||
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
||||
* terms governing use, modification, and redistribution, is contained in *
|
||||
* the COPYING file, which can be found at the root of the source code *
|
||||
* distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases. *
|
||||
* If you do not have access to either file, you may request a copy from *
|
||||
* help@hdfgroup.org. *
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
/*
|
||||
* Purpose: Tests the plugin module (H5PL)
|
||||
*/
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
#include "H5PLextern.h"
|
||||
|
||||
#define H5Z_FILTER_DYNLIB4 260
|
||||
|
||||
#define PUSH_ERR(func, minor, str) H5Epush2(H5E_DEFAULT, __FILE__, func, __LINE__, H5E_ERR_CLS, H5E_PLUGIN, minor, str)
|
||||
|
||||
static size_t H5Z_filter_dynlib4(unsigned int flags, size_t cd_nelmts,
|
||||
const unsigned int *cd_values, size_t nbytes, size_t *buf_size, void **buf);
|
||||
|
||||
/* This message derives from H5Z */
|
||||
const H5Z_class2_t H5Z_DYNLIB4[1] = {{
|
||||
H5Z_CLASS_T_VERS, /* H5Z_class_t version */
|
||||
H5Z_FILTER_DYNLIB4, /* Filter id number */
|
||||
1, 1, /* Encoding and decoding enabled */
|
||||
"dynlib4", /* Filter name for debugging */
|
||||
NULL, /* The "can apply" callback */
|
||||
NULL, /* The "set local" callback */
|
||||
(H5Z_func_t)H5Z_filter_dynlib4, /* The actual filter function */
|
||||
}};
|
||||
|
||||
H5PL_type_t H5PLget_plugin_type(void) {return H5PL_TYPE_FILTER;}
|
||||
const void *H5PLget_plugin_info(void) {return H5Z_DYNLIB4;}
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: H5Z_filter_dynlib4
|
||||
*
|
||||
* Purpose: A dynlib4 filter method that adds on and subtract from
|
||||
* the original value with another value. It will be built
|
||||
* as a shared library. plugin.c test will load and use
|
||||
* this filter library. Designed to call a HDF function.
|
||||
*
|
||||
* Return: Success: Data chunk size
|
||||
*
|
||||
* Failure: 0
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static size_t
|
||||
H5Z_filter_dynlib4(unsigned int flags, size_t cd_nelmts,
|
||||
const unsigned int *cd_values, size_t nbytes,
|
||||
size_t *buf_size, void **buf)
|
||||
{
|
||||
int *int_ptr = (int *)*buf; /* Pointer to the data values */
|
||||
size_t buf_left = *buf_size; /* Amount of data buffer left to process */
|
||||
int add_on = 0;
|
||||
unsigned ver_info[3];
|
||||
|
||||
/* Check for the library version */
|
||||
if(H5get_libversion(&ver_info[0], &ver_info[1], &ver_info[2]) < 0) {
|
||||
PUSH_ERR("dynlib4", H5E_CALLBACK, "H5get_libversion");
|
||||
return(0);
|
||||
}
|
||||
/* Check for the correct number of parameters */
|
||||
if(cd_nelmts == 0)
|
||||
return(0);
|
||||
|
||||
/* Check that permanent parameters are set correctly */
|
||||
if(cd_values[0] > 9)
|
||||
return(0);
|
||||
|
||||
if(ver_info[0] != cd_values[1] || ver_info[1] != cd_values[2]) {
|
||||
PUSH_ERR("dynlib4", H5E_CALLBACK, "H5get_libversion does not match");
|
||||
return(0);
|
||||
}
|
||||
|
||||
add_on = (int)cd_values[0];
|
||||
|
||||
if(flags & H5Z_FLAG_REVERSE) { /*read*/
|
||||
/* Substract the "add on" value to all the data values */
|
||||
while(buf_left > 0) {
|
||||
*int_ptr++ -= add_on;
|
||||
buf_left -= sizeof(int);
|
||||
} /* end while */
|
||||
} /* end if */
|
||||
else { /*write*/
|
||||
/* Add the "add on" value to all the data values */
|
||||
while(buf_left > 0) {
|
||||
*int_ptr++ += add_on;
|
||||
buf_left -= sizeof(int);
|
||||
} /* end while */
|
||||
} /* end else */
|
||||
|
||||
return nbytes;
|
||||
} /* end H5Z_filter_dynlib4() */
|
||||
|
@ -82,35 +82,33 @@ static herr_t custom_print_cb(unsigned n, const H5E_error2_t *err_desc,
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: test_error
|
||||
* Function: test_error
|
||||
*
|
||||
* Purpose: Test error API functions
|
||||
* Purpose: Test error API functions
|
||||
*
|
||||
* Return: Success: 0
|
||||
*
|
||||
* Failure: -1
|
||||
*
|
||||
* Programmer: Raymond Lu
|
||||
* July 10, 2003
|
||||
* Return: Success: 0
|
||||
* Failure: -1
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static herr_t
|
||||
test_error(hid_t file)
|
||||
{
|
||||
hid_t dataset, space;
|
||||
hid_t estack_id;
|
||||
hid_t dataset = -1;
|
||||
hid_t space = -1;
|
||||
hid_t estack_id = -1;
|
||||
hsize_t dims[2];
|
||||
const char *FUNC_test_error = "test_error";
|
||||
H5E_auto2_t old_func;
|
||||
void *old_data;
|
||||
void *old_data = NULL;
|
||||
|
||||
HDfprintf(stderr, "\nTesting error API based on data I/O\n");
|
||||
|
||||
/* Create the data space */
|
||||
dims[0] = DIM0;
|
||||
dims[1] = DIM1;
|
||||
if ((space = H5Screate_simple(2, dims, NULL))<0) TEST_ERROR;
|
||||
if ((space = H5Screate_simple(2, dims, NULL)) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Test H5E_BEGIN_TRY */
|
||||
H5E_BEGIN_TRY {
|
||||
@ -118,40 +116,40 @@ test_error(hid_t file)
|
||||
} H5E_END_TRY;
|
||||
|
||||
/* Create the dataset */
|
||||
if((dataset = H5Dcreate2(file, DSET_NAME, H5T_STD_I32BE, space, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
|
||||
if ((dataset = H5Dcreate2(file, DSET_NAME, H5T_STD_I32BE, space, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT)) < 0) {
|
||||
H5Epush(H5E_DEFAULT, __FILE__, FUNC_test_error, __LINE__, ERR_CLS, ERR_MAJ_IO, ERR_MIN_CREATE,
|
||||
"H5Dcreate2 failed");
|
||||
goto error;
|
||||
} /* end if */
|
||||
}
|
||||
|
||||
/* Test enabling and disabling default printing */
|
||||
if(H5Eget_auto2(H5E_DEFAULT, &old_func, &old_data) < 0)
|
||||
TEST_ERROR;
|
||||
if(old_data != NULL)
|
||||
TEST_ERROR;
|
||||
if (H5Eget_auto2(H5E_DEFAULT, &old_func, &old_data) < 0)
|
||||
TEST_ERROR;
|
||||
if (old_data != NULL)
|
||||
TEST_ERROR;
|
||||
#ifdef H5_USE_16_API
|
||||
if (old_func != (H5E_auto_t)H5Eprint)
|
||||
TEST_ERROR;
|
||||
TEST_ERROR;
|
||||
#else /* H5_USE_16_API */
|
||||
if (old_func != (H5E_auto2_t)H5Eprint2)
|
||||
TEST_ERROR;
|
||||
TEST_ERROR;
|
||||
#endif /* H5_USE_16_API */
|
||||
|
||||
if(H5Eset_auto2(H5E_DEFAULT, NULL, NULL) < 0)
|
||||
if (H5Eset_auto2(H5E_DEFAULT, NULL, NULL) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Make H5Dwrite fail, verify default print is disabled */
|
||||
if(H5Dwrite(FAKE_ID, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, ipoints2) >= 0) {
|
||||
if (H5Dwrite(FAKE_ID, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, ipoints2) >= 0) {
|
||||
H5Epush(H5E_DEFAULT, __FILE__, FUNC_test_error, __LINE__, ERR_CLS, ERR_MAJ_IO, ERR_MIN_WRITE,
|
||||
"H5Dwrite shouldn't succeed");
|
||||
goto error;
|
||||
} /* end if */
|
||||
}
|
||||
|
||||
if(H5Eset_auto2(H5E_DEFAULT, old_func, old_data) < 0)
|
||||
if (H5Eset_auto2(H5E_DEFAULT, old_func, old_data) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Test saving and restoring the current error stack */
|
||||
if(H5Dwrite(FAKE_ID, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, ipoints2) < 0) {
|
||||
if (H5Dwrite(FAKE_ID, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, ipoints2) < 0) {
|
||||
H5Epush(H5E_DEFAULT, __FILE__, FUNC_test_error, __LINE__, ERR_CLS, ERR_MAJ_IO, ERR_MIN_WRITE,
|
||||
"H5Dwrite failed as supposed to");
|
||||
estack_id = H5Eget_current_stack();
|
||||
@ -159,10 +157,11 @@ test_error(hid_t file)
|
||||
H5Sclose(space);
|
||||
H5Eset_current_stack(estack_id);
|
||||
goto error;
|
||||
} /* end if */
|
||||
}
|
||||
|
||||
/* In case program comes to this point, close dataset */
|
||||
if(H5Dclose(dataset) < 0) TEST_ERROR;
|
||||
if(H5Dclose(dataset) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
TEST_ERROR;
|
||||
|
||||
@ -172,16 +171,12 @@ test_error(hid_t file)
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: init_error
|
||||
* Function: init_error
|
||||
*
|
||||
* Purpose: Initialize error information.
|
||||
* Purpose: Initialize error information.
|
||||
*
|
||||
* Return: Success: 0
|
||||
*
|
||||
* Failure: -1
|
||||
*
|
||||
* Programmer: Raymond Lu
|
||||
* July 10, 2003
|
||||
* Return: Success: 0
|
||||
* Failure: -1
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -194,46 +189,46 @@ init_error(void)
|
||||
char *msg = NULL;
|
||||
H5E_type_t msg_type;
|
||||
|
||||
if(NULL == (cls_name = (char *)HDmalloc(HDstrlen(ERR_CLS_NAME) + 1)))
|
||||
if (NULL == (cls_name = (char *)HDmalloc(HDstrlen(ERR_CLS_NAME) + 1)))
|
||||
TEST_ERROR
|
||||
if(NULL == (msg = (char *)HDmalloc(HDstrlen(ERR_MIN_SUBROUTINE_MSG) + 1)))
|
||||
if (NULL == (msg = (char *)HDmalloc(HDstrlen(ERR_MIN_SUBROUTINE_MSG) + 1)))
|
||||
TEST_ERROR
|
||||
|
||||
if((ERR_CLS = H5Eregister_class(ERR_CLS_NAME, PROG_NAME, PROG_VERS)) < 0)
|
||||
if ((ERR_CLS = H5Eregister_class(ERR_CLS_NAME, PROG_NAME, PROG_VERS)) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
if(cls_size != H5Eget_class_name(ERR_CLS, cls_name, (size_t)cls_size) + 1)
|
||||
if (cls_size != H5Eget_class_name(ERR_CLS, cls_name, (size_t)cls_size) + 1)
|
||||
TEST_ERROR;
|
||||
if(HDstrcmp(ERR_CLS_NAME, cls_name))
|
||||
if (HDstrcmp(ERR_CLS_NAME, cls_name))
|
||||
TEST_ERROR;
|
||||
|
||||
if((ERR_MAJ_TEST = H5Ecreate_msg(ERR_CLS, H5E_MAJOR, ERR_MAJ_TEST_MSG)) < 0)
|
||||
if ((ERR_MAJ_TEST = H5Ecreate_msg(ERR_CLS, H5E_MAJOR, ERR_MAJ_TEST_MSG)) < 0)
|
||||
TEST_ERROR;
|
||||
if((ERR_MAJ_IO = H5Ecreate_msg(ERR_CLS, H5E_MAJOR, ERR_MAJ_IO_MSG)) < 0)
|
||||
if ((ERR_MAJ_IO = H5Ecreate_msg(ERR_CLS, H5E_MAJOR, ERR_MAJ_IO_MSG)) < 0)
|
||||
TEST_ERROR;
|
||||
if((ERR_MAJ_API = H5Ecreate_msg(ERR_CLS, H5E_MAJOR, ERR_MAJ_API_MSG)) < 0)
|
||||
if ((ERR_MAJ_API = H5Ecreate_msg(ERR_CLS, H5E_MAJOR, ERR_MAJ_API_MSG)) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
if((ERR_MIN_SUBROUTINE = H5Ecreate_msg(ERR_CLS, H5E_MINOR, ERR_MIN_SUBROUTINE_MSG)) < 0)
|
||||
if ((ERR_MIN_SUBROUTINE = H5Ecreate_msg(ERR_CLS, H5E_MINOR, ERR_MIN_SUBROUTINE_MSG)) < 0)
|
||||
TEST_ERROR;
|
||||
if((ERR_MIN_ERRSTACK = H5Ecreate_msg(ERR_CLS, H5E_MINOR, ERR_MIN_ERRSTACK_MSG)) < 0)
|
||||
if ((ERR_MIN_ERRSTACK = H5Ecreate_msg(ERR_CLS, H5E_MINOR, ERR_MIN_ERRSTACK_MSG)) < 0)
|
||||
TEST_ERROR;
|
||||
if((ERR_MIN_CREATE = H5Ecreate_msg(ERR_CLS, H5E_MINOR, ERR_MIN_CREATE_MSG)) < 0)
|
||||
if ((ERR_MIN_CREATE = H5Ecreate_msg(ERR_CLS, H5E_MINOR, ERR_MIN_CREATE_MSG)) < 0)
|
||||
TEST_ERROR;
|
||||
if((ERR_MIN_WRITE = H5Ecreate_msg(ERR_CLS, H5E_MINOR, ERR_MIN_WRITE_MSG)) < 0)
|
||||
if ((ERR_MIN_WRITE = H5Ecreate_msg(ERR_CLS, H5E_MINOR, ERR_MIN_WRITE_MSG)) < 0)
|
||||
TEST_ERROR;
|
||||
if((ERR_MIN_GETNUM = H5Ecreate_msg(ERR_CLS, H5E_MINOR, ERR_MIN_GETNUM_MSG)) < 0)
|
||||
if ((ERR_MIN_GETNUM = H5Ecreate_msg(ERR_CLS, H5E_MINOR, ERR_MIN_GETNUM_MSG)) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
if(msg_size != H5Eget_msg(ERR_MIN_SUBROUTINE, &msg_type, msg, (size_t)msg_size) + 1)
|
||||
if (msg_size != H5Eget_msg(ERR_MIN_SUBROUTINE, &msg_type, msg, (size_t)msg_size) + 1)
|
||||
TEST_ERROR;
|
||||
if(msg_type != H5E_MINOR)
|
||||
if (msg_type != H5E_MINOR)
|
||||
TEST_ERROR;
|
||||
if(HDstrcmp(msg, ERR_MIN_SUBROUTINE_MSG))
|
||||
if (HDstrcmp(msg, ERR_MIN_SUBROUTINE_MSG))
|
||||
TEST_ERROR;
|
||||
|
||||
/* Register another class for later testing. */
|
||||
if((ERR_CLS2 = H5Eregister_class(ERR_CLS2_NAME, PROG2_NAME, PROG_VERS)) < 0)
|
||||
if ((ERR_CLS2 = H5Eregister_class(ERR_CLS2_NAME, PROG2_NAME, PROG_VERS)) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
HDfree(cls_name);
|
||||
@ -242,9 +237,9 @@ init_error(void)
|
||||
return 0;
|
||||
|
||||
error:
|
||||
if(cls_name)
|
||||
if (cls_name)
|
||||
HDfree(cls_name);
|
||||
if(msg)
|
||||
if (msg)
|
||||
HDfree(msg);
|
||||
|
||||
return -1;
|
||||
@ -252,16 +247,12 @@ error:
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: error_stack
|
||||
* Function: error_stack
|
||||
*
|
||||
* Purpose: Manipulates current error stack.
|
||||
* Purpose: Manipulates current error stack.
|
||||
*
|
||||
* Return: Success: 0
|
||||
*
|
||||
* Failure: -1
|
||||
*
|
||||
* Programmer: Raymond Lu
|
||||
* July 14, 2003
|
||||
* Return: Success: 0
|
||||
* Failure: -1
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -271,23 +262,23 @@ error_stack(void)
|
||||
ssize_t err_num;
|
||||
const char *FUNC_error_stack = "error_stack";
|
||||
|
||||
if((err_num = H5Eget_num(H5E_DEFAULT)) < 0)
|
||||
if ((err_num = H5Eget_num(H5E_DEFAULT)) < 0)
|
||||
TEST_ERROR;
|
||||
if(err_num)
|
||||
if (err_num)
|
||||
TEST_ERROR;
|
||||
|
||||
if((ERR_STACK = H5Eget_current_stack()) < 0)
|
||||
if ((ERR_STACK = H5Eget_current_stack()) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Make it push error, force this function to fail */
|
||||
if((err_num = H5Eget_num(ERR_STACK)) == 0) {
|
||||
if ((err_num = H5Eget_num(ERR_STACK)) == 0) {
|
||||
H5Epush(ERR_STACK, __FILE__, FUNC_error_stack, __LINE__, ERR_CLS, ERR_MAJ_API, ERR_MIN_GETNUM,
|
||||
"Get number test failed, returned %d", (int)err_num);
|
||||
goto error;
|
||||
} /* end if */
|
||||
}
|
||||
|
||||
/* In case program falls through here, close the stack and let it fail. */
|
||||
if(H5Eclose_stack(ERR_STACK) < 0)
|
||||
if (H5Eclose_stack(ERR_STACK) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
return -1;
|
||||
@ -300,14 +291,10 @@ error:
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: long_desc_cb
|
||||
*
|
||||
* Purpose: Callback function to help test long description handling
|
||||
* Purpose: Callback function to help test long description handling
|
||||
*
|
||||
* Return: Success: 0
|
||||
*
|
||||
* Failure: -1
|
||||
*
|
||||
* Programmer: Quincey Koziol
|
||||
* January 19, 2005
|
||||
* Return: Success: 0
|
||||
* Failure: -1
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -316,24 +303,20 @@ long_desc_cb(unsigned H5_ATTR_UNUSED n, const H5E_error2_t *err_desc, void *clie
|
||||
{
|
||||
char *real_desc = (char *)client_data;
|
||||
|
||||
if(err_desc->desc != NULL && HDstrcmp(err_desc->desc, real_desc) == 0)
|
||||
return(0);
|
||||
if (err_desc->desc != NULL && HDstrcmp(err_desc->desc, real_desc) == 0)
|
||||
return 0;
|
||||
else
|
||||
return(-1);
|
||||
return -1;
|
||||
} /* end long_desc_cb() */
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: test_long_desc
|
||||
* Function: test_long_desc
|
||||
*
|
||||
* Purpose: Test long error description handling
|
||||
* Purpose: Test long error description handling
|
||||
*
|
||||
* Return: Success: 0
|
||||
*
|
||||
* Failure: -1
|
||||
*
|
||||
* Programmer: Quincey Koziol
|
||||
* January 19, 2005
|
||||
* Return: Success: 0
|
||||
* Failure: -1
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -347,56 +330,59 @@ test_long_desc(void)
|
||||
const char *test_FUNC = "test_long_desc";
|
||||
|
||||
/* Allocate space for the error description info */
|
||||
if(NULL == (long_desc = (char*)HDmalloc(LONG_DESC_SIZE))) TEST_ERROR;
|
||||
if(NULL == (full_desc = (char*)HDmalloc(LONG_DESC_SIZE + 128))) TEST_ERROR;
|
||||
if (NULL == (long_desc = (char *)HDmalloc(LONG_DESC_SIZE)))
|
||||
TEST_ERROR;
|
||||
if (NULL == (full_desc = (char *)HDmalloc(LONG_DESC_SIZE + 128)))
|
||||
TEST_ERROR;
|
||||
|
||||
/* Create the long part of the error description */
|
||||
for(u = 0; u < LONG_DESC_SIZE; u++)
|
||||
for (u = 0; u < LONG_DESC_SIZE; u++)
|
||||
long_desc[u] = (char)('A' + (u % 26));
|
||||
long_desc[LONG_DESC_SIZE - 1] = '\0';
|
||||
|
||||
/* Clear the default error stack */
|
||||
if(H5Eclear2(H5E_DEFAULT) < 0) TEST_ERROR;
|
||||
if (H5Eclear2(H5E_DEFAULT) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Push an error with a long description */
|
||||
if(H5Epush(H5E_DEFAULT, __FILE__, test_FUNC, __LINE__, ERR_CLS, ERR_MAJ_TEST, ERR_MIN_SUBROUTINE, format, long_desc) < 0) TEST_ERROR;
|
||||
if (H5Epush(H5E_DEFAULT, __FILE__, test_FUNC, __LINE__, ERR_CLS, ERR_MAJ_TEST, ERR_MIN_SUBROUTINE, format, long_desc) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Create the string that should be in the description. Must use HDsnprintf here
|
||||
* because snprintf is _snprintf on Windows */
|
||||
* because snprintf is _snprintf on Windows
|
||||
*/
|
||||
HDsnprintf(full_desc, (size_t)(LONG_DESC_SIZE + 128), format, long_desc);
|
||||
|
||||
/* Make certain that the description is correct */
|
||||
if(H5Ewalk2(H5E_DEFAULT, H5E_WALK_UPWARD, long_desc_cb, full_desc) < 0) TEST_ERROR;
|
||||
if (H5Ewalk2(H5E_DEFAULT, H5E_WALK_UPWARD, long_desc_cb, full_desc) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Clear the default error stack again */
|
||||
if(H5Eclear2(H5E_DEFAULT) < 0) TEST_ERROR;
|
||||
if (H5Eclear2(H5E_DEFAULT) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
HDfree(long_desc);
|
||||
HDfree(full_desc);
|
||||
|
||||
return(0);
|
||||
return 0;
|
||||
|
||||
error:
|
||||
if(long_desc)
|
||||
if (long_desc)
|
||||
HDfree(long_desc);
|
||||
if(full_desc)
|
||||
if (full_desc)
|
||||
HDfree(full_desc);
|
||||
|
||||
return(-1);
|
||||
return -1;
|
||||
} /* end test_long_desc() */
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: dump_error
|
||||
*
|
||||
* Purpose: Prints error stack in default and customized ways.
|
||||
* Purpose: Prints error stack in default and customized ways.
|
||||
*
|
||||
* Return: Success: 0
|
||||
*
|
||||
* Failure: -1
|
||||
*
|
||||
* Programmer: Raymond Lu
|
||||
* July 17, 2003
|
||||
* Return: Success: 0
|
||||
* Failure: -1
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -405,12 +391,12 @@ dump_error(hid_t estack)
|
||||
{
|
||||
/* Print errors in library default way */
|
||||
HDfprintf(stderr, "********* Print error stack in HDF5 default way *********\n");
|
||||
if(H5Eprint2(estack, stderr) < 0)
|
||||
if (H5Eprint2(estack, stderr) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Customized way to print errors */
|
||||
HDfprintf(stderr, "\n********* Print error stack in customized way *********\n");
|
||||
if(H5Ewalk2(estack, H5E_WALK_UPWARD, custom_print_cb, stderr) < 0)
|
||||
if (H5Ewalk2(estack, H5E_WALK_UPWARD, custom_print_cb, stderr) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
return 0;
|
||||
@ -423,34 +409,30 @@ error:
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: custom_print_cb
|
||||
*
|
||||
* Purpose: Callback function to print error stack in customized way.
|
||||
* Purpose: Callback function to print error stack in customized way.
|
||||
*
|
||||
* Return: Success: 0
|
||||
*
|
||||
* Failure: -1
|
||||
*
|
||||
* Programmer: Raymond Lu
|
||||
* July 17, 2003
|
||||
* Return: Success: 0
|
||||
* Failure: -1
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static herr_t
|
||||
custom_print_cb(unsigned n, const H5E_error2_t *err_desc, void* client_data)
|
||||
{
|
||||
FILE *stream = (FILE *)client_data;
|
||||
FILE *stream = (FILE *)client_data;
|
||||
char maj[MSG_SIZE];
|
||||
char min[MSG_SIZE];
|
||||
char cls[MSG_SIZE];
|
||||
const int indent = 4;
|
||||
const int indent = 4;
|
||||
|
||||
/* Get descriptions for the major and minor error numbers */
|
||||
if(H5Eget_class_name(err_desc->cls_id, cls, MSG_SIZE) < 0)
|
||||
if (H5Eget_class_name(err_desc->cls_id, cls, MSG_SIZE) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
if(H5Eget_msg(err_desc->maj_num, NULL, maj, MSG_SIZE) < 0)
|
||||
if (H5Eget_msg(err_desc->maj_num, NULL, maj, MSG_SIZE) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
if(H5Eget_msg(err_desc->min_num, NULL, min, MSG_SIZE) < 0)
|
||||
if (H5Eget_msg(err_desc->min_num, NULL, min, MSG_SIZE) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
HDfprintf(stream, "%*serror #%03d: %s in %s(): line %u\n",
|
||||
@ -468,54 +450,58 @@ error:
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: test_create
|
||||
* Function: test_create
|
||||
*
|
||||
* Purpose: Test creating an empty error stack
|
||||
* Purpose: Test creating an empty error stack
|
||||
*
|
||||
* Return: Success: 0
|
||||
* Failure: -1
|
||||
*
|
||||
* Programmer: Quincey Koziol
|
||||
* November 1, 2007
|
||||
* Return: Success: 0
|
||||
* Failure: -1
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static herr_t
|
||||
test_create(void)
|
||||
{
|
||||
const char *err_func = "test_create"; /* Function name for pushing error */
|
||||
const char *err_msg = "Error message"; /* Error message for pushing error */
|
||||
ssize_t err_num; /* Number of errors on stack */
|
||||
hid_t estack_id; /* Error stack ID */
|
||||
const char *err_func = "test_create"; /* Function name for pushing error */
|
||||
const char *err_msg = "Error message"; /* Error message for pushing error */
|
||||
ssize_t err_num; /* Number of errors on stack */
|
||||
hid_t estack_id = -1; /* Error stack ID */
|
||||
|
||||
/* Create an empty error stack */
|
||||
if((estack_id = H5Ecreate_stack()) < 0) TEST_ERROR
|
||||
if ((estack_id = H5Ecreate_stack()) < 0)
|
||||
TEST_ERROR
|
||||
|
||||
/* Check the number of errors on stack */
|
||||
err_num = H5Eget_num(estack_id);
|
||||
if(err_num != 0) TEST_ERROR
|
||||
if (err_num != 0)
|
||||
TEST_ERROR
|
||||
|
||||
/* Push an error with a long description */
|
||||
if(H5Epush(estack_id, __FILE__, err_func, __LINE__, ERR_CLS, ERR_MAJ_TEST, ERR_MIN_SUBROUTINE, "%s", err_msg) < 0) TEST_ERROR;
|
||||
if (H5Epush(estack_id, __FILE__, err_func, __LINE__, ERR_CLS, ERR_MAJ_TEST, ERR_MIN_SUBROUTINE, "%s", err_msg) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Check the number of errors on stack */
|
||||
err_num = H5Eget_num(estack_id);
|
||||
if(err_num != 1) TEST_ERROR
|
||||
if (err_num != 1)
|
||||
TEST_ERROR
|
||||
|
||||
/* Clear the error stack */
|
||||
if(H5Eclear2(estack_id) < 0) TEST_ERROR
|
||||
if (H5Eclear2(estack_id) < 0)
|
||||
TEST_ERROR
|
||||
|
||||
/* Check the number of errors on stack */
|
||||
err_num = H5Eget_num(estack_id);
|
||||
if(err_num != 0) TEST_ERROR
|
||||
if (err_num != 0)
|
||||
TEST_ERROR
|
||||
|
||||
/* Close error stack */
|
||||
if(H5Eclose_stack(estack_id) < 0) TEST_ERROR
|
||||
if(H5Eclose_stack(estack_id) < 0)
|
||||
TEST_ERROR
|
||||
|
||||
return(0);
|
||||
return 0;
|
||||
|
||||
error:
|
||||
return(-1);
|
||||
return -1;
|
||||
} /* end test_create() */
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
@ -526,70 +512,72 @@ error:
|
||||
* Return: Success: 0
|
||||
* Failure: -1
|
||||
*
|
||||
* Programmer: Allen Byrne
|
||||
* February 18, 2010
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static herr_t
|
||||
test_copy(void)
|
||||
{
|
||||
const char *err_func = "test_copy"; /* Function name for pushing error */
|
||||
const char *err_msg = "Error message"; /* Error message for pushing error */
|
||||
ssize_t err_num; /* Number of errors on stack */
|
||||
hid_t estack_id; /* Error stack ID */
|
||||
herr_t ret; /* Generic return value */
|
||||
const char *err_func = "test_copy"; /* Function name for pushing error */
|
||||
const char *err_msg = "Error message"; /* Error message for pushing error */
|
||||
ssize_t err_num; /* Number of errors on stack */
|
||||
hid_t estack_id = -1; /* Error stack ID */
|
||||
herr_t ret; /* Generic return value */
|
||||
|
||||
/* Push an error with a long description */
|
||||
if(H5Epush(H5E_DEFAULT, __FILE__, err_func, __LINE__, ERR_CLS, ERR_MAJ_TEST, ERR_MIN_SUBROUTINE, "%s", err_msg) < 0) TEST_ERROR;
|
||||
if (H5Epush(H5E_DEFAULT, __FILE__, err_func, __LINE__, ERR_CLS, ERR_MAJ_TEST, ERR_MIN_SUBROUTINE, "%s", err_msg) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Check the number of errors on stack */
|
||||
err_num = H5Eget_num(H5E_DEFAULT);
|
||||
if(err_num != 1) TEST_ERROR
|
||||
if (err_num != 1)
|
||||
TEST_ERROR
|
||||
|
||||
/* Copy error stack, which clears the original */
|
||||
if((estack_id = H5Eget_current_stack()) < 0) TEST_ERROR
|
||||
if ((estack_id = H5Eget_current_stack()) < 0)
|
||||
TEST_ERROR
|
||||
|
||||
/* Check the number of errors on stack copy */
|
||||
err_num = H5Eget_num(estack_id);
|
||||
if(err_num != 1) TEST_ERROR
|
||||
if (err_num != 1)
|
||||
TEST_ERROR
|
||||
|
||||
/* Check the number of errors on original stack */
|
||||
err_num = H5Eget_num(H5E_DEFAULT);
|
||||
if(err_num != 0) TEST_ERROR
|
||||
if (err_num != 0)
|
||||
TEST_ERROR
|
||||
|
||||
/* Put the stack copy as the default. It closes the stack copy, too. */
|
||||
if(H5Eset_current_stack(estack_id) < 0) TEST_ERROR
|
||||
if (H5Eset_current_stack(estack_id) < 0)
|
||||
TEST_ERROR
|
||||
|
||||
/* Check the number of errors on default stack */
|
||||
err_num = H5Eget_num(H5E_DEFAULT);
|
||||
if(err_num != 1) TEST_ERROR
|
||||
if (err_num != 1)
|
||||
TEST_ERROR
|
||||
|
||||
/* Try to close error stack copy. Should fail because
|
||||
* the current H5Eset_current_stack closes the stack to be set.*/
|
||||
* the current H5Eset_current_stack closes the stack to be set.
|
||||
*/
|
||||
H5E_BEGIN_TRY {
|
||||
ret = H5Eclose_stack(estack_id);
|
||||
} H5E_END_TRY
|
||||
if(ret >= 0) TEST_ERROR
|
||||
if (ret >= 0)
|
||||
TEST_ERROR
|
||||
|
||||
return(0);
|
||||
return 0;
|
||||
|
||||
error:
|
||||
return(-1);
|
||||
return -1;
|
||||
} /* end test_copy() */
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: close_error
|
||||
* Function: close_error
|
||||
*
|
||||
* Purpose: Closes error information.
|
||||
* Purpose: Closes error information.
|
||||
*
|
||||
* Return: Success: 0
|
||||
*
|
||||
* Failure: -1
|
||||
*
|
||||
* Programmer: Raymond Lu
|
||||
* July 10, 2003
|
||||
* Return: Success: 0
|
||||
* Failure: -1
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -597,19 +585,19 @@ static herr_t
|
||||
close_error(void)
|
||||
{
|
||||
/* Close major errors, let H5Eunregister_class close minor errors */
|
||||
if(H5Eclose_msg(ERR_MAJ_TEST) < 0)
|
||||
if (H5Eclose_msg(ERR_MAJ_TEST) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
if(H5Eclose_msg(ERR_MAJ_IO) < 0)
|
||||
if (H5Eclose_msg(ERR_MAJ_IO) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
if(H5Eclose_msg(ERR_MAJ_API) < 0)
|
||||
if (H5Eclose_msg(ERR_MAJ_API) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
if(H5Eunregister_class(ERR_CLS) < 0)
|
||||
if (H5Eunregister_class(ERR_CLS) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
if(H5Eunregister_class(ERR_CLS2) < 0)
|
||||
if (H5Eunregister_class(ERR_CLS2) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
return 0;
|
||||
@ -620,19 +608,15 @@ error:
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: test_filter_error
|
||||
* Function: test_filter_error
|
||||
*
|
||||
* Purpose: Make sure the error message prints out the filter name
|
||||
* Purpose: Make sure the error message prints out the filter name
|
||||
* when the existent file is opened but the filter isn't
|
||||
* registered. The existent file was created with
|
||||
* gen_filters.c.
|
||||
*
|
||||
* Return: Success: 0
|
||||
*
|
||||
* Failure: -1
|
||||
*
|
||||
* Programmer: Raymond Lu
|
||||
* 2 June 2011
|
||||
* Return: Success: 0
|
||||
* Failure: -1
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
@ -640,71 +624,72 @@ static herr_t
|
||||
test_filter_error(const char *fname)
|
||||
{
|
||||
const char *pathname = H5_get_srcdir_filename(fname); /* Corrected test file name */
|
||||
hid_t file, dataset; /* handles */
|
||||
hid_t file = -1;
|
||||
hid_t dataset = -1;
|
||||
int buf[20];
|
||||
|
||||
HDfprintf(stderr, "\nTesting error message during data reading when filter isn't registered\n");
|
||||
|
||||
/* Open the file */
|
||||
if((file = H5Fopen(pathname, H5F_ACC_RDONLY, H5P_DEFAULT)) < 0)
|
||||
if ((file = H5Fopen(pathname, H5F_ACC_RDONLY, H5P_DEFAULT)) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Open the regular dataset */
|
||||
if((dataset = H5Dopen2(file, DSET_FILTER_NAME, H5P_DEFAULT)) < 0)
|
||||
if ((dataset = H5Dopen2(file, DSET_FILTER_NAME, H5P_DEFAULT)) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
if(H5Dread(dataset, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) >= 0)
|
||||
TEST_ERROR;
|
||||
if (H5Dread(dataset, H5T_NATIVE_INT, H5S_ALL, H5S_ALL, H5P_DEFAULT, buf) >= 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Close/release resources */
|
||||
if(H5Dclose(dataset) < 0)
|
||||
if (H5Dclose(dataset) < 0)
|
||||
TEST_ERROR
|
||||
|
||||
if(H5Fclose(file) < 0)
|
||||
if (H5Fclose(file) < 0)
|
||||
TEST_ERROR
|
||||
|
||||
return 0;
|
||||
|
||||
error:
|
||||
return -1;
|
||||
}
|
||||
} /* end test_filter_error() */
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: main
|
||||
* Function: main
|
||||
*
|
||||
* Purpose: Test error API.
|
||||
*
|
||||
* Programmer: Raymond Lu
|
||||
* July 10, 2003
|
||||
* Purpose: Test error API.
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
int
|
||||
main(void)
|
||||
{
|
||||
hid_t file, fapl;
|
||||
hid_t estack_id;
|
||||
char filename[1024];
|
||||
const char *FUNC_main = "main";
|
||||
hid_t file = -1;
|
||||
hid_t fapl = -1;
|
||||
hid_t estack_id = -1;
|
||||
char filename[1024];
|
||||
const char *FUNC_main = "main";
|
||||
|
||||
HDfprintf(stderr, " This program tests the Error API. There're supposed to be some error messages\n");
|
||||
|
||||
/* Initialize errors */
|
||||
if(init_error() < 0)
|
||||
if (init_error() < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
fapl = h5_fileaccess();
|
||||
if ((fapl = h5_fileaccess()) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
h5_fixname(FILENAME[0], fapl, filename, sizeof filename);
|
||||
if((file = H5Fcreate(filename, H5F_ACC_TRUNC, H5P_DEFAULT, fapl)) < 0)
|
||||
TEST_ERROR;
|
||||
h5_fixname(FILENAME[0], fapl, filename, sizeof(filename));
|
||||
if ((file = H5Fcreate(filename, H5F_ACC_TRUNC, H5P_DEFAULT, fapl)) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Test error stack */
|
||||
if(error_stack() < 0) {
|
||||
if (error_stack() < 0) {
|
||||
/* Push an error onto error stack */
|
||||
if(H5Epush(ERR_STACK, __FILE__, FUNC_main, __LINE__, ERR_CLS, ERR_MAJ_TEST, ERR_MIN_ERRSTACK,
|
||||
"Error stack test failed") < 0) TEST_ERROR;
|
||||
if (H5Epush(ERR_STACK, __FILE__, FUNC_main, __LINE__, ERR_CLS, ERR_MAJ_TEST, ERR_MIN_ERRSTACK,
|
||||
"Error stack test failed") < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Delete an error from the top of error stack */
|
||||
H5Epop(ERR_STACK, 1);
|
||||
@ -724,34 +709,39 @@ main(void)
|
||||
} /* end if */
|
||||
|
||||
/* Test error API */
|
||||
if(test_error(file) < 0) {
|
||||
if (test_error(file) < 0) {
|
||||
H5Epush(H5E_DEFAULT, __FILE__, FUNC_main, __LINE__, ERR_CLS, ERR_MAJ_TEST, ERR_MIN_SUBROUTINE,
|
||||
"Error test failed, %s", "it's wrong");
|
||||
estack_id = H5Eget_current_stack();
|
||||
H5Eprint2(estack_id, stderr);
|
||||
H5Eclose_stack(estack_id);
|
||||
} /* end if */
|
||||
}
|
||||
|
||||
/* Test pushing a very long error description */
|
||||
if(test_long_desc() < 0) TEST_ERROR;
|
||||
if (test_long_desc() < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Test creating a new error stack */
|
||||
if(test_create() < 0) TEST_ERROR;
|
||||
if (test_create() < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Test copying a new error stack */
|
||||
if(test_copy() < 0) TEST_ERROR;
|
||||
if (test_copy() < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
if(H5Fclose(file) < 0) TEST_ERROR;
|
||||
if (H5Fclose(file) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Close error information */
|
||||
if(close_error() < 0)
|
||||
if (close_error() < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
/* Test error message during data reading when filter isn't registered
|
||||
* Use default FAPL to avoid some VFD drivers by the check-vfd test because
|
||||
* the test file was pre-generated. */
|
||||
* the test file was pre-generated.
|
||||
*/
|
||||
h5_fixname(DATAFILE, H5P_DEFAULT, filename, sizeof filename);
|
||||
if(test_filter_error(filename) < 0)
|
||||
if (test_filter_error(filename) < 0)
|
||||
TEST_ERROR;
|
||||
|
||||
h5_clean_files(FILENAME, fapl);
|
||||
|
@ -19,8 +19,8 @@
|
||||
|
||||
#include "h5test.h"
|
||||
|
||||
#define FILENAME "filenotclosed"
|
||||
#define DATASET "dset"
|
||||
#define FILENAME "filenotclosed"
|
||||
#define DATASET_NAME "dset"
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: catch_signal
|
||||
@ -114,7 +114,7 @@ main(void)
|
||||
TEST_ERROR
|
||||
|
||||
/* Create the dataset */
|
||||
if((did = H5Dcreate2(fid, "dset", H5T_NATIVE_INT, sid, H5P_DEFAULT, dcpl, H5P_DEFAULT)) < 0)
|
||||
if((did = H5Dcreate2(fid, DATASET_NAME, H5T_NATIVE_INT, sid, H5P_DEFAULT, dcpl, H5P_DEFAULT)) < 0)
|
||||
TEST_ERROR
|
||||
|
||||
/* Write to the dataset */
|
||||
|
1511
test/filter_plugin.c
Normal file
1511
test/filter_plugin.c
Normal file
File diff suppressed because it is too large
Load Diff
93
test/filter_plugin1_dsets.c
Normal file
93
test/filter_plugin1_dsets.c
Normal file
@ -0,0 +1,93 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* Copyright by The HDF Group. *
|
||||
* All rights reserved. *
|
||||
* *
|
||||
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
||||
* terms governing use, modification, and redistribution, is contained in *
|
||||
* the COPYING file, which can be found at the root of the source code *
|
||||
* distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases. *
|
||||
* If you do not have access to either file, you may request a copy from *
|
||||
* help@hdfgroup.org. *
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
/*
|
||||
* Purpose: Test dataset filter plugin for the filter_pluging.c test.
|
||||
*/
|
||||
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
|
||||
#include "H5PLextern.h"
|
||||
|
||||
#define FILTER1_ID 257
|
||||
|
||||
static size_t add_sub_value(unsigned int flags, size_t cd_nelmts,
|
||||
const unsigned int *cd_values, size_t nbytes, size_t *buf_size, void **buf);
|
||||
|
||||
/* Filter class struct */
|
||||
const H5Z_class2_t FILTER_INFO[1] = {{
|
||||
H5Z_CLASS_T_VERS, /* H5Z_class_t version */
|
||||
FILTER1_ID, /* Filter ID number */
|
||||
1, /* Encoding enabled */
|
||||
1, /* Decoding enabled */
|
||||
"test filter plugin 1", /* Filter name for debugging */
|
||||
NULL, /* The "can apply" callback */
|
||||
NULL, /* The "set local" callback */
|
||||
(H5Z_func_t)add_sub_value, /* The actual filter function */
|
||||
}};
|
||||
|
||||
H5PL_type_t H5PLget_plugin_type(void) {return H5PL_TYPE_FILTER;}
|
||||
const void *H5PLget_plugin_info(void) {return FILTER_INFO;}
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: add_sub_value
|
||||
*
|
||||
* Purpose: On write:
|
||||
* Adds a caller-supplied value to the element
|
||||
* On read:
|
||||
* Subtracts a caller-supplied value from the element
|
||||
*
|
||||
* Return: Success: Data chunk size in bytes
|
||||
* Failure: 0
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static size_t
|
||||
add_sub_value(unsigned int flags, size_t cd_nelmts, const unsigned int *cd_values,
|
||||
size_t nbytes, size_t *buf_size, void **buf)
|
||||
{
|
||||
int *int_ptr = (int *)*buf; /* Pointer to the data values */
|
||||
size_t buf_left = *buf_size; /* Amount of data buffer left to process */
|
||||
int value = 0; /* Data value to add/subtract */
|
||||
|
||||
/* Check for the correct number of parameters */
|
||||
if (0 == cd_nelmts)
|
||||
return 0;
|
||||
|
||||
/* Check that permanent parameters are set correctly */
|
||||
if (cd_values[0] > 9)
|
||||
return 0;
|
||||
|
||||
value = (int)cd_values[0];
|
||||
|
||||
if (flags & H5Z_FLAG_REVERSE) {
|
||||
/* READ - Substract the given value from all the data values */
|
||||
while (buf_left > 0) {
|
||||
*int_ptr++ -= value;
|
||||
buf_left -= sizeof(int);
|
||||
}
|
||||
}
|
||||
else {
|
||||
/* WRITE - Add the given value to all the data values */
|
||||
while (buf_left > 0) {
|
||||
*int_ptr++ += value;
|
||||
buf_left -= sizeof(int);
|
||||
}
|
||||
}
|
||||
|
||||
return nbytes;
|
||||
|
||||
} /* end add_sub_value() */
|
||||
|
88
test/filter_plugin2_dsets.c
Normal file
88
test/filter_plugin2_dsets.c
Normal file
@ -0,0 +1,88 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* Copyright by The HDF Group. *
|
||||
* All rights reserved. *
|
||||
* *
|
||||
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
||||
* terms governing use, modification, and redistribution, is contained in *
|
||||
* the COPYING file, which can be found at the root of the source code *
|
||||
* distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases. *
|
||||
* If you do not have access to either file, you may request a copy from *
|
||||
* help@hdfgroup.org. *
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
/*
|
||||
* Purpose: Test dataset filter plugin for the filter_pluging.c test.
|
||||
*/
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
|
||||
#include "H5PLextern.h"
|
||||
|
||||
#define FILTER2_ID 258
|
||||
#define MULTIPLIER 3
|
||||
|
||||
static size_t mult_div_value(unsigned int flags, size_t cd_nelmts,
|
||||
const unsigned int *cd_values, size_t nbytes, size_t *buf_size, void **buf);
|
||||
|
||||
/* Filter class struct */
|
||||
const H5Z_class2_t FILTER_INFO[1] = {{
|
||||
H5Z_CLASS_T_VERS, /* H5Z_class_t version */
|
||||
FILTER2_ID, /* Filter ID number */
|
||||
1, /* Encoding enabled */
|
||||
1, /* Decoding enabled */
|
||||
"test filter plugin 2", /* Filter name for debugging */
|
||||
NULL, /* The "can apply" callback */
|
||||
NULL, /* The "set local" callback */
|
||||
(H5Z_func_t)mult_div_value, /* The actual filter function */
|
||||
}};
|
||||
|
||||
H5PL_type_t H5PLget_plugin_type(void) {return H5PL_TYPE_FILTER;}
|
||||
const void *H5PLget_plugin_info(void) {return FILTER_INFO;}
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: mult_div_value
|
||||
*
|
||||
* Purpose: On write:
|
||||
* Multiplies an element by a constant value.
|
||||
* On read:
|
||||
* Divides an element by a constant value.
|
||||
*
|
||||
* Return: Success: Data chunk size in bytes
|
||||
* Failure: 0
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static size_t
|
||||
mult_div_value(unsigned int flags, size_t cd_nelmts,
|
||||
const unsigned int *cd_values, size_t nbytes, size_t *buf_size, void **buf)
|
||||
{
|
||||
int *int_ptr = (int *)*buf; /* Pointer to the data values */
|
||||
size_t buf_left = *buf_size; /* Amount of data buffer left to process */
|
||||
|
||||
/* Check for the correct number of parameters */
|
||||
if (cd_nelmts > 0)
|
||||
return 0;
|
||||
|
||||
/* Assignment to eliminate unused parameter warning */
|
||||
cd_values = cd_values;
|
||||
|
||||
if (flags & H5Z_FLAG_REVERSE) {
|
||||
/* READ - Divide the original value by MULTIPLIER */
|
||||
while (buf_left > 0) {
|
||||
*int_ptr++ /= MULTIPLIER;
|
||||
buf_left -= sizeof(int);
|
||||
}
|
||||
}
|
||||
else {
|
||||
/* WRITE - Multiply the original value by MULTIPLIER */
|
||||
while (buf_left > 0) {
|
||||
*int_ptr++ *= MULTIPLIER;
|
||||
buf_left -= sizeof(int);
|
||||
}
|
||||
}
|
||||
|
||||
return nbytes;
|
||||
} /* end mult_div_value() */
|
||||
|
119
test/filter_plugin3_dsets.c
Normal file
119
test/filter_plugin3_dsets.c
Normal file
@ -0,0 +1,119 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* Copyright by The HDF Group. *
|
||||
* All rights reserved. *
|
||||
* *
|
||||
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
||||
* terms governing use, modification, and redistribution, is contained in *
|
||||
* the COPYING file, which can be found at the root of the source code *
|
||||
* distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases. *
|
||||
* If you do not have access to either file, you may request a copy from *
|
||||
* help@hdfgroup.org. *
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
/*
|
||||
* Purpose: Test dataset filter plugin for the filter_pluging.c test.
|
||||
* This filter makes an HDF5 API call to ensure that works correctly.
|
||||
*/
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
|
||||
#include "H5PLextern.h"
|
||||
|
||||
#define FILTER3_ID 259
|
||||
|
||||
#define PUSH_ERR(func, minor, str) H5Epush2(H5E_DEFAULT, __FILE__, func, __LINE__, H5E_ERR_CLS, H5E_PLUGIN, minor, str)
|
||||
|
||||
static size_t add_sub_value_hdf5(unsigned int flags, size_t cd_nelmts,
|
||||
const unsigned int *cd_values, size_t nbytes, size_t *buf_size, void **buf);
|
||||
|
||||
/* Filter class struct */
|
||||
const H5Z_class2_t FILTER_INFO[1] = {{
|
||||
H5Z_CLASS_T_VERS, /* H5Z_class_t version */
|
||||
FILTER3_ID, /* Filter ID number */
|
||||
1, /* Encoding enabled */
|
||||
1, /* Decoding enabled */
|
||||
"test filter plugin 3", /* Filter name for debugging */
|
||||
NULL, /* The "can apply" callback */
|
||||
NULL, /* The "set local" callback */
|
||||
(H5Z_func_t)add_sub_value_hdf5, /* The actual filter function */
|
||||
}};
|
||||
|
||||
H5PL_type_t H5PLget_plugin_type(void) {return H5PL_TYPE_FILTER;}
|
||||
const void *H5PLget_plugin_info(void) {return FILTER_INFO;}
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: add_sub_value_hdf5
|
||||
*
|
||||
* Purpose: On write:
|
||||
* Adds a caller-supplied value to the element
|
||||
* On read:
|
||||
* Subtracts a caller-supplied value from the element
|
||||
*
|
||||
* NOTE: This filter is identical to filter #1 only it makes
|
||||
* an HDF5 library call to ensure doing that doesn't
|
||||
* cause problems.
|
||||
*
|
||||
* Return: Success: Data chunk size in bytes
|
||||
* Failure: 0
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static size_t
|
||||
add_sub_value_hdf5(unsigned int flags, size_t cd_nelmts, const unsigned int *cd_values,
|
||||
size_t nbytes, size_t *buf_size, void **buf)
|
||||
{
|
||||
int *int_ptr = (int *)*buf; /* Pointer to the data values */
|
||||
size_t buf_left = *buf_size; /* Amount of data buffer left to process */
|
||||
int value = 0; /* Data value to add/subtract */
|
||||
unsigned majnum = 0; /* Output data from the HDF5 library call */
|
||||
unsigned minnum = 0;
|
||||
unsigned relnum = 0;
|
||||
|
||||
/* Check for the library version.
|
||||
* We don't do anything with this information - it's just to ensure that
|
||||
* HDF5 library calls work properly from inside filter plugins.
|
||||
*/
|
||||
if (H5get_libversion(&majnum, &minnum, &relnum) < 0) {
|
||||
PUSH_ERR("filter plugin 3", H5E_CALLBACK, "H5get_libversion");
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Check for the correct number of parameters */
|
||||
if (cd_nelmts == 0)
|
||||
return 0;
|
||||
|
||||
/* Check that permanent parameters are set correctly */
|
||||
if (cd_values[0] > 9)
|
||||
return 0;
|
||||
|
||||
/* Ensure that the version numbers match what was passed in.
|
||||
* Again, this is trivial work, just to ensure that the library calls are
|
||||
* working properly.
|
||||
*/
|
||||
if (majnum != cd_values[1] || minnum != cd_values[2]) {
|
||||
PUSH_ERR("filter plugin 3", H5E_CALLBACK, "library versions do not match");
|
||||
return 0;
|
||||
}
|
||||
|
||||
value = (int)cd_values[0];
|
||||
|
||||
if (flags & H5Z_FLAG_REVERSE) {
|
||||
/* READ - Substract the given value from all the data values */
|
||||
while (buf_left > 0) {
|
||||
*int_ptr++ -= value;
|
||||
buf_left -= sizeof(int);
|
||||
}
|
||||
}
|
||||
else {
|
||||
/* WRITE - Add the given value to all the data values */
|
||||
while (buf_left > 0) {
|
||||
*int_ptr++ += value;
|
||||
buf_left -= sizeof(int);
|
||||
}
|
||||
}
|
||||
|
||||
return nbytes;
|
||||
} /* end add_sub_value_hdf5() */
|
||||
|
106
test/filter_plugin4_groups.c
Normal file
106
test/filter_plugin4_groups.c
Normal file
@ -0,0 +1,106 @@
|
||||
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
|
||||
* Copyright by The HDF Group. *
|
||||
* All rights reserved. *
|
||||
* *
|
||||
* This file is part of HDF5. The full HDF5 copyright notice, including *
|
||||
* terms governing use, modification, and redistribution, is contained in *
|
||||
* the COPYING file, which can be found at the root of the source code *
|
||||
* distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases. *
|
||||
* If you do not have access to either file, you may request a copy from *
|
||||
* help@hdfgroup.org. *
|
||||
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
|
||||
|
||||
/*
|
||||
* Purpose: Test group filter plugin for the filter_pluging.c test.
|
||||
*/
|
||||
|
||||
#include <stdlib.h>
|
||||
#include <stdio.h>
|
||||
#include <string.h>
|
||||
|
||||
#include "H5PLextern.h"
|
||||
|
||||
#define FILTER4_ID 260
|
||||
#define SUFFIX_LEN 8
|
||||
#define GROUP_SUFFIX ".h5group"
|
||||
|
||||
static size_t append_to_group_name(unsigned int flags, size_t cd_nelmts,
|
||||
const unsigned int *cd_values, size_t nbytes, size_t *buf_size, void **buf);
|
||||
|
||||
/* Filter class struct */
|
||||
const H5Z_class2_t FILTER_INFO[1] = {{
|
||||
H5Z_CLASS_T_VERS, /* H5Z_class_t version */
|
||||
FILTER4_ID, /* Filter ID number */
|
||||
1, /* Encoding enabled */
|
||||
1, /* Decoding enabled */
|
||||
"test filter plugin 4", /* Filter name for debugging */
|
||||
NULL, /* The "can apply" callback */
|
||||
NULL, /* The "set local" callback */
|
||||
(H5Z_func_t)append_to_group_name, /* The actual filter function */
|
||||
}};
|
||||
|
||||
H5PL_type_t H5PLget_plugin_type(void) {return H5PL_TYPE_FILTER;}
|
||||
const void *H5PLget_plugin_info(void) {return FILTER_INFO;}
|
||||
|
||||
|
||||
/*-------------------------------------------------------------------------
|
||||
* Function: append_to_group_name
|
||||
*
|
||||
* Purpose: On write:
|
||||
* Appends the suffix ".h5group" to the group name
|
||||
* On read:
|
||||
* Removes the ".h5group" suffix from the group name
|
||||
*
|
||||
* Return: Success: Data size in bytes
|
||||
* Failure: 0
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
static size_t
|
||||
append_to_group_name(unsigned int flags, size_t cd_nelmts,
|
||||
const unsigned int *cd_values, size_t nbytes, size_t *buf_size, void **buf)
|
||||
{
|
||||
size_t new_name_size = 0; /* Return value */
|
||||
|
||||
/* Check for the correct number of parameters */
|
||||
if (cd_nelmts > 0)
|
||||
return 0;
|
||||
|
||||
/* Assignment to eliminate unused parameter warning. */
|
||||
cd_values = cd_values;
|
||||
|
||||
if (flags & H5Z_FLAG_REVERSE) {
|
||||
/* READ - Remove the suffix from the group name */
|
||||
new_name_size = *buf_size = nbytes - SUFFIX_LEN;
|
||||
}
|
||||
else {
|
||||
/* WRITE - Append the suffix to the group name */
|
||||
void *outbuf = NULL; /* Pointer to new buffer */
|
||||
unsigned char *dst = NULL; /* Temporary pointer to destination buffer */
|
||||
|
||||
/* Get memory for the new, larger string buffer using the
|
||||
* library's memory allocator.
|
||||
*/
|
||||
if (NULL == (dst = (unsigned char *)(outbuf = H5allocate_memory(nbytes + SUFFIX_LEN, 0))))
|
||||
return 0;
|
||||
|
||||
/* Copy raw data */
|
||||
memcpy((void *)dst, (const void *)(*buf), nbytes);
|
||||
|
||||
/* Append suffix to raw data for storage */
|
||||
dst += nbytes;
|
||||
memcpy((void *)dst, (const void *)GROUP_SUFFIX, SUFFIX_LEN);
|
||||
|
||||
/* Free the passed-in buffer using the library's allocator */
|
||||
H5free_memory(*buf);
|
||||
|
||||
/* Set return values */
|
||||
*buf_size = nbytes + SUFFIX_LEN;
|
||||
*buf = outbuf;
|
||||
outbuf = NULL;
|
||||
new_name_size = *buf_size;
|
||||
}
|
||||
|
||||
return new_name_size;
|
||||
} /* append_to_group_name() */
|
||||
|
1217
test/plugin.c
1217
test/plugin.c
File diff suppressed because it is too large
Load Diff
@ -679,7 +679,7 @@ test_array_compound_atomic(void)
|
||||
|
||||
/* Check the 1st field's name */
|
||||
mname = H5Tget_member_name(tid2, 0);
|
||||
CHECK(mname, NULL, "H5Tget_member_name");
|
||||
CHECK_PTR(mname, "H5Tget_member_name");
|
||||
if(HDstrcmp(mname, "i") != 0)
|
||||
TestErrPrintf("Compound field name doesn't match!, mname=%s\n", mname);
|
||||
H5free_memory(mname);
|
||||
@ -698,7 +698,7 @@ test_array_compound_atomic(void)
|
||||
|
||||
/* Check the 2nd field's name */
|
||||
mname = H5Tget_member_name(tid2, 1);
|
||||
CHECK(mname, NULL, "H5Tget_member_name");
|
||||
CHECK_PTR(mname, "H5Tget_member_name");
|
||||
if(HDstrcmp(mname, "f") != 0)
|
||||
TestErrPrintf("Compound field name doesn't match!, mname=%s\n", mname);
|
||||
H5free_memory(mname);
|
||||
@ -897,7 +897,7 @@ test_array_compound_array(void)
|
||||
|
||||
/* Check the 1st field's name */
|
||||
mname=H5Tget_member_name(tid2,0);
|
||||
CHECK(mname, NULL, "H5Tget_member_name");
|
||||
CHECK_PTR(mname, "H5Tget_member_name");
|
||||
if(HDstrcmp(mname,"i")!=0)
|
||||
TestErrPrintf("Compound field name doesn't match!, mname=%s\n",mname);
|
||||
H5free_memory(mname);
|
||||
@ -916,7 +916,7 @@ test_array_compound_array(void)
|
||||
|
||||
/* Check the 2nd field's name */
|
||||
mname=H5Tget_member_name(tid2,1);
|
||||
CHECK(mname, NULL, "H5Tget_member_name");
|
||||
CHECK_PTR(mname, "H5Tget_member_name");
|
||||
if(HDstrcmp(mname,"f")!=0)
|
||||
TestErrPrintf("Compound field name doesn't match!, mname=%s\n",mname);
|
||||
H5free_memory(mname);
|
||||
@ -1604,7 +1604,7 @@ test_array_bkg(void)
|
||||
/* Initialize the data */
|
||||
/* ------------------- */
|
||||
dtsinfo = (CmpDTSinfo *)HDmalloc(sizeof(CmpDTSinfo));
|
||||
CHECK(dtsinfo, NULL, "HDmalloc");
|
||||
CHECK_PTR(dtsinfo, "HDmalloc");
|
||||
HDmemset(dtsinfo, 0, sizeof(CmpDTSinfo));
|
||||
for (i = 0; i < LENGTH; i++) {
|
||||
for (j = 0; j < ALEN; j++) {
|
||||
@ -1927,7 +1927,7 @@ test_compat(void)
|
||||
|
||||
/* Check the 1st field's name */
|
||||
mname=H5Tget_member_name(tid1,0);
|
||||
CHECK(mname, NULL, "H5Tget_member_name");
|
||||
CHECK_PTR(mname, "H5Tget_member_name");
|
||||
if(HDstrcmp(mname,"i")!=0)
|
||||
TestErrPrintf("Compound field name doesn't match!, mname=%s\n",mname);
|
||||
H5free_memory(mname);
|
||||
@ -1946,7 +1946,7 @@ test_compat(void)
|
||||
|
||||
/* Check the 2nd field's name */
|
||||
mname=H5Tget_member_name(tid1,1);
|
||||
CHECK(mname, NULL, "H5Tget_member_name");
|
||||
CHECK_PTR(mname, "H5Tget_member_name");
|
||||
if(HDstrcmp(mname,"f")!=0)
|
||||
TestErrPrintf("Compound field name doesn't match!, mname=%s\n",mname);
|
||||
H5free_memory(mname);
|
||||
@ -1965,7 +1965,7 @@ test_compat(void)
|
||||
|
||||
/* Check the 3rd field's name */
|
||||
mname=H5Tget_member_name(tid1,2);
|
||||
CHECK(mname, NULL, "H5Tget_member_name");
|
||||
CHECK_PTR(mname, "H5Tget_member_name");
|
||||
if(HDstrcmp(mname,"l")!=0)
|
||||
TestErrPrintf("Compound field name doesn't match!, mname=%s\n",mname);
|
||||
H5free_memory(mname);
|
||||
@ -2009,7 +2009,7 @@ test_compat(void)
|
||||
|
||||
/* Check the 1st field's name */
|
||||
mname=H5Tget_member_name(tid1,0);
|
||||
CHECK(mname, NULL, "H5Tget_member_name");
|
||||
CHECK_PTR(mname, "H5Tget_member_name");
|
||||
if(mname && HDstrcmp(mname,"i")!=0)
|
||||
TestErrPrintf("Compound field name doesn't match!, mname=%s\n",mname);
|
||||
if(mname) H5free_memory(mname);
|
||||
@ -2028,7 +2028,7 @@ test_compat(void)
|
||||
|
||||
/* Check the 2nd field's name */
|
||||
mname=H5Tget_member_name(tid1,1);
|
||||
CHECK(mname, NULL, "H5Tget_member_name");
|
||||
CHECK_PTR(mname, "H5Tget_member_name");
|
||||
if(mname && HDstrcmp(mname,"f")!=0)
|
||||
TestErrPrintf("Compound field name doesn't match!, mname=%s\n",mname);
|
||||
if(mname) H5free_memory(mname);
|
||||
@ -2073,7 +2073,7 @@ test_compat(void)
|
||||
|
||||
/* Check the 3rd field's name */
|
||||
mname=H5Tget_member_name(tid1,2);
|
||||
CHECK(mname, NULL, "H5Tget_member_name");
|
||||
CHECK_PTR(mname, "H5Tget_member_name");
|
||||
if(mname && HDstrcmp(mname,"l")!=0)
|
||||
TestErrPrintf("Compound field name doesn't match!, mname=%s\n",mname);
|
||||
if(mname) H5free_memory(mname);
|
||||
@ -2118,7 +2118,7 @@ test_compat(void)
|
||||
|
||||
/* Check the 4th field's name */
|
||||
mname=H5Tget_member_name(tid1,3);
|
||||
CHECK(mname, NULL, "H5Tget_member_name");
|
||||
CHECK_PTR(mname, "H5Tget_member_name");
|
||||
if(mname && HDstrcmp(mname,"d")!=0)
|
||||
TestErrPrintf("Compound field name doesn't match!, mname=%s\n",mname);
|
||||
if(mname) H5free_memory(mname);
|
||||
|
14
test/tattr.c
14
test/tattr.c
@ -277,7 +277,7 @@ test_attr_basic_write(hid_t fapl)
|
||||
|
||||
if(attr_name_size > 0) {
|
||||
attr_name = (char*)HDcalloc((size_t)(attr_name_size + 1), sizeof(char));
|
||||
CHECK(attr_name, NULL, "HDcalloc");
|
||||
CHECK_PTR(attr_name, "HDcalloc");
|
||||
|
||||
if(attr_name) {
|
||||
ret = (herr_t)H5Aget_name(attr, (size_t)(attr_name_size + 1), attr_name);
|
||||
@ -313,7 +313,7 @@ test_attr_basic_write(hid_t fapl)
|
||||
|
||||
if(attr_name_size > 0) {
|
||||
attr_name = (char*)HDcalloc((size_t)(attr_name_size+1), sizeof(char));
|
||||
CHECK(attr_name, NULL, "HDcalloc");
|
||||
CHECK_PTR(attr_name, "HDcalloc");
|
||||
|
||||
if(attr_name) {
|
||||
ret = (herr_t)H5Aget_name(attr2, (size_t)(attr_name_size + 1), attr_name);
|
||||
@ -6862,7 +6862,7 @@ test_attr_iterate2(hbool_t new_format, hid_t fcpl, hid_t fapl)
|
||||
/* Allocate the "visited link" array */
|
||||
iter_info.max_visit = max_compact * 2;
|
||||
visited = (hbool_t*)HDmalloc(sizeof(hbool_t) * iter_info.max_visit);
|
||||
CHECK(visited, NULL, "HDmalloc");
|
||||
CHECK_PTR(visited, "HDmalloc");
|
||||
iter_info.visited = visited;
|
||||
|
||||
/* Loop over operating on different indices on link fields */
|
||||
@ -8040,7 +8040,7 @@ test_attr_shared_write(hid_t fcpl, hid_t fapl)
|
||||
|
||||
/* Allocate & initialize "big" attribute data */
|
||||
big_value = (unsigned *)HDmalloc((size_t)(SPACE1_DIM1 * SPACE1_DIM2 * SPACE1_DIM3) * sizeof(unsigned));
|
||||
CHECK(big_value, NULL, "HDmalloc");
|
||||
CHECK_PTR(big_value, "HDmalloc");
|
||||
HDmemset(big_value, 1, sizeof(unsigned) * (size_t)(SPACE1_DIM1 * SPACE1_DIM2 * SPACE1_DIM3));
|
||||
|
||||
/* Create dataspace for dataset */
|
||||
@ -8371,7 +8371,7 @@ test_attr_shared_rename(hid_t fcpl, hid_t fapl)
|
||||
|
||||
/* Allocate & initialize "big" attribute data */
|
||||
big_value = (unsigned *)HDmalloc((size_t)(SPACE1_DIM1 * SPACE1_DIM2 * SPACE1_DIM3) * sizeof(unsigned));
|
||||
CHECK(big_value, NULL, "HDmalloc");
|
||||
CHECK_PTR(big_value, "HDmalloc");
|
||||
HDmemset(big_value, 1, sizeof(unsigned) * (size_t)(SPACE1_DIM1 * SPACE1_DIM2 * SPACE1_DIM3));
|
||||
|
||||
/* Create dataspace for dataset */
|
||||
@ -8817,7 +8817,7 @@ test_attr_shared_delete(hid_t fcpl, hid_t fapl)
|
||||
|
||||
/* Allocate & initialize "big" attribute data */
|
||||
big_value = (unsigned *)HDmalloc((size_t)(SPACE1_DIM1 * SPACE1_DIM2 * SPACE1_DIM3) * sizeof(unsigned));
|
||||
CHECK(big_value, NULL, "HDmalloc");
|
||||
CHECK_PTR(big_value, "HDmalloc");
|
||||
HDmemset(big_value, 1, sizeof(unsigned) * (size_t)(SPACE1_DIM1 * SPACE1_DIM2 * SPACE1_DIM3));
|
||||
|
||||
/* Create dataspace for dataset */
|
||||
@ -9186,7 +9186,7 @@ test_attr_shared_unlink(hid_t fcpl, hid_t fapl)
|
||||
|
||||
/* Allocate & initialize "big" attribute data */
|
||||
big_value = (unsigned *)HDmalloc((size_t)(SPACE1_DIM1 * SPACE1_DIM2 * SPACE1_DIM3) * sizeof(unsigned));
|
||||
CHECK(big_value, NULL, "HDmalloc");
|
||||
CHECK_PTR(big_value, "HDmalloc");
|
||||
HDmemset(big_value, 1, sizeof(unsigned) * (size_t)(SPACE1_DIM1 * SPACE1_DIM2 * SPACE1_DIM3));
|
||||
|
||||
/* Create dataspace for dataset */
|
||||
|
@ -187,7 +187,7 @@ test_chksum_large(void)
|
||||
|
||||
/* Allocate the buffer */
|
||||
large_buf = (uint8_t *)HDmalloc((size_t)BUF_LEN);
|
||||
CHECK(large_buf, NULL, "HDmalloc");
|
||||
CHECK_PTR(large_buf, "HDmalloc");
|
||||
|
||||
/* Initialize buffer w/known data */
|
||||
for(u = 0; u < BUF_LEN; u++)
|
||||
|
@ -669,22 +669,22 @@ static void test_multiple_ends(hid_t file, hbool_t is_chunked)
|
||||
void test_coords(void)
|
||||
{
|
||||
hid_t fid;
|
||||
hbool_t is_chunk[2] = {TRUE, FALSE};
|
||||
int i;
|
||||
hbool_t is_chunk;
|
||||
herr_t ret; /* Generic error return */
|
||||
|
||||
fid = H5Fcreate(FILENAME, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT);
|
||||
CHECK(fid, FAIL, "H5Fcreate");
|
||||
|
||||
for(i=0, is_chunk=FALSE; i<2; i++, is_chunk++) {
|
||||
for (i = 0; i < 2; i++) {
|
||||
/* Test H5Sselect_elements with selection of one block of data */
|
||||
test_singleEnd_selElements(fid, is_chunk);
|
||||
test_singleEnd_selElements(fid, is_chunk[i]);
|
||||
|
||||
/* Test H5Sselect_hyperslab with selection of one block of data */
|
||||
test_singleEnd_selHyperslab(fid, is_chunk);
|
||||
test_singleEnd_selHyperslab(fid, is_chunk[i]);
|
||||
|
||||
/* Test H5Sselect_hyperslab with selection of multiple blocks of data */
|
||||
test_multiple_ends(fid, is_chunk);
|
||||
test_multiple_ends(fid, is_chunk[i]);
|
||||
}
|
||||
|
||||
ret = H5Fclose(fid);
|
||||
|
@ -13,7 +13,7 @@
|
||||
srcdir=@srcdir@
|
||||
TOP_BUILDDIR=@top_builddir@
|
||||
|
||||
# Determine backward compatibility options enabled
|
||||
# Determine if backward compatibility options enabled
|
||||
DEPRECATED_SYMBOLS="@DEPRECATED_SYMBOLS@"
|
||||
|
||||
EXIT_SUCCESS=0
|
||||
@ -23,21 +23,21 @@ nerrors=0
|
||||
verbose=yes
|
||||
exit_code=$EXIT_SUCCESS
|
||||
|
||||
TEST_NAME=plugin
|
||||
TEST_NAME=filter_plugin
|
||||
TEST_BIN=`pwd`/$TEST_NAME
|
||||
FROM_DIR=`pwd`/.libs
|
||||
case $(uname) in
|
||||
CYGWIN* )
|
||||
PLUGIN_LIB1="$FROM_DIR/cygdynlib1* $FROM_DIR/cygdynlib3*"
|
||||
PLUGIN_LIB2="$FROM_DIR/cygdynlib2* $FROM_DIR/cygdynlib4*"
|
||||
PLUGINS_FOR_DIR1="$FROM_DIR/cygfilter_plugin1* $FROM_DIR/cygfilter_plugin3*"
|
||||
PLUGINS_FOR_DIR2="$FROM_DIR/cygfilter_plugin2* $FROM_DIR/cygfilter_plugin4*"
|
||||
;;
|
||||
*)
|
||||
PLUGIN_LIB1="$FROM_DIR/libdynlib1.* $FROM_DIR/libdynlib3.*"
|
||||
PLUGIN_LIB2="$FROM_DIR/libdynlib2.* $FROM_DIR/libdynlib4.*"
|
||||
PLUGINS_FOR_DIR1="$FROM_DIR/libfilter_plugin1* $FROM_DIR/libfilter_plugin3*"
|
||||
PLUGINS_FOR_DIR2="$FROM_DIR/libfilter_plugin2* $FROM_DIR/libfilter_plugin4*"
|
||||
;;
|
||||
esac
|
||||
PLUGIN_LIBDIR1=testdir1
|
||||
PLUGIN_LIBDIR2=testdir2
|
||||
PLUGIN_DIR1=filter_plugin_dir1
|
||||
PLUGIN_DIR2=filter_plugin_dir2
|
||||
CP="cp -p" # Use -p to preserve mode,ownership,timestamps
|
||||
RM="rm -rf"
|
||||
|
||||
@ -50,34 +50,34 @@ TESTING() {
|
||||
}
|
||||
|
||||
# Main Body
|
||||
# Create test directories if not exists yet.
|
||||
test -d $PLUGIN_LIBDIR1 || mkdir -p $PLUGIN_LIBDIR1
|
||||
# Create test directories if necessary.
|
||||
test -d $PLUGIN_DIR1 || mkdir -p $PLUGIN_DIR1
|
||||
if [ $? != 0 ]; then
|
||||
echo "Failed to create test directory($PLUGIN_LIBDIR1)"
|
||||
echo "Failed to create filter plugin test directory ($PLUGIN_DIR1)"
|
||||
exit $EXIT_FAILURE
|
||||
fi
|
||||
|
||||
test -d $PLUGIN_LIBDIR2 || mkdir -p $PLUGIN_LIBDIR2
|
||||
test -d $PLUGIN_DIR2 || mkdir -p $PLUGIN_DIR2
|
||||
if [ $? != 0 ]; then
|
||||
echo "Failed to create test directory($PLUGIN_LIBDIR2)"
|
||||
echo "Failed to create filter plugin test directory ($PLUGIN_DIR2)"
|
||||
exit $EXIT_FAILURE
|
||||
fi
|
||||
|
||||
# copy plugin library for test
|
||||
$CP $PLUGIN_LIB1 $PLUGIN_LIBDIR1
|
||||
# Copy plugins for the tests.
|
||||
$CP $PLUGINS_FOR_DIR1 $PLUGIN_DIR1
|
||||
if [ $? != 0 ]; then
|
||||
echo "Failed to copy plugin library ($PLUGIN_LIB1) for test."
|
||||
echo "Failed to copy filter plugins ($PLUGINS_FOR_DIR1) to test directory."
|
||||
exit $EXIT_FAILURE
|
||||
fi
|
||||
|
||||
$CP $PLUGIN_LIB2 $PLUGIN_LIBDIR2
|
||||
$CP $PLUGINS_FOR_DIR2 $PLUGIN_DIR2
|
||||
if [ $? != 0 ]; then
|
||||
echo "Failed to copy plugin library ($PLUGIN_LIB2) for test."
|
||||
echo "Failed to copy filter plugins ($PLUGINS_FOR_DIR2) to test directory."
|
||||
exit $EXIT_FAILURE
|
||||
fi
|
||||
|
||||
# setup plugin path
|
||||
ENVCMD="env HDF5_PLUGIN_PATH=${PLUGIN_LIBDIR1}:${PLUGIN_LIBDIR2}"
|
||||
ENVCMD="env HDF5_PLUGIN_PATH=${PLUGIN_DIR1}:${PLUGIN_DIR2}"
|
||||
|
||||
# Run the test
|
||||
$ENVCMD $TEST_BIN
|
||||
@ -87,9 +87,9 @@ fi
|
||||
|
||||
############################################
|
||||
# HDFFV-9655 test for relative path disabled
|
||||
# setup plugin path relative to test
|
||||
# setup filter plugin path relative to test
|
||||
# actual executable is in the .libs folder
|
||||
#ENVCMD="env HDF5_PLUGIN_PATH=@/../${PLUGIN_LIBDIR1}:@/../${PLUGIN_LIBDIR2}"
|
||||
#ENVCMD="env HDF5_PLUGIN_PATH=@/../${PLUGIN_DIR1}:@/../${PLUGIN_DIR2}"
|
||||
#
|
||||
# Run the test
|
||||
#$ENVCMD $TEST_BIN
|
||||
@ -103,11 +103,11 @@ if test $nerrors -ne 0 ; then
|
||||
echo "$nerrors errors encountered"
|
||||
exit_code=$EXIT_FAILURE
|
||||
else
|
||||
echo "All Plugin API tests passed."
|
||||
echo "All filter plugin tests passed."
|
||||
exit_code=$EXIT_SUCCESS
|
||||
fi
|
||||
|
||||
# Clean up temporary files/directories and leave
|
||||
$RM $PLUGIN_LIBDIR1 $PLUGIN_LIBDIR2
|
||||
$RM $PLUGIN_DIR1 $PLUGIN_DIR2
|
||||
|
||||
exit $exit_code
|
@ -53,7 +53,7 @@ HDF5-DIAG: Error detected in HDF5 (version (number)) thread (IDs):
|
||||
#004: (file name) line (number) in H5Z_pipeline(): required filter 'bogus' is not registered
|
||||
major: Data filters
|
||||
minor: Read failed
|
||||
#005: (file name) line (number) in H5PL_load(): required dynamically loaded plugin filter '305' is not available
|
||||
#005: (file name) line (number) in H5PL_load(): filter plugins disabled
|
||||
major: Plugin for dynamically loaded library
|
||||
minor: Unable to load metadata into cache
|
||||
|
||||
|
209
test/testhdf5.h
209
test/testhdf5.h
@ -30,130 +30,147 @@
|
||||
|
||||
/* Use %ld to print the value because long should cover most cases. */
|
||||
/* Used to make certain a return value _is_not_ a value */
|
||||
#define CHECK(ret, val, where) do { \
|
||||
if (VERBOSE_HI) print_func(" Call to routine: %15s at line %4d " \
|
||||
"in %s returned %ld \n", \
|
||||
where, (int)__LINE__, __FILE__, \
|
||||
(long)(ret)); \
|
||||
if ((ret) == (val)) { \
|
||||
TestErrPrintf("*** UNEXPECTED RETURN from %s is %ld at line %4d " \
|
||||
"in %s\n", where, (long)(ret), (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
#define CHECK(ret, val, where) do { \
|
||||
if (VERBOSE_HI) { \
|
||||
print_func(" Call to routine: %15s at line %4d " \
|
||||
"in %s returned %ld \n", \
|
||||
where, (int)__LINE__, __FILE__, \
|
||||
(long)(ret)); \
|
||||
} \
|
||||
if ((ret) == (val)) { \
|
||||
TestErrPrintf("*** UNEXPECTED RETURN from %s is %ld at line %4d " \
|
||||
"in %s\n", where, (long)(ret), (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
#define CHECK_I(ret,where) { \
|
||||
if (VERBOSE_HI) { \
|
||||
print_func(" Call to routine: %15s at line %4d in %s returned %ld\n", \
|
||||
(where), (int)__LINE__, __FILE__, (long)(ret)); \
|
||||
} \
|
||||
if ((ret)<0) { \
|
||||
TestErrPrintf ("*** UNEXPECTED RETURN from %s is %ld line %4d in %s\n", \
|
||||
(where), (long)(ret), (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
#define CHECK_I(ret,where) { \
|
||||
if (VERBOSE_HI) { \
|
||||
print_func(" Call to routine: %15s at line %4d in %s returned %ld\n", \
|
||||
(where), (int)__LINE__, __FILE__, (long)(ret)); \
|
||||
} \
|
||||
if ((ret)<0) { \
|
||||
TestErrPrintf ("*** UNEXPECTED RETURN from %s is %ld line %4d in %s\n", \
|
||||
(where), (long)(ret), (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define CHECK_PTR(ret,where) { \
|
||||
if (VERBOSE_HI) { \
|
||||
print_func(" Call to routine: %15s at line %4d in %s returned %p\n", \
|
||||
(where), (int)__LINE__, __FILE__, (ret)); \
|
||||
} \
|
||||
if (!(ret)) { \
|
||||
TestErrPrintf ("*** UNEXPECTED RETURN from %s is NULL line %4d in %s\n", \
|
||||
(where), (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
/* Check that a pointer is valid (i.e.: not NULL) */
|
||||
#define CHECK_PTR(ret,where) { \
|
||||
if (VERBOSE_HI) { \
|
||||
print_func(" Call to routine: %15s at line %4d in %s returned %p\n", \
|
||||
(where), (int)__LINE__, __FILE__, (ret)); \
|
||||
} \
|
||||
if (!(ret)) { \
|
||||
TestErrPrintf ("*** UNEXPECTED RETURN from %s is NULL line %4d in %s\n", \
|
||||
(where), (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
}
|
||||
|
||||
#define CHECK_PTR_NULL(ret,where) { \
|
||||
if (VERBOSE_HI) { \
|
||||
print_func(" Call to routine: %15s at line %4d in %s returned %p\n", \
|
||||
(where), (int)__LINE__, __FILE__, (ret)); \
|
||||
} \
|
||||
if (ret) { \
|
||||
TestErrPrintf ("*** UNEXPECTED RETURN from %s is not NULL line %4d in %s\n", \
|
||||
(where), (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
/* Check that a pointer is NULL */
|
||||
#define CHECK_PTR_NULL(ret,where) { \
|
||||
if (VERBOSE_HI) { \
|
||||
print_func(" Call to routine: %15s at line %4d in %s returned %p\n", \
|
||||
(where), (int)__LINE__, __FILE__, (ret)); \
|
||||
} \
|
||||
if (ret) { \
|
||||
TestErrPrintf ("*** UNEXPECTED RETURN from %s is not NULL line %4d in %s\n", \
|
||||
(where), (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
}
|
||||
|
||||
/* Check that two pointers are equal */
|
||||
#define CHECK_PTR_EQ(ret, val, where) { \
|
||||
if (VERBOSE_HI) { \
|
||||
print_func(" Call to routine: %15s at line %4d in %s returned %p\n", \
|
||||
(where), (int)__LINE__, __FILE__, (const void *)(ret)); \
|
||||
} \
|
||||
if (ret != val) { \
|
||||
TestErrPrintf ("*** UNEXPECTED RETURN from %s: returned value of %p is not equal to %p line %4d in %s\n", \
|
||||
(where), (const void *)(ret), (const void *)(val), (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
}
|
||||
|
||||
/* Used to make certain a return value _is_ a value */
|
||||
#define VERIFY(_x, _val, where) do { \
|
||||
long __x = (long)_x, __val = (long)_val; \
|
||||
if(VERBOSE_HI) { \
|
||||
print_func(" Call to routine: %15s at line %4d in %s had value " \
|
||||
"%ld \n", (where), (int)__LINE__, __FILE__, __x); \
|
||||
} \
|
||||
if((__x) != (__val)) { \
|
||||
TestErrPrintf("*** UNEXPECTED VALUE from %s should be %ld, but is %ld at line %4d " \
|
||||
"in %s\n", (where), __val, __x, (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
#define VERIFY(_x, _val, where) do { \
|
||||
long __x = (long)_x, __val = (long)_val; \
|
||||
if(VERBOSE_HI) { \
|
||||
print_func(" Call to routine: %15s at line %4d in %s had value " \
|
||||
"%ld \n", (where), (int)__LINE__, __FILE__, __x); \
|
||||
} \
|
||||
if((__x) != (__val)) { \
|
||||
TestErrPrintf("*** UNEXPECTED VALUE from %s should be %ld, but is %ld at line %4d " \
|
||||
"in %s\n", (where), __val, __x, (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
/* Used to make certain a (non-'long' type's) return value _is_ a value */
|
||||
#define VERIFY_TYPE(_x, _val, _type, _format, where) do { \
|
||||
_type __x = (_type)_x, __val = (_type)_val; \
|
||||
if(VERBOSE_HI) { \
|
||||
print_func(" Call to routine: %15s at line %4d in %s had value " \
|
||||
_format " \n", (where), (int)__LINE__, __FILE__, __x); \
|
||||
} \
|
||||
if((__x) != (__val)) { \
|
||||
TestErrPrintf("*** UNEXPECTED VALUE from %s should be " _format ", but is " _format " at line %4d " \
|
||||
"in %s\n", (where), __val, __x, (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
#define VERIFY_TYPE(_x, _val, _type, _format, where) do { \
|
||||
_type __x = (_type)_x, __val = (_type)_val; \
|
||||
if(VERBOSE_HI) { \
|
||||
print_func(" Call to routine: %15s at line %4d in %s had value " \
|
||||
_format " \n", (where), (int)__LINE__, __FILE__, __x); \
|
||||
} \
|
||||
if((__x) != (__val)) { \
|
||||
TestErrPrintf("*** UNEXPECTED VALUE from %s should be " _format ", but is " _format " at line %4d " \
|
||||
"in %s\n", (where), __val, __x, (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
/* Used to make certain a string return value _is_ a value */
|
||||
#define VERIFY_STR(x, val, where) do { \
|
||||
if (VERBOSE_HI) { \
|
||||
print_func(" Call to routine: %15s at line %4d in %s had value " \
|
||||
"%s \n", (where), (int)__LINE__, __FILE__, x); \
|
||||
} \
|
||||
if (HDstrcmp(x, val)) { \
|
||||
TestErrPrintf("*** UNEXPECTED VALUE from %s should be %s, but is %s at line %4d " \
|
||||
"in %s\n", where, val, x, (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
#define VERIFY_STR(x, val, where) do { \
|
||||
if (VERBOSE_HI) { \
|
||||
print_func(" Call to routine: %15s at line %4d in %s had value " \
|
||||
"%s \n", (where), (int)__LINE__, __FILE__, x); \
|
||||
} \
|
||||
if (HDstrcmp(x, val)) { \
|
||||
TestErrPrintf("*** UNEXPECTED VALUE from %s should be %s, but is %s at line %4d " \
|
||||
"in %s\n", where, val, x, (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
/* Used to document process through a test and to check for errors */
|
||||
#define RESULT(ret,func) do { \
|
||||
if (VERBOSE_MED) { \
|
||||
print_func(" Call to routine: %15s at line %4d in %s returned " \
|
||||
"%ld\n", func, (int)__LINE__, __FILE__, (long)(ret)); \
|
||||
} \
|
||||
if (VERBOSE_HI) \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
if ((ret) == FAIL) { \
|
||||
TestErrPrintf("*** UNEXPECTED RETURN from %s is %ld at line %4d " \
|
||||
"in %s\n", func, (long)(ret), (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
#define RESULT(ret,func) do { \
|
||||
if (VERBOSE_MED) { \
|
||||
print_func(" Call to routine: %15s at line %4d in %s returned " \
|
||||
"%ld\n", func, (int)__LINE__, __FILE__, (long)(ret)); \
|
||||
} \
|
||||
if (VERBOSE_HI) \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
if ((ret) == FAIL) { \
|
||||
TestErrPrintf("*** UNEXPECTED RETURN from %s is %ld at line %4d " \
|
||||
"in %s\n", func, (long)(ret), (int)__LINE__, __FILE__); \
|
||||
H5Eprint2(H5E_DEFAULT, stdout); \
|
||||
} \
|
||||
} while(0)
|
||||
|
||||
/* Used to document process through a test */
|
||||
#if defined(H5_HAVE_PARALLEL) && defined(H5_PARALLEL_TEST)
|
||||
#define MESSAGE(V,A) { \
|
||||
int mpi_rank; \
|
||||
\
|
||||
MPI_Comm_rank(MPI_COMM_WORLD, &mpi_rank); \
|
||||
if(mpi_rank == 0 && HDGetTestVerbosity() > (V)) \
|
||||
print_func A ; \
|
||||
#define MESSAGE(V,A) { \
|
||||
int mpi_rank; \
|
||||
\
|
||||
MPI_Comm_rank(MPI_COMM_WORLD, &mpi_rank); \
|
||||
if(mpi_rank == 0 && HDGetTestVerbosity() > (V)) \
|
||||
print_func A ; \
|
||||
}
|
||||
#else /* H5_HAVE_PARALLEL */
|
||||
#define MESSAGE(V,A) {if (HDGetTestVerbosity() > (V)) print_func A;}
|
||||
#endif /* H5_HAVE_PARALLEL */
|
||||
|
||||
/* Used to indicate an error that is complex to check for */
|
||||
#define ERROR(where) do { \
|
||||
if(VERBOSE_HI) \
|
||||
print_func(" Call to routine: %15s at line %4d in %s returned " \
|
||||
"invalid result\n", where, (int)__LINE__, __FILE__); \
|
||||
TestErrPrintf("*** UNEXPECTED RESULT from %s at line %4d in %s\n", \
|
||||
where, (int)__LINE__, __FILE__); \
|
||||
#define ERROR(where) do { \
|
||||
if(VERBOSE_HI) \
|
||||
print_func(" Call to routine: %15s at line %4d in %s returned " \
|
||||
"invalid result\n", where, (int)__LINE__, __FILE__); \
|
||||
TestErrPrintf("*** UNEXPECTED RESULT from %s at line %4d in %s\n", \
|
||||
where, (int)__LINE__, __FILE__); \
|
||||
} while(0)
|
||||
|
||||
/* definitions for command strings */
|
||||
|
@ -1072,7 +1072,7 @@ test_get_obj_ids(void)
|
||||
VERIFY(oid_count, (NGROUPS + NDSETS + 1), "H5Fget_obj_count");
|
||||
|
||||
oid_list = (hid_t *)HDcalloc((size_t)oid_list_size, sizeof(hid_t));
|
||||
CHECK(oid_list, NULL, "HDcalloc");
|
||||
CHECK_PTR(oid_list, "HDcalloc");
|
||||
|
||||
/* Call the public function H5F_get_obj_ids to use H5F_get_objects. User reported having problem here.
|
||||
* that the returned size (ret_count) from H5Fget_obj_ids is one greater than the size passed in
|
||||
@ -1135,7 +1135,7 @@ test_get_obj_ids(void)
|
||||
VERIFY(oid_count, NDSETS, "H5Fget_obj_count");
|
||||
|
||||
oid_list = (hid_t *)HDcalloc((size_t)oid_count, sizeof(hid_t));
|
||||
CHECK(oid_list, NULL, "HDcalloc");
|
||||
CHECK_PTR(oid_list, "HDcalloc");
|
||||
|
||||
/* Get the list of all opened objects */
|
||||
ret_count = H5Fget_obj_ids((hid_t)H5F_OBJ_ALL, H5F_OBJ_ALL, (size_t)oid_count, oid_list);
|
||||
@ -2667,7 +2667,7 @@ cal_chksum(const char *file, uint32_t *chksum)
|
||||
|
||||
/* Allocate space for the file data */
|
||||
file_data = HDmalloc((size_t)sb.st_size);
|
||||
CHECK(file_data, NULL, "HDmalloc");
|
||||
CHECK_PTR(file_data, "HDmalloc");
|
||||
|
||||
if(file_data) {
|
||||
/* Read file's data into memory */
|
||||
|
@ -783,9 +783,9 @@ test_h5o_link(void)
|
||||
/* Allocate memory buffers */
|
||||
/* (These are treated as 2-D buffers) */
|
||||
wdata = (int *)HDmalloc((size_t)(TEST6_DIM1 * TEST6_DIM2) * sizeof(int));
|
||||
CHECK(wdata, NULL, "HDmalloc");
|
||||
CHECK_PTR(wdata, "HDmalloc");
|
||||
rdata = (int *)HDmalloc((size_t)(TEST6_DIM1 * TEST6_DIM2) * sizeof(int));
|
||||
CHECK(rdata, NULL, "HDmalloc");
|
||||
CHECK_PTR(rdata, "HDmalloc");
|
||||
|
||||
/* Initialize the raw data */
|
||||
for(i = n = 0; i < (TEST6_DIM1 * TEST6_DIM2); i++)
|
||||
|
42
test/theap.c
42
test/theap.c
@ -88,11 +88,11 @@ test_heap_init(void)
|
||||
|
||||
/* Allocate arrays */
|
||||
rand_num = (test_obj *)HDmalloc(sizeof(test_obj) * NUM_ELEMS);
|
||||
CHECK(rand_num, NULL, "HDmalloc");
|
||||
CHECK_PTR(rand_num, "HDmalloc");
|
||||
inc_sort_num = (test_obj *)HDmalloc(sizeof(test_obj) * NUM_ELEMS);
|
||||
CHECK(inc_sort_num, NULL, "HDmalloc");
|
||||
CHECK_PTR(inc_sort_num, "HDmalloc");
|
||||
dec_sort_num = (test_obj *)HDmalloc(sizeof(test_obj) * NUM_ELEMS);
|
||||
CHECK(dec_sort_num, NULL, "HDmalloc");
|
||||
CHECK_PTR(dec_sort_num, "HDmalloc");
|
||||
|
||||
/* Create randomized set of numbers */
|
||||
curr_time = HDtime(NULL);
|
||||
@ -127,7 +127,7 @@ test_heap_create(void)
|
||||
|
||||
/* Try creating a maximum Heap */
|
||||
heap=H5HP_create(H5HP_MAX_HEAP);
|
||||
CHECK(heap, NULL, "H5HP_create");
|
||||
CHECK_PTR(heap, "H5HP_create");
|
||||
|
||||
/* Try closing the heap */
|
||||
ret=H5HP_close(heap);
|
||||
@ -135,7 +135,7 @@ test_heap_create(void)
|
||||
|
||||
/* Try creating a minimum Heap */
|
||||
heap=H5HP_create(H5HP_MIN_HEAP);
|
||||
CHECK(heap, NULL, "H5HP_create");
|
||||
CHECK_PTR(heap, "H5HP_create");
|
||||
|
||||
/* Try closing the heap */
|
||||
ret=H5HP_close(heap);
|
||||
@ -163,7 +163,7 @@ test_heap_insert_min(void)
|
||||
|
||||
/* Create a Heap */
|
||||
heap=H5HP_create(H5HP_MIN_HEAP);
|
||||
CHECK(heap, NULL, "H5HP_create");
|
||||
CHECK_PTR(heap, "H5HP_create");
|
||||
|
||||
/* Check that the heap has no elements */
|
||||
num=H5HP_count(heap);
|
||||
@ -237,7 +237,7 @@ test_heap_insert_max(void)
|
||||
|
||||
/* Create a Heap */
|
||||
heap=H5HP_create(H5HP_MAX_HEAP);
|
||||
CHECK(heap, NULL, "H5HP_create");
|
||||
CHECK_PTR(heap, "H5HP_create");
|
||||
|
||||
/* Check that the heap has no elements */
|
||||
num=H5HP_count(heap);
|
||||
@ -325,7 +325,7 @@ test_heap_insert_many_core(H5HP_type_t heap_type, test_obj *arr, size_t nelem, i
|
||||
|
||||
/* Create a Heap */
|
||||
heap=H5HP_create(heap_type);
|
||||
CHECK(heap, NULL, "H5HP_create");
|
||||
CHECK_PTR(heap, "H5HP_create");
|
||||
|
||||
/* Check that the heap has no elements */
|
||||
num=H5HP_count(heap);
|
||||
@ -405,7 +405,7 @@ test_heap_remove_min(void)
|
||||
|
||||
/* Create a Heap */
|
||||
heap=H5HP_create(H5HP_MIN_HEAP);
|
||||
CHECK(heap, NULL, "H5HP_create");
|
||||
CHECK_PTR(heap, "H5HP_create");
|
||||
|
||||
/* Check that the heap has no elements */
|
||||
num=H5HP_count(heap);
|
||||
@ -434,19 +434,19 @@ test_heap_remove_min(void)
|
||||
ret=H5HP_remove(heap,&val,&ptr);
|
||||
CHECK(ret, FAIL, "H5HP_remove");
|
||||
VERIFY(val, 5, "H5HP_remove");
|
||||
VERIFY(ptr, &obj2, "H5HP_remove");
|
||||
CHECK_PTR_EQ(ptr, &obj2, "H5HP_remove");
|
||||
|
||||
/* Remove second maximum value from heap */
|
||||
ret=H5HP_remove(heap,&val,&ptr);
|
||||
CHECK(ret, FAIL, "H5HP_remove");
|
||||
VERIFY(val, 10, "H5HP_remove");
|
||||
VERIFY(ptr, &obj1, "H5HP_remove");
|
||||
CHECK_PTR_EQ(ptr, &obj1, "H5HP_remove");
|
||||
|
||||
/* Remove third maximum value from heap */
|
||||
ret=H5HP_remove(heap,&val,&ptr);
|
||||
CHECK(ret, FAIL, "H5HP_remove");
|
||||
VERIFY(val, 20, "H5HP_remove");
|
||||
VERIFY(ptr, &obj3, "H5HP_remove");
|
||||
CHECK_PTR_EQ(ptr, &obj3, "H5HP_remove");
|
||||
|
||||
/* Try removing an object from an empty heap */
|
||||
ret=H5HP_remove(heap,&val,&ptr);
|
||||
@ -479,7 +479,7 @@ test_heap_remove_max(void)
|
||||
|
||||
/* Create a Heap */
|
||||
heap=H5HP_create(H5HP_MAX_HEAP);
|
||||
CHECK(heap, NULL, "H5HP_create");
|
||||
CHECK_PTR(heap, "H5HP_create");
|
||||
|
||||
/* Check that the heap has no elements */
|
||||
num=H5HP_count(heap);
|
||||
@ -508,19 +508,19 @@ test_heap_remove_max(void)
|
||||
ret=H5HP_remove(heap,&val,&ptr);
|
||||
CHECK(ret, FAIL, "H5HP_remove");
|
||||
VERIFY(val, 20, "H5HP_remove");
|
||||
VERIFY(ptr, &obj3, "H5HP_remove");
|
||||
CHECK_PTR_EQ(ptr, &obj3, "H5HP_remove");
|
||||
|
||||
/* Remove second maximum value from heap */
|
||||
ret=H5HP_remove(heap,&val,&ptr);
|
||||
CHECK(ret, FAIL, "H5HP_remove");
|
||||
VERIFY(val, 10, "H5HP_remove");
|
||||
VERIFY(ptr, &obj1, "H5HP_remove");
|
||||
CHECK_PTR_EQ(ptr, &obj1, "H5HP_remove");
|
||||
|
||||
/* Remove third maximum value from heap */
|
||||
ret=H5HP_remove(heap,&val,&ptr);
|
||||
CHECK(ret, FAIL, "H5HP_remove");
|
||||
VERIFY(val, 5, "H5HP_remove");
|
||||
VERIFY(ptr, &obj2, "H5HP_remove");
|
||||
CHECK_PTR_EQ(ptr, &obj2, "H5HP_remove");
|
||||
|
||||
/* Try removing an object from an empty heap */
|
||||
ret=H5HP_remove(heap,&val,&ptr);
|
||||
@ -567,7 +567,7 @@ static void test_heap_remove_many_core(H5HP_type_t heap_type, test_obj *arr, siz
|
||||
|
||||
/* Create a Heap */
|
||||
heap=H5HP_create(heap_type);
|
||||
CHECK(heap, NULL, "H5HP_create");
|
||||
CHECK_PTR(heap, "H5HP_create");
|
||||
|
||||
/* Check that the heap has no elements */
|
||||
num=H5HP_count(heap);
|
||||
@ -714,7 +714,7 @@ test_heap_change_min(void)
|
||||
|
||||
/* Create a Heap */
|
||||
heap=H5HP_create(H5HP_MIN_HEAP);
|
||||
CHECK(heap, NULL, "H5HP_create");
|
||||
CHECK_PTR(heap, "H5HP_create");
|
||||
|
||||
/* Check that the heap has no elements */
|
||||
num=H5HP_count(heap);
|
||||
@ -788,7 +788,7 @@ test_heap_change_max(void)
|
||||
|
||||
/* Create a Heap */
|
||||
heap=H5HP_create(H5HP_MAX_HEAP);
|
||||
CHECK(heap, NULL, "H5HP_create");
|
||||
CHECK_PTR(heap, "H5HP_create");
|
||||
|
||||
/* Check that the heap has no elements */
|
||||
num=H5HP_count(heap);
|
||||
@ -880,7 +880,7 @@ test_heap_incdec_min(void)
|
||||
|
||||
/* Create a Heap */
|
||||
heap=H5HP_create(H5HP_MIN_HEAP);
|
||||
CHECK(heap, NULL, "H5HP_create");
|
||||
CHECK_PTR(heap, "H5HP_create");
|
||||
|
||||
/* Check that the heap has no elements */
|
||||
num=H5HP_count(heap);
|
||||
@ -955,7 +955,7 @@ test_heap_incdec_max(void)
|
||||
|
||||
/* Create a Heap */
|
||||
heap=H5HP_create(H5HP_MAX_HEAP);
|
||||
CHECK(heap, NULL, "H5HP_create");
|
||||
CHECK_PTR(heap, "H5HP_create");
|
||||
|
||||
/* Check that the heap has no elements */
|
||||
num=H5HP_count(heap);
|
||||
|
346
test/tid.c
346
test/tid.c
@ -16,223 +16,225 @@
|
||||
#include "testhdf5.h"
|
||||
#include "hdf5.h"
|
||||
|
||||
/* Include H5Ipkg.h to calculate max number of groups */
|
||||
/* Include H5Ipkg.h to calculate max number of groups */
|
||||
#define H5I_FRIEND /*suppress error about including H5Ipkg */
|
||||
#include "H5Ipkg.h"
|
||||
|
||||
/* Test basic functionality of registering and deleting types and IDs */
|
||||
/* Test basic functionality of registering and deleting types and IDs */
|
||||
static int basic_id_test(void)
|
||||
{
|
||||
H5I_type_t myType = H5I_BADID;
|
||||
hid_t arrayID = H5I_INVALID_HID;
|
||||
void* testObj = NULL;
|
||||
void* testPtr = NULL;
|
||||
char nameString[10];
|
||||
hid_t testID;
|
||||
ssize_t testSize = -1;
|
||||
herr_t err;
|
||||
int num_ref;
|
||||
hsize_t num_members;
|
||||
H5I_type_t myType = H5I_BADID;
|
||||
hid_t arrayID = H5I_INVALID_HID;
|
||||
void* testObj = NULL;
|
||||
void* testPtr = NULL;
|
||||
char nameString[10];
|
||||
hid_t testID;
|
||||
ssize_t testSize = -1;
|
||||
herr_t err;
|
||||
int num_ref;
|
||||
hsize_t num_members;
|
||||
|
||||
|
||||
/* Try to register an ID with ficticious types */
|
||||
H5E_BEGIN_TRY
|
||||
arrayID = H5Iregister((H5I_type_t) 420, testObj);
|
||||
H5E_END_TRY
|
||||
/* Try to register an ID with ficticious types */
|
||||
H5E_BEGIN_TRY
|
||||
arrayID = H5Iregister((H5I_type_t) 420, testObj);
|
||||
H5E_END_TRY
|
||||
|
||||
VERIFY(arrayID, H5I_INVALID_HID, "H5Iregister");
|
||||
if(arrayID != H5I_INVALID_HID)
|
||||
goto out;
|
||||
VERIFY(arrayID, H5I_INVALID_HID, "H5Iregister");
|
||||
if(arrayID != H5I_INVALID_HID)
|
||||
goto out;
|
||||
|
||||
H5E_BEGIN_TRY
|
||||
arrayID = H5Iregister((H5I_type_t) -1, testObj);
|
||||
H5E_END_TRY
|
||||
H5E_BEGIN_TRY
|
||||
arrayID = H5Iregister((H5I_type_t) -1, testObj);
|
||||
H5E_END_TRY
|
||||
|
||||
VERIFY(arrayID, H5I_INVALID_HID, "H5Iregister");
|
||||
if(arrayID != H5I_INVALID_HID)
|
||||
goto out;
|
||||
VERIFY(arrayID, H5I_INVALID_HID, "H5Iregister");
|
||||
if(arrayID != H5I_INVALID_HID)
|
||||
goto out;
|
||||
|
||||
/* Try to access IDs with ficticious types */
|
||||
H5E_BEGIN_TRY
|
||||
testPtr = H5Iobject_verify((hid_t)100, (H5I_type_t) 0);
|
||||
H5E_END_TRY
|
||||
/* Try to access IDs with ficticious types */
|
||||
H5E_BEGIN_TRY
|
||||
testPtr = H5Iobject_verify((hid_t)100, (H5I_type_t) 0);
|
||||
H5E_END_TRY
|
||||
|
||||
VERIFY(testPtr, NULL, "H5Iobject_verify");
|
||||
if(testPtr != NULL)
|
||||
goto out;
|
||||
CHECK_PTR_NULL(testPtr, "H5Iobject_verify");
|
||||
if(testPtr != NULL)
|
||||
goto out;
|
||||
|
||||
H5E_BEGIN_TRY
|
||||
testPtr = H5Iobject_verify((hid_t)700, (H5I_type_t) 700);
|
||||
H5E_END_TRY
|
||||
H5E_BEGIN_TRY
|
||||
testPtr = H5Iobject_verify((hid_t)700, (H5I_type_t) 700);
|
||||
H5E_END_TRY
|
||||
|
||||
VERIFY(testPtr, NULL, "H5Iobject_verify");
|
||||
if(testPtr != NULL)
|
||||
goto out;
|
||||
CHECK_PTR_NULL(testPtr, "H5Iobject_verify");
|
||||
if(testPtr != NULL)
|
||||
goto out;
|
||||
|
||||
/* Register a type */
|
||||
myType = H5Iregister_type((size_t)64, 0, (H5I_free_t) free );
|
||||
/* Register a type */
|
||||
myType = H5Iregister_type((size_t)64, 0, (H5I_free_t) free );
|
||||
|
||||
CHECK(myType, H5I_BADID, "H5Iregister_type");
|
||||
if(myType == H5I_BADID)
|
||||
goto out;
|
||||
CHECK(myType, H5I_BADID, "H5Iregister_type");
|
||||
if(myType == H5I_BADID)
|
||||
goto out;
|
||||
|
||||
/* Register an ID and retrieve the object it points to.
|
||||
* Once the ID has been registered, testObj will be freed when
|
||||
* its ID type is destroyed. */
|
||||
testObj = HDmalloc(7 * sizeof(int));
|
||||
arrayID = H5Iregister(myType, testObj);
|
||||
/* Register an ID and retrieve the object it points to.
|
||||
* Once the ID has been registered, testObj will be freed when
|
||||
* its ID type is destroyed.
|
||||
*/
|
||||
testObj = HDmalloc(7 * sizeof(int));
|
||||
arrayID = H5Iregister(myType, testObj);
|
||||
|
||||
CHECK(arrayID, H5I_INVALID_HID, "H5Iregister");
|
||||
if(arrayID == H5I_INVALID_HID)
|
||||
{
|
||||
HDfree(testObj);
|
||||
goto out;
|
||||
}
|
||||
CHECK(arrayID, H5I_INVALID_HID, "H5Iregister");
|
||||
if(arrayID == H5I_INVALID_HID) {
|
||||
HDfree(testObj);
|
||||
goto out;
|
||||
}
|
||||
|
||||
testPtr = (int *) H5Iobject_verify(arrayID, myType);
|
||||
testPtr = (int *)H5Iobject_verify(arrayID, myType);
|
||||
|
||||
VERIFY(testPtr, testObj, "H5Iobject_verify");
|
||||
if(testPtr != testObj)
|
||||
goto out;
|
||||
CHECK_PTR_EQ(testPtr, testObj, "H5Iobject_verify");
|
||||
if(testPtr != testObj)
|
||||
goto out;
|
||||
|
||||
/* Ensure that H5Iget_file_id and H5Iget_name() fail, since this
|
||||
* is an hid_t for the wrong kind of object */
|
||||
H5E_BEGIN_TRY
|
||||
testID = H5Iget_file_id(arrayID);
|
||||
H5E_END_TRY
|
||||
/* Ensure that H5Iget_file_id and H5Iget_name() fail, since this
|
||||
* is an hid_t for the wrong kind of object
|
||||
*/
|
||||
H5E_BEGIN_TRY
|
||||
testID = H5Iget_file_id(arrayID);
|
||||
H5E_END_TRY
|
||||
|
||||
VERIFY(testID, H5I_INVALID_HID, "H5Iget_file_id");
|
||||
if(testID != H5I_INVALID_HID)
|
||||
goto out;
|
||||
VERIFY(testID, H5I_INVALID_HID, "H5Iget_file_id");
|
||||
if(testID != H5I_INVALID_HID)
|
||||
goto out;
|
||||
|
||||
H5E_BEGIN_TRY
|
||||
testSize = H5Iget_name(arrayID, nameString, (size_t)9);
|
||||
H5E_END_TRY
|
||||
H5E_BEGIN_TRY
|
||||
testSize = H5Iget_name(arrayID, nameString, (size_t)9);
|
||||
H5E_END_TRY
|
||||
|
||||
VERIFY(testSize, -1, "H5Iget_name");
|
||||
if(testSize != -1)
|
||||
goto out;
|
||||
VERIFY(testSize, -1, "H5Iget_name");
|
||||
if(testSize != -1)
|
||||
goto out;
|
||||
|
||||
/* Make sure H5Iremove_verify catches objects of the wrong type */
|
||||
H5E_BEGIN_TRY
|
||||
testPtr = (int*) H5Iremove_verify(arrayID, (H5I_type_t) 0);
|
||||
H5E_END_TRY
|
||||
/* Make sure H5Iremove_verify catches objects of the wrong type */
|
||||
H5E_BEGIN_TRY
|
||||
testPtr = (int*) H5Iremove_verify(arrayID, (H5I_type_t) 0);
|
||||
H5E_END_TRY
|
||||
|
||||
VERIFY(testPtr, NULL, "H5Iremove_verify");
|
||||
if(testPtr != NULL)
|
||||
goto out;
|
||||
CHECK_PTR_NULL(testPtr, "H5Iremove_verify");
|
||||
if(testPtr != NULL)
|
||||
goto out;
|
||||
|
||||
H5E_BEGIN_TRY
|
||||
testPtr = (int*) H5Iremove_verify(arrayID, (H5I_type_t) ((int) myType-1));
|
||||
H5E_END_TRY
|
||||
H5E_BEGIN_TRY
|
||||
testPtr = (int*) H5Iremove_verify(arrayID, (H5I_type_t) ((int) myType-1));
|
||||
H5E_END_TRY
|
||||
|
||||
VERIFY(testPtr, NULL, "H5Iremove_verify");
|
||||
if(testPtr != NULL)
|
||||
goto out;
|
||||
CHECK_PTR_NULL(testPtr, "H5Iremove_verify");
|
||||
if(testPtr != NULL)
|
||||
goto out;
|
||||
|
||||
/* Remove an ID and make sure we can't access it */
|
||||
testPtr = (int*) H5Iremove_verify(arrayID, myType);
|
||||
/* Remove an ID and make sure we can't access it */
|
||||
testPtr = (int*) H5Iremove_verify(arrayID, myType);
|
||||
|
||||
CHECK(testPtr, NULL, "H5Iremove_verify");
|
||||
if(testPtr == NULL)
|
||||
goto out;
|
||||
CHECK_PTR(testPtr, "H5Iremove_verify");
|
||||
if(testPtr == NULL)
|
||||
goto out;
|
||||
|
||||
H5E_BEGIN_TRY
|
||||
testPtr = (int*) H5Iobject_verify(arrayID, myType);
|
||||
H5E_END_TRY
|
||||
H5E_BEGIN_TRY
|
||||
testPtr = (int*) H5Iobject_verify(arrayID, myType);
|
||||
H5E_END_TRY
|
||||
|
||||
VERIFY(testPtr, NULL, "H5Iobject_verify");
|
||||
if(testPtr != NULL)
|
||||
goto out;
|
||||
CHECK_PTR_NULL(testPtr, "H5Iobject_verify");
|
||||
if(testPtr != NULL)
|
||||
goto out;
|
||||
|
||||
/* Delete the type and make sure we can't access objects within it */
|
||||
arrayID = H5Iregister(myType, testObj);
|
||||
/* Delete the type and make sure we can't access objects within it */
|
||||
arrayID = H5Iregister(myType, testObj);
|
||||
|
||||
err = H5Idestroy_type(myType);
|
||||
VERIFY(err, 0, "H5Idestroy_type");
|
||||
if( err != 0)
|
||||
goto out;
|
||||
VERIFY(H5Itype_exists(myType), 0, "H5Itype_exists");
|
||||
if(H5Itype_exists(myType) != 0)
|
||||
err = H5Idestroy_type(myType);
|
||||
VERIFY(err, 0, "H5Idestroy_type");
|
||||
if( err != 0)
|
||||
goto out;
|
||||
VERIFY(H5Itype_exists(myType), 0, "H5Itype_exists");
|
||||
if(H5Itype_exists(myType) != 0)
|
||||
goto out;
|
||||
|
||||
H5E_BEGIN_TRY
|
||||
VERIFY(H5Inmembers(myType, NULL), -1, "H5Inmembers");
|
||||
if(H5Inmembers(myType, NULL) != -1)
|
||||
goto out;
|
||||
H5E_END_TRY
|
||||
|
||||
H5E_BEGIN_TRY
|
||||
VERIFY(H5Inmembers(myType, NULL), -1, "H5Inmembers");
|
||||
if(H5Inmembers(myType, NULL) != -1)
|
||||
goto out;
|
||||
H5E_END_TRY
|
||||
/* Register another type and another object in that type */
|
||||
myType = H5Iregister_type((size_t)64, 0, (H5I_free_t) free );
|
||||
|
||||
/* Register another type and another object in that type */
|
||||
myType = H5Iregister_type((size_t)64, 0, (H5I_free_t) free );
|
||||
CHECK(myType, H5I_BADID, "H5Iregister_type");
|
||||
if(myType == H5I_BADID)
|
||||
goto out;
|
||||
|
||||
CHECK(myType, H5I_BADID, "H5Iregister_type");
|
||||
if(myType == H5I_BADID)
|
||||
goto out;
|
||||
/* The memory that testObj pointed to should already have been
|
||||
* freed when the previous type was destroyed. Allocate new
|
||||
* memory for it.
|
||||
*/
|
||||
testObj = HDmalloc(7 * sizeof(int));
|
||||
arrayID = H5Iregister(myType, testObj);
|
||||
|
||||
/* The memory that testObj pointed to should already have been
|
||||
* freed when the previous type was destroyed. Allocate new
|
||||
* memory for it.
|
||||
*/
|
||||
testObj = HDmalloc(7 * sizeof(int));
|
||||
arrayID = H5Iregister(myType, testObj);
|
||||
CHECK(arrayID, H5I_INVALID_HID, "H5Iregister");
|
||||
if(arrayID == H5I_INVALID_HID) {
|
||||
HDfree(testObj);
|
||||
goto out;
|
||||
}
|
||||
|
||||
CHECK(arrayID, H5I_INVALID_HID, "H5Iregister");
|
||||
if(arrayID == H5I_INVALID_HID)
|
||||
{
|
||||
HDfree(testObj);
|
||||
goto out;
|
||||
}
|
||||
err = H5Inmembers(myType, &num_members);
|
||||
CHECK(err, -1, "H5Inmembers");
|
||||
if (err < 0)
|
||||
goto out;
|
||||
VERIFY(num_members, 1, "H5Inmembers");
|
||||
if(num_members != 1)
|
||||
goto out;
|
||||
|
||||
err = H5Inmembers(myType, &num_members);
|
||||
CHECK(err, -1, "H5Inmembers");
|
||||
if (err < 0)
|
||||
goto out;
|
||||
VERIFY(num_members, 1, "H5Inmembers");
|
||||
if(num_members != 1)
|
||||
goto out;
|
||||
/* Increment references to type and ensure that dec_type_ref
|
||||
* doesn't destroy the type
|
||||
*/
|
||||
num_ref = H5Iinc_type_ref(myType);
|
||||
VERIFY(num_ref, 2, "H5Iinc_type_ref");
|
||||
if( num_ref != 2)
|
||||
goto out;
|
||||
num_ref = H5Idec_type_ref(myType);
|
||||
VERIFY(num_ref, 1, "H5Idec_type_ref");
|
||||
if(num_ref != 1)
|
||||
goto out;
|
||||
err = H5Inmembers(myType, &num_members);
|
||||
CHECK(err, -1, "H5Inmembers");
|
||||
if (err < 0)
|
||||
goto out;
|
||||
VERIFY(num_members, 1, "H5Inmembers");
|
||||
if(num_members != 1)
|
||||
goto out;
|
||||
|
||||
/* Increment references to type and ensure that dec_type_ref
|
||||
doesn't destroy the type */
|
||||
num_ref = H5Iinc_type_ref(myType);
|
||||
VERIFY(num_ref, 2, "H5Iinc_type_ref");
|
||||
if( num_ref != 2)
|
||||
goto out;
|
||||
num_ref = H5Idec_type_ref(myType);
|
||||
VERIFY(num_ref, 1, "H5Idec_type_ref");
|
||||
if(num_ref != 1)
|
||||
goto out;
|
||||
/* This call to dec_type_ref should destroy the type */
|
||||
num_ref = H5Idec_type_ref(myType);
|
||||
VERIFY(num_ref, 0, "H5Idec_type_ref");
|
||||
if(num_ref != 0)
|
||||
goto out;
|
||||
VERIFY(H5Itype_exists(myType), 0, "H5Itype_exists");
|
||||
if (H5Itype_exists(myType) != 0)
|
||||
goto out;
|
||||
|
||||
H5E_BEGIN_TRY
|
||||
err = H5Inmembers(myType, &num_members);
|
||||
CHECK(err, -1, "H5Inmembers");
|
||||
if (err < 0)
|
||||
if(err >= 0)
|
||||
goto out;
|
||||
VERIFY(num_members, 1, "H5Inmembers");
|
||||
if(num_members != 1)
|
||||
goto out;
|
||||
H5E_END_TRY
|
||||
|
||||
/* This call to dec_type_ref should destroy the type */
|
||||
num_ref = H5Idec_type_ref(myType);
|
||||
VERIFY(num_ref, 0, "H5Idec_type_ref");
|
||||
if(num_ref != 0)
|
||||
goto out;
|
||||
VERIFY(H5Itype_exists(myType), 0, "H5Itype_exists");
|
||||
if (H5Itype_exists(myType) != 0)
|
||||
goto out;
|
||||
|
||||
H5E_BEGIN_TRY
|
||||
err = H5Inmembers(myType, &num_members);
|
||||
if(err >= 0)
|
||||
goto out;
|
||||
H5E_END_TRY
|
||||
|
||||
return 0;
|
||||
return 0;
|
||||
|
||||
out:
|
||||
/* Clean up type if it has been allocated and free memory used
|
||||
* by testObj */
|
||||
if(myType >= 0)
|
||||
H5Idestroy_type(myType);
|
||||
/* Clean up type if it has been allocated and free memory used
|
||||
* by testObj
|
||||
*/
|
||||
if(myType >= 0)
|
||||
H5Idestroy_type(myType);
|
||||
|
||||
return -1;
|
||||
return -1;
|
||||
}
|
||||
|
||||
|
||||
@ -263,7 +265,7 @@ static int id_predefined_test(void )
|
||||
testPtr = H5Isearch(H5I_GENPROP_LST, (H5I_search_func_t) test_search_func, testObj);
|
||||
H5E_END_TRY
|
||||
|
||||
VERIFY(testPtr, NULL, "H5Isearch");
|
||||
CHECK_PTR_NULL(testPtr, "H5Isearch");
|
||||
if(testPtr != NULL)
|
||||
goto out;
|
||||
|
||||
@ -301,7 +303,7 @@ static int id_predefined_test(void )
|
||||
testPtr = H5Iremove_verify(typeID, H5I_DATATYPE);
|
||||
H5E_END_TRY
|
||||
|
||||
VERIFY(testPtr, NULL, "H5Iremove_verify");
|
||||
CHECK_PTR_NULL(testPtr, "H5Iremove_verify");
|
||||
if(testPtr != NULL)
|
||||
goto out;
|
||||
|
||||
@ -309,7 +311,7 @@ static int id_predefined_test(void )
|
||||
testPtr = H5Iobject_verify(typeID, H5I_DATATYPE);
|
||||
H5E_END_TRY
|
||||
|
||||
VERIFY(testPtr, NULL, "H5Iobject_verify");
|
||||
CHECK_PTR_NULL(testPtr, "H5Iobject_verify");
|
||||
if(testPtr != NULL)
|
||||
goto out;
|
||||
|
||||
|
@ -159,7 +159,7 @@ test_iter_group(hid_t fapl, hbool_t new_format)
|
||||
|
||||
/* Keep a copy of the dataset names around for later */
|
||||
lnames[i] = HDstrdup(name);
|
||||
CHECK(lnames[i], NULL, "strdup");
|
||||
CHECK_PTR(lnames[i], "strdup");
|
||||
|
||||
ret = H5Dclose(dataset);
|
||||
CHECK(ret, FAIL, "H5Dclose");
|
||||
@ -170,13 +170,13 @@ test_iter_group(hid_t fapl, hbool_t new_format)
|
||||
CHECK(ret, FAIL, "H5Gcreate2");
|
||||
|
||||
lnames[NDATASETS] = HDstrdup("grp");
|
||||
CHECK(lnames[NDATASETS], NULL, "strdup");
|
||||
CHECK_PTR(lnames[NDATASETS], "strdup");
|
||||
|
||||
ret = H5Tcommit2(file, "dtype", datatype, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT);
|
||||
CHECK(ret, FAIL, "H5Tcommit2");
|
||||
|
||||
lnames[NDATASETS + 1] = HDstrdup("dtype");
|
||||
CHECK(lnames[NDATASETS], NULL, "strdup");
|
||||
CHECK_PTR(lnames[NDATASETS], "strdup");
|
||||
|
||||
/* Close everything up */
|
||||
ret = H5Tclose(datatype);
|
||||
@ -412,7 +412,7 @@ static void test_iter_attr(hid_t fapl, hbool_t new_format)
|
||||
|
||||
/* Keep a copy of the attribute names around for later */
|
||||
anames[i] = HDstrdup(name);
|
||||
CHECK(anames[i], NULL, "strdup");
|
||||
CHECK_PTR(anames[i], "strdup");
|
||||
|
||||
ret = H5Aclose(attribute);
|
||||
CHECK(ret, FAIL, "H5Aclose");
|
||||
@ -596,7 +596,7 @@ test_iter_group_large(hid_t fapl)
|
||||
|
||||
/* Allocate & initialize array */
|
||||
names = (iter_info *)HDcalloc(sizeof(iter_info), (ITER_NGROUPS + 2));
|
||||
CHECK(names, NULL, "HDcalloc");
|
||||
CHECK_PTR(names, "HDcalloc");
|
||||
|
||||
/* Output message about test being performed */
|
||||
MESSAGE(5, ("Testing Large Group Iteration Functionality\n"));
|
||||
@ -733,7 +733,7 @@ static void test_grp_memb_funcs(hid_t fapl)
|
||||
|
||||
/* Keep a copy of the dataset names around for later */
|
||||
dnames[i] = HDstrdup(name);
|
||||
CHECK(dnames[i], NULL, "strdup");
|
||||
CHECK_PTR(dnames[i], "strdup");
|
||||
|
||||
ret = H5Dclose(dataset);
|
||||
CHECK(ret, FAIL, "H5Dclose");
|
||||
@ -744,13 +744,13 @@ static void test_grp_memb_funcs(hid_t fapl)
|
||||
CHECK(ret, FAIL, "H5Gcreate2");
|
||||
|
||||
dnames[NDATASETS] = HDstrdup("grp");
|
||||
CHECK(dnames[NDATASETS], NULL, "strdup");
|
||||
CHECK_PTR(dnames[NDATASETS], "strdup");
|
||||
|
||||
ret = H5Tcommit2(file, "dtype", datatype, H5P_DEFAULT, H5P_DEFAULT, H5P_DEFAULT);
|
||||
CHECK(ret, FAIL, "H5Tcommit2");
|
||||
|
||||
dnames[NDATASETS + 1] = HDstrdup("dtype");
|
||||
CHECK(dnames[NDATASETS], NULL, "strdup");
|
||||
CHECK_PTR(dnames[NDATASETS], "strdup");
|
||||
|
||||
/* Close everything up */
|
||||
ret = H5Tclose(datatype);
|
||||
@ -797,7 +797,7 @@ static void test_grp_memb_funcs(hid_t fapl)
|
||||
|
||||
/* Keep a copy of the dataset names around for later */
|
||||
obj_names[i] = HDstrdup(dataset_name);
|
||||
CHECK(obj_names[i], NULL, "strdup");
|
||||
CHECK_PTR(obj_names[i], "strdup");
|
||||
|
||||
ret = H5Oget_info_by_idx(root_group, ".", H5_INDEX_NAME, H5_ITER_INC, (hsize_t)i, &oinfo, H5P_DEFAULT);
|
||||
CHECK(ret, FAIL, "H5Oget_info_by_idx");
|
||||
|
98
test/tmisc.c
98
test/tmisc.c
@ -30,6 +30,7 @@
|
||||
#include "testhdf5.h"
|
||||
#include "H5srcdir.h"
|
||||
#include "H5Dpkg.h" /* Datasets */
|
||||
#include "H5MMprivate.h" /* Memory */
|
||||
|
||||
/* Definitions for misc. test #1 */
|
||||
#define MISC1_FILE "tmisc1.h5"
|
||||
@ -722,7 +723,7 @@ create_struct3(void)
|
||||
herr_t ret; /* For error checking */
|
||||
|
||||
str3hndl = (misc5_struct3_hndl *)HDmalloc(sizeof(misc5_struct3_hndl));
|
||||
CHECK(str3hndl,NULL,"malloc");
|
||||
CHECK_PTR(str3hndl, "malloc");
|
||||
|
||||
str3hndl->st3h_base = H5Tcreate(H5T_COMPOUND, sizeof(misc5_struct3));
|
||||
CHECK(str3hndl->st3h_base, FAIL, "H5Tcreate");
|
||||
@ -765,7 +766,7 @@ create_struct2(void)
|
||||
herr_t ret; /* For error checking */
|
||||
|
||||
str2hndl = (misc5_struct2_hndl *)HDmalloc(sizeof(misc5_struct2_hndl));
|
||||
CHECK(str2hndl, NULL, "malloc");
|
||||
CHECK_PTR(str2hndl, "HDmalloc");
|
||||
|
||||
str2hndl->st2h_base = H5Tcreate(H5T_COMPOUND, sizeof(misc5_struct2));
|
||||
CHECK(str2hndl->st2h_base, FAIL, "H5Tcreate");
|
||||
@ -774,7 +775,7 @@ create_struct2(void)
|
||||
CHECK(ret, FAIL, "H5Tinsert");
|
||||
|
||||
str2hndl->st2h_st3hndl = create_struct3();
|
||||
CHECK(str2hndl->st2h_st3hndl,NULL,"create_struct3");
|
||||
CHECK_PTR(str2hndl->st2h_st3hndl, "create_struct3");
|
||||
|
||||
ret = H5Tinsert(str2hndl->st2h_base, "st2_el2", HOFFSET(misc5_struct2, st2_el2), str2hndl->st2h_st3hndl->st3h_id);
|
||||
CHECK(ret,FAIL,"H5Tinsert");
|
||||
@ -810,7 +811,7 @@ set_struct2(misc5_struct2 *buf)
|
||||
buf->st2_el2.len = MISC5_DBGNELM3;
|
||||
|
||||
buf->st2_el2.p = HDmalloc((buf->st2_el2.len)*sizeof(misc5_struct3));
|
||||
CHECK(buf->st2_el2.p,NULL,"malloc");
|
||||
CHECK_PTR(buf->st2_el2.p, "HDmalloc");
|
||||
|
||||
for(i=0; i<(buf->st2_el2.len); i++)
|
||||
set_struct3(&(((misc5_struct3 *)(buf->st2_el2.p))[i]));
|
||||
@ -831,7 +832,7 @@ create_struct1(void)
|
||||
herr_t ret; /* For error checking */
|
||||
|
||||
str1hndl = (misc5_struct1_hndl *)HDmalloc(sizeof(misc5_struct1_hndl));
|
||||
CHECK(str1hndl, NULL, "malloc");
|
||||
CHECK_PTR(str1hndl, "HDmalloc");
|
||||
|
||||
str1hndl->st1h_base = H5Tcreate(H5T_COMPOUND, sizeof(misc5_struct1));
|
||||
CHECK(str1hndl->st1h_base, FAIL, "H5Tcreate");
|
||||
@ -840,7 +841,7 @@ create_struct1(void)
|
||||
CHECK(ret, FAIL, "H5Tinsert");
|
||||
|
||||
str1hndl->st1h_st2hndl=create_struct2();
|
||||
CHECK(str1hndl->st1h_st2hndl,NULL,"create_struct2");
|
||||
CHECK_PTR(str1hndl->st1h_st2hndl, "create_struct2");
|
||||
|
||||
ret = H5Tinsert(str1hndl->st1h_base, "st1_el2", HOFFSET(misc5_struct1, st1_el2), str1hndl->st1h_st2hndl->st2h_id);
|
||||
CHECK(ret,FAIL,"H5Tinsert");
|
||||
@ -876,7 +877,7 @@ set_struct1(misc5_struct1 *buf)
|
||||
buf->st1_el2.len=MISC5_DBGNELM2;
|
||||
|
||||
buf->st1_el2.p=HDmalloc((buf->st1_el2.len)*sizeof(misc5_struct2));
|
||||
CHECK(buf->st1_el2.p,NULL,"malloc");
|
||||
CHECK_PTR(buf->st1_el2.p, "HDmalloc");
|
||||
|
||||
for(i=0; i<(buf->st1_el2.len); i++)
|
||||
set_struct2(&(((misc5_struct2 *)(buf->st1_el2.p))[i]));
|
||||
@ -912,7 +913,7 @@ test_misc5(void)
|
||||
|
||||
/* Create the memory structure to write */
|
||||
str1hndl = create_struct1();
|
||||
CHECK(str1hndl, NULL, "create_struct1");
|
||||
CHECK_PTR(str1hndl, "create_struct1");
|
||||
|
||||
/* Create the dataspace */
|
||||
dims[0] = MISC5_NELMTOPLVL;
|
||||
@ -926,7 +927,7 @@ test_misc5(void)
|
||||
/* Create the variable-length buffer */
|
||||
buf.len = MISC5_DBGNELM1;
|
||||
buf.p = HDmalloc((buf.len) * sizeof(misc5_struct1));
|
||||
CHECK(buf.p, NULL, "malloc");
|
||||
CHECK_PTR(buf.p, "HDmalloc");
|
||||
|
||||
/* Create the top-level VL information */
|
||||
for(i = 0; i < MISC5_DBGNELM1; i++)
|
||||
@ -1252,10 +1253,10 @@ test_misc8(void)
|
||||
|
||||
/* Allocate space for the data to write & read */
|
||||
wdata = (int *)HDmalloc(sizeof(int) * MISC8_DIM0 * MISC8_DIM1);
|
||||
CHECK(wdata,NULL,"malloc");
|
||||
CHECK_PTR(wdata, "HDmalloc");
|
||||
#ifdef VERIFY_DATA
|
||||
rdata = (int *)HDmalloc(sizeof(int) * MISC8_DIM0 * MISC8_DIM1);
|
||||
CHECK(rdata,NULL,"malloc");
|
||||
CHECK_PTR(rdata, "HDmalloc");
|
||||
#endif /* VERIFY_DATA */
|
||||
|
||||
/* Initialize values */
|
||||
@ -2143,7 +2144,7 @@ misc13_verify_dataset(hid_t loc_id, const char *name, const unsigned *data)
|
||||
|
||||
/* Create a data buffer for the dataset read */
|
||||
read_data = (unsigned *)HDcalloc(MISC13_DIM1, sizeof(unsigned));
|
||||
CHECK(read_data, NULL, "HDcalloc");
|
||||
CHECK_PTR(read_data, "HDcalloc");
|
||||
|
||||
/* Open the contiguous dataset in the root group */
|
||||
dsid = H5Dopen2(loc_id, name, H5P_DEFAULT);
|
||||
@ -2269,14 +2270,14 @@ misc13_insert_user_block(const char *old_name, const char *new_name, const char
|
||||
|
||||
/* Allocate space for the user block */
|
||||
user_block = HDcalloc(size, (size_t)1);
|
||||
CHECK(user_block, NULL, "HDcalloc");
|
||||
CHECK_PTR(user_block, "HDcalloc");
|
||||
|
||||
/* Copy in the user block data */
|
||||
HDmemcpy(user_block, str, strlen(str));
|
||||
|
||||
/* Open the new file */
|
||||
new_fp = HDfopen(new_name,"wb");
|
||||
CHECK(new_fp, NULL, "HDfopen");
|
||||
CHECK_PTR(new_fp, "HDfopen");
|
||||
|
||||
/* Write the user block to the new file */
|
||||
written = HDfwrite(user_block, (size_t)1, size, new_fp);
|
||||
@ -2284,11 +2285,11 @@ misc13_insert_user_block(const char *old_name, const char *new_name, const char
|
||||
|
||||
/* Open the old file */
|
||||
old_fp = HDfopen(old_name,"rb");
|
||||
CHECK(old_fp, NULL, "HDfopen");
|
||||
CHECK_PTR(old_fp, "HDfopen");
|
||||
|
||||
/* Allocate space for the copy buffer */
|
||||
copy_buf = HDmalloc((size_t)MISC13_COPY_BUF_SIZE);
|
||||
CHECK(copy_buf, NULL, "HDmalloc");
|
||||
CHECK_PTR(copy_buf, "HDmalloc");
|
||||
|
||||
/* Copy data from the old file to the new file */
|
||||
while((read_in = HDfread(copy_buf, (size_t)1, (size_t)MISC13_COPY_BUF_SIZE, old_fp)) > 0) {
|
||||
@ -2438,7 +2439,7 @@ test_misc13(void)
|
||||
|
||||
/* Create a data buffer for the datasets */
|
||||
data = (unsigned *)HDcalloc(MISC13_DIM1, sizeof(unsigned));
|
||||
CHECK(data, NULL, "HDcalloc");
|
||||
CHECK_PTR(data, "HDcalloc");
|
||||
|
||||
/* Initialize data to write */
|
||||
misc13_init_data(data);
|
||||
@ -3445,7 +3446,7 @@ test_misc19(void)
|
||||
|
||||
/* Get a VFD class to register */
|
||||
vfd_cls = h5_get_dummy_vfd_class();
|
||||
CHECK(vfd_cls, NULL, "h5_get_dummy_vfd_class");
|
||||
CHECK_PTR(vfd_cls, "h5_get_dummy_vfd_class");
|
||||
|
||||
/* Register a virtual file driver */
|
||||
vfdid = H5FDregister(vfd_cls);
|
||||
@ -5526,6 +5527,64 @@ test_misc33(void)
|
||||
|
||||
} /* end test_misc33() */
|
||||
|
||||
/****************************************************************
|
||||
**
|
||||
** test_misc34(): Ensure zero-size memory allocations work
|
||||
**
|
||||
****************************************************************/
|
||||
static void
|
||||
test_misc34(void)
|
||||
{
|
||||
void *mem = NULL; /* allocated buffer */
|
||||
char *dup = NULL; /* 'duplicated' string */
|
||||
size_t sz = 0; /* buffer size */
|
||||
|
||||
/* Output message about test being performed */
|
||||
MESSAGE(5, ("Testing O and NULL behavior in H5MM API calls"));
|
||||
|
||||
/* H5MM_xfree(): Ensure that passing NULL is allowed and returns NULL */
|
||||
mem = H5MM_xfree(mem);
|
||||
CHECK_PTR_NULL(mem, "H5MM_xfree");
|
||||
|
||||
/* H5MM_malloc(): Ensure that size 0 returns NULL */
|
||||
mem = H5MM_malloc(sz);
|
||||
CHECK_PTR_NULL(mem, "H5MM_malloc");
|
||||
mem = H5MM_xfree(mem);
|
||||
|
||||
/* H5MM_calloc(): Ensure that size 0 returns NULL */
|
||||
mem = H5MM_calloc(sz);
|
||||
CHECK_PTR_NULL(mem, "H5MM_calloc");
|
||||
mem = H5MM_xfree(mem);
|
||||
|
||||
/* H5MM_realloc(): Check behavior:
|
||||
*
|
||||
* H5MM_realloc(NULL, size) <==> H5MM_malloc(size)
|
||||
* H5MM_realloc(ptr, 0) <==> H5MM_xfree(ptr)
|
||||
* H5MM_realloc(NULL, 0) <==> NULL
|
||||
*/
|
||||
mem = H5MM_xfree(mem);
|
||||
|
||||
sz = 1024;
|
||||
mem = H5MM_realloc(mem, sz);
|
||||
CHECK_PTR(mem, "H5MM_realloc (case 1)");
|
||||
/* Don't free mem here! */
|
||||
|
||||
sz = 0;
|
||||
mem = H5MM_realloc(mem, sz);
|
||||
CHECK_PTR_NULL(mem, "H5MM_realloc (case 2)");
|
||||
mem = H5MM_xfree(mem);
|
||||
|
||||
mem = H5MM_realloc(mem, sz);
|
||||
CHECK_PTR_NULL(mem, "H5MM_realloc (case 3)");
|
||||
mem = H5MM_xfree(mem);
|
||||
|
||||
/* H5MM_xstrdup(): Ensure NULL returns NULL */
|
||||
dup = H5MM_xstrdup((const char *)mem);
|
||||
CHECK_PTR_NULL(dup, "H5MM_xstrdup");
|
||||
dup = (char *)H5MM_xfree((void *)dup);
|
||||
|
||||
} /* end test_misc34() */
|
||||
|
||||
|
||||
/****************************************************************
|
||||
**
|
||||
@ -5575,6 +5634,7 @@ test_misc(void)
|
||||
test_misc31(); /* Test Reentering library through deprecated routines after H5close() */
|
||||
test_misc32(); /* Test filter memory allocation functions */
|
||||
test_misc33(); /* Test to verify that H5HL_offset_into() returns error if offset exceeds heap block */
|
||||
test_misc34(); /* Test behavior of 0 and NULL in H5MM API calls */
|
||||
|
||||
} /* test_misc() */
|
||||
|
||||
@ -5632,5 +5692,5 @@ cleanup_misc(void)
|
||||
HDremove(MISC29_COPY_FILE);
|
||||
HDremove(MISC30_FILE);
|
||||
HDremove(MISC31_FILE);
|
||||
}
|
||||
} /* end cleanup_misc() */
|
||||
|
||||
|
@ -67,7 +67,7 @@ test_refstr_create(void)
|
||||
|
||||
/* Try creating a ref-counted string */
|
||||
rs=H5RS_create("foo");
|
||||
CHECK(rs, NULL, "H5RS_create");
|
||||
CHECK_PTR(rs, "H5RS_create");
|
||||
|
||||
/* Get the reference count on the string */
|
||||
count=H5RS_get_count(rs);
|
||||
@ -97,7 +97,7 @@ test_refstr_count(void)
|
||||
|
||||
/* Try creating a ref-counted string */
|
||||
rs=H5RS_create("foo");
|
||||
CHECK(rs, NULL, "H5RS_create");
|
||||
CHECK_PTR(rs, "H5RS_create");
|
||||
|
||||
/* Get the reference count on the string */
|
||||
count=H5RS_get_count(rs);
|
||||
@ -144,7 +144,7 @@ test_refstr_dup(void)
|
||||
|
||||
/* Try creating a ref-counted string */
|
||||
rs1=H5RS_create("foo");
|
||||
CHECK(rs1, NULL, "H5RS_create");
|
||||
CHECK_PTR(rs1, "H5RS_create");
|
||||
|
||||
/* Get the reference count on the string */
|
||||
count=H5RS_get_count(rs1);
|
||||
@ -152,7 +152,7 @@ test_refstr_dup(void)
|
||||
|
||||
/* Duplicate r-string */
|
||||
rs2=H5RS_dup(rs1);
|
||||
CHECK(rs2, NULL, "H5RS_dup");
|
||||
CHECK_PTR(rs2, "H5RS_dup");
|
||||
|
||||
/* Get the reference count on the strings */
|
||||
count=H5RS_get_count(rs1);
|
||||
@ -194,11 +194,11 @@ test_refstr_cmp(void)
|
||||
|
||||
/* Create first reference counted string */
|
||||
rs1=H5RS_create("foo");
|
||||
CHECK(rs1, NULL, "H5RS_create");
|
||||
CHECK_PTR(rs1, "H5RS_create");
|
||||
|
||||
/* Create second reference counted string */
|
||||
rs2=H5RS_create("foo2");
|
||||
CHECK(rs2, NULL, "H5RS_create");
|
||||
CHECK_PTR(rs2, "H5RS_create");
|
||||
|
||||
/* Compare the strings in various ways */
|
||||
cmp=H5RS_cmp(rs1,rs1);
|
||||
@ -246,12 +246,12 @@ test_refstr_wrap(void)
|
||||
|
||||
/* Wrap ref-counted string around existing buffer */
|
||||
rs=H5RS_wrap(buf);
|
||||
CHECK(rs, NULL, "H5RS_wrap");
|
||||
CHECK_PTR(rs, "H5RS_wrap");
|
||||
|
||||
/* Get pointer to raw string in ref-counted string */
|
||||
s=H5RS_get_str(rs);
|
||||
CHECK(s, NULL, "H5RS_get_str");
|
||||
VERIFY(s, buf, "wrapping");
|
||||
CHECK_PTR(s, "H5RS_get_str");
|
||||
CHECK_PTR_EQ(s, buf, "wrapping");
|
||||
cmp=HDstrcmp(s,buf);
|
||||
VERIFY(cmp, 0, "HDstrcmp");
|
||||
|
||||
@ -264,7 +264,7 @@ test_refstr_wrap(void)
|
||||
|
||||
/* Get pointer to raw string in ref-counted string */
|
||||
s=H5RS_get_str(rs);
|
||||
CHECK(s, NULL, "H5RS_get_str");
|
||||
CHECK_PTR(s, "H5RS_get_str");
|
||||
CHECK(s, buf, "wrapping");
|
||||
cmp=HDstrcmp(s,buf);
|
||||
if(cmp<=0)
|
||||
@ -299,17 +299,17 @@ test_refstr_own(void)
|
||||
|
||||
/* Initialize buffer */
|
||||
s = (char *)H5FL_BLK_MALLOC(str_buf,HDstrlen("foo") + 1);
|
||||
CHECK(s, NULL, "H5FL_BLK_MALLOC");
|
||||
CHECK_PTR(s, "H5FL_BLK_MALLOC");
|
||||
HDstrcpy(s, "foo");
|
||||
|
||||
/* Transfer ownership of dynamically allocated string to ref-counted string */
|
||||
rs=H5RS_own(s);
|
||||
CHECK(rs, NULL, "H5RS_own");
|
||||
CHECK_PTR(rs, "H5RS_own");
|
||||
|
||||
/* Get pointer to raw string in ref-counted string */
|
||||
t=H5RS_get_str(rs);
|
||||
CHECK(t, NULL, "H5RS_get_str");
|
||||
VERIFY(t, s, "transferring");
|
||||
CHECK_PTR(t, "H5RS_get_str");
|
||||
CHECK_PTR_EQ(t, s, "transferring");
|
||||
cmp=HDstrcmp(s,t);
|
||||
VERIFY(cmp, 0, "HDstrcmp");
|
||||
|
||||
@ -322,8 +322,8 @@ test_refstr_own(void)
|
||||
|
||||
/* Get pointer to raw string in ref-counted string */
|
||||
t=H5RS_get_str(rs);
|
||||
CHECK(t, NULL, "H5RS_get_str");
|
||||
VERIFY(t, s, "transferring");
|
||||
CHECK_PTR(t, "H5RS_get_str");
|
||||
CHECK_PTR_EQ(t, s, "transferring");
|
||||
cmp=HDstrcmp(t,s);
|
||||
VERIFY(cmp, 0, "HDstrcmp");
|
||||
|
||||
|
130
test/tselect.c
130
test/tselect.c
@ -228,9 +228,9 @@ test_select_hyper(hid_t xfer_plist)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint8_t *)HDmalloc(sizeof(uint8_t) * SPACE2_DIM1 * SPACE2_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint8_t *)HDcalloc(sizeof(uint8_t), (size_t)(SPACE3_DIM1 * SPACE3_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE2_DIM1; i++)
|
||||
@ -432,9 +432,9 @@ test_select_point(hid_t xfer_plist)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint8_t *)HDmalloc(sizeof(uint8_t) * SPACE2_DIM1 * SPACE2_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint8_t *)HDcalloc(sizeof(uint8_t), (size_t)(SPACE3_DIM1 * SPACE3_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE2_DIM1; i++)
|
||||
@ -710,9 +710,9 @@ test_select_all(hid_t xfer_plist)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint8_t *)HDmalloc(sizeof(uint8_t) * SPACE4_DIM1 * SPACE4_DIM2 * SPACE4_DIM3);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint8_t *)HDcalloc(sizeof(uint8_t), (size_t)(SPACE4_DIM1 * SPACE4_DIM2 * SPACE4_DIM3));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE4_DIM1; i++)
|
||||
@ -797,9 +797,9 @@ test_select_all_hyper(hid_t xfer_plist)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint8_t *)HDmalloc(sizeof(uint8_t) * SPACE2_DIM1 * SPACE2_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint8_t *)HDcalloc(sizeof(uint8_t), (size_t)(SPACE3_DIM1 * SPACE3_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE2_DIM1; i++)
|
||||
@ -939,9 +939,9 @@ test_select_combo(void)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint8_t *)HDmalloc(sizeof(uint8_t) * SPACE2_DIM1 * SPACE2_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint8_t *)HDcalloc(sizeof(uint8_t), (size_t)(SPACE3_DIM1 * SPACE3_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE2_DIM1; i++)
|
||||
@ -1106,9 +1106,9 @@ test_select_hyper_stride(hid_t xfer_plist)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint16_t *)HDmalloc(sizeof(uint16_t) * SPACE2_DIM1 * SPACE2_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint16_t *)HDcalloc(sizeof(uint16_t), (size_t)(SPACE3_DIM1 * SPACE3_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE2_DIM1; i++)
|
||||
@ -1234,9 +1234,9 @@ test_select_hyper_contig(hid_t dset_type, hid_t xfer_plist)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint16_t *)HDmalloc(sizeof(uint16_t) * SPACE2_DIM1 * SPACE2_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint16_t *)HDcalloc(sizeof(uint16_t), (size_t)(SPACE2_DIM1 * SPACE2_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE2_DIM1; i++)
|
||||
@ -1364,9 +1364,9 @@ test_select_hyper_contig2(hid_t dset_type, hid_t xfer_plist)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint16_t *)HDmalloc(sizeof(uint16_t) * SPACE8_DIM1 * SPACE8_DIM2 * SPACE8_DIM3 * SPACE8_DIM4);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint16_t *)HDcalloc(sizeof(uint16_t), (size_t)(SPACE8_DIM1 * SPACE8_DIM2 * SPACE8_DIM3 * SPACE8_DIM4));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE8_DIM1; i++)
|
||||
@ -1491,9 +1491,9 @@ test_select_hyper_contig3(hid_t dset_type, hid_t xfer_plist)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint16_t *)HDmalloc(sizeof(uint16_t) * SPACE8_DIM1 * SPACE8_DIM2 * SPACE8_DIM3 * SPACE8_DIM4);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint16_t *)HDcalloc(sizeof(uint16_t), (size_t)(SPACE8_DIM1 * SPACE8_DIM2 * SPACE8_DIM3 * SPACE8_DIM4));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE8_DIM4; i++)
|
||||
@ -1735,9 +1735,9 @@ test_select_hyper_contig_dr__run_test(int test_num, const uint16_t *cube_buf,
|
||||
|
||||
/* Allocate buffers */
|
||||
small_cube_buf_1 = (uint16_t *)HDcalloc(sizeof(uint16_t), small_cube_size);
|
||||
CHECK(small_cube_buf_1, NULL, "HDcalloc");
|
||||
CHECK_PTR(small_cube_buf_1, "HDcalloc");
|
||||
large_cube_buf_1 = (uint16_t *)HDcalloc(sizeof(uint16_t), large_cube_size);
|
||||
CHECK(large_cube_buf_1, NULL, "HDcalloc");
|
||||
CHECK_PTR(large_cube_buf_1, "HDcalloc");
|
||||
|
||||
/* Create a dataset transfer property list */
|
||||
fapl = H5Pcreate(H5P_FILE_ACCESS);
|
||||
@ -2342,7 +2342,7 @@ test_select_hyper_contig_dr(hid_t dset_type, hid_t xfer_plist)
|
||||
|
||||
/* Allocate cube buffer for writing values */
|
||||
cube_buf = (uint16_t *)HDmalloc(sizeof(uint16_t) * max_cube_size);
|
||||
CHECK(cube_buf, NULL, "HDmalloc");
|
||||
CHECK_PTR(cube_buf, "HDmalloc");
|
||||
|
||||
/* Initialize the cube buffer */
|
||||
cube_ptr = cube_buf;
|
||||
@ -2351,7 +2351,7 @@ test_select_hyper_contig_dr(hid_t dset_type, hid_t xfer_plist)
|
||||
|
||||
/* Allocate cube buffer for zeroing values on disk */
|
||||
zero_buf = (uint16_t *)HDcalloc(sizeof(uint16_t), max_cube_size);
|
||||
CHECK(zero_buf, NULL, "HDcalloc");
|
||||
CHECK_PTR(zero_buf, "HDcalloc");
|
||||
|
||||
for(large_rank = 1; large_rank <= max_rank; large_rank++) {
|
||||
for(small_rank = 1; small_rank < large_rank; small_rank++) {
|
||||
@ -2811,9 +2811,9 @@ test_select_hyper_checker_board_dr__run_test(int test_num, const uint16_t *cube_
|
||||
|
||||
/* Allocate & initialize buffers */
|
||||
small_cube_buf_1 = (uint16_t *)HDcalloc(sizeof(uint16_t), small_cube_size);
|
||||
CHECK(small_cube_buf_1, NULL, "HDcalloc");
|
||||
CHECK_PTR(small_cube_buf_1, "HDcalloc");
|
||||
large_cube_buf_1 = (uint16_t *)HDcalloc(sizeof(uint16_t), large_cube_size);
|
||||
CHECK(large_cube_buf_1, NULL, "HDcalloc");
|
||||
CHECK_PTR(large_cube_buf_1, "HDcalloc");
|
||||
|
||||
|
||||
/* Create a dataset transfer property list */
|
||||
@ -3574,7 +3574,7 @@ test_select_hyper_checker_board_dr(hid_t dset_type, hid_t xfer_plist)
|
||||
|
||||
/* Allocate cube buffer for writing values */
|
||||
cube_buf = (uint16_t *)HDmalloc(sizeof(uint16_t) * max_cube_size);
|
||||
CHECK(cube_buf, NULL, "HDmalloc");
|
||||
CHECK_PTR(cube_buf, "HDmalloc");
|
||||
|
||||
/* Initialize the cube buffer */
|
||||
cube_ptr = cube_buf;
|
||||
@ -3583,7 +3583,7 @@ test_select_hyper_checker_board_dr(hid_t dset_type, hid_t xfer_plist)
|
||||
|
||||
/* Allocate cube buffer for zeroing values on disk */
|
||||
zero_buf = (uint16_t *)HDcalloc(sizeof(uint16_t), max_cube_size);
|
||||
CHECK(zero_buf, NULL, "HDcalloc");
|
||||
CHECK_PTR(zero_buf, "HDcalloc");
|
||||
|
||||
for(large_rank = 1; large_rank <= max_rank; large_rank++) {
|
||||
for(small_rank = 1; small_rank < large_rank; small_rank++) {
|
||||
@ -3651,11 +3651,11 @@ test_select_hyper_copy(void)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint16_t *)HDmalloc(sizeof(uint16_t) * SPACE2_DIM1 * SPACE2_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint16_t *)HDcalloc(sizeof(uint16_t), (size_t)(SPACE3_DIM1 * SPACE3_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
rbuf2 = (uint16_t *)HDcalloc(sizeof(uint16_t), (size_t)(SPACE3_DIM1 * SPACE3_DIM2));
|
||||
CHECK(rbuf2, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf2, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE2_DIM1; i++)
|
||||
@ -3813,11 +3813,11 @@ test_select_point_copy(void)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint16_t *)HDmalloc(sizeof(uint16_t) * SPACE2_DIM1 * SPACE2_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint16_t *)HDcalloc(sizeof(uint16_t), (size_t)(SPACE3_DIM1 * SPACE3_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
rbuf2 = (uint16_t *)HDcalloc(sizeof(uint16_t), (size_t)(SPACE3_DIM1 * SPACE3_DIM2));
|
||||
CHECK(rbuf2, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf2, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE2_DIM1; i++)
|
||||
@ -3991,9 +3991,9 @@ test_select_hyper_offset(void)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint8_t *)HDmalloc(sizeof(uint8_t) * SPACE2_DIM1 * SPACE2_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint8_t *)HDcalloc(sizeof(uint8_t), (size_t)(SPACE3_DIM1 * SPACE3_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE2_DIM1; i++)
|
||||
@ -4149,9 +4149,9 @@ test_select_hyper_offset2(void)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint8_t *)HDmalloc(sizeof(uint8_t) * SPACE7_DIM1 * SPACE7_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint8_t *)HDcalloc(sizeof(uint8_t), (size_t)(SPACE7_DIM1 * SPACE7_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE7_DIM1; i++)
|
||||
@ -4272,9 +4272,9 @@ test_select_point_offset(void)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint8_t *)HDmalloc(sizeof(uint8_t) * SPACE2_DIM1 * SPACE2_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint8_t *)HDcalloc(sizeof(uint8_t), (size_t)(SPACE3_DIM1 * SPACE3_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE2_DIM1; i++)
|
||||
@ -4452,9 +4452,9 @@ test_select_hyper_union(void)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint8_t *)HDmalloc(sizeof(uint8_t) * SPACE2_DIM1 * SPACE2_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint8_t *)HDcalloc(sizeof(uint8_t), (size_t)(SPACE3_DIM1 * SPACE3_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE2_DIM1; i++)
|
||||
@ -5319,9 +5319,9 @@ test_select_hyper_and_2d(void)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint8_t *)HDmalloc(sizeof(uint8_t) * SPACE2_DIM1 * SPACE2_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint8_t *)HDcalloc(sizeof(uint8_t), (size_t)(SPACE2_DIM1 * SPACE2_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE2_DIM1; i++)
|
||||
@ -5448,9 +5448,9 @@ test_select_hyper_xor_2d(void)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint8_t *)HDmalloc(sizeof(uint8_t) * SPACE2_DIM1 * SPACE2_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint8_t *)HDcalloc(sizeof(uint8_t), (size_t)(SPACE2_DIM1 * SPACE2_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE2_DIM1; i++)
|
||||
@ -5579,9 +5579,9 @@ test_select_hyper_notb_2d(void)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint8_t *)HDmalloc(sizeof(uint8_t) * SPACE2_DIM1 * SPACE2_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint8_t *)HDcalloc(sizeof(uint8_t), (size_t)(SPACE2_DIM1 * SPACE2_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE2_DIM1; i++)
|
||||
@ -5709,9 +5709,9 @@ test_select_hyper_nota_2d(void)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint8_t *)HDmalloc(sizeof(uint8_t) * SPACE2_DIM1 * SPACE2_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint8_t *)HDcalloc(sizeof(uint8_t), (size_t)(SPACE2_DIM1 * SPACE2_DIM2));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE2_DIM1; i++)
|
||||
@ -5869,9 +5869,9 @@ test_select_hyper_union_random_5d(hid_t read_plist)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (int *)HDmalloc(sizeof(int) * SPACE5_DIM1 * SPACE5_DIM2 * SPACE5_DIM3 * SPACE5_DIM4 * SPACE5_DIM5);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (int *)HDcalloc(sizeof(int), (size_t)(SPACE5_DIM1 * SPACE5_DIM2 * SPACE5_DIM3 * SPACE5_DIM4 * SPACE5_DIM5));
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE5_DIM1; i++)
|
||||
@ -6061,9 +6061,9 @@ test_select_hyper_chunk(hid_t fapl_plist, hid_t xfer_plist)
|
||||
|
||||
/* Allocate the transfer buffers */
|
||||
data = (short *)HDmalloc(sizeof(short) * X * Y * Z);
|
||||
CHECK(data, NULL, "HDmalloc");
|
||||
CHECK_PTR(data, "HDmalloc");
|
||||
data_out = (short *)HDcalloc((size_t)(NX * NY * NZ), sizeof(short));
|
||||
CHECK(data_out, NULL, "HDcalloc");
|
||||
CHECK_PTR(data_out, "HDcalloc");
|
||||
|
||||
/*
|
||||
* Data buffer initialization.
|
||||
@ -6296,9 +6296,9 @@ test_select_point_chunk(void)
|
||||
|
||||
/* Allocate the transfer buffers */
|
||||
data = (unsigned *)HDmalloc(sizeof(unsigned) * SPACE7_DIM1 * SPACE7_DIM2);
|
||||
CHECK(data, NULL, "HDmalloc");
|
||||
CHECK_PTR(data, "HDmalloc");
|
||||
data_out = (unsigned *)HDcalloc((size_t)(SPACE7_DIM1 * SPACE7_DIM2), sizeof(unsigned));
|
||||
CHECK(data_out, NULL, "HDcalloc");
|
||||
CHECK_PTR(data_out, "HDcalloc");
|
||||
|
||||
/*
|
||||
* Data buffer initialization.
|
||||
@ -7057,7 +7057,7 @@ test_select_fill_all(void)
|
||||
|
||||
/* Allocate memory buffer */
|
||||
wbuf = (unsigned *)HDmalloc(sizeof(unsigned) * SPACE7_DIM1 * SPACE7_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
|
||||
/* Initialize memory buffer */
|
||||
for(u = 0, tbuf = wbuf; u < SPACE7_DIM1; u++)
|
||||
@ -7133,7 +7133,7 @@ test_select_fill_point(hssize_t *offset)
|
||||
|
||||
/* Allocate memory buffer */
|
||||
wbuf = (unsigned *)HDmalloc(sizeof(unsigned) * SPACE7_DIM1 * SPACE7_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
|
||||
/* Initialize memory buffer */
|
||||
for(u = 0, tbuf = wbuf; u < SPACE7_DIM1; u++)
|
||||
@ -7230,7 +7230,7 @@ test_select_fill_hyper_simple(hssize_t *offset)
|
||||
|
||||
/* Allocate memory buffer */
|
||||
wbuf = (unsigned *)HDmalloc(sizeof(unsigned) * SPACE7_DIM1 * SPACE7_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
|
||||
/* Initialize memory buffer */
|
||||
for(u = 0, tbuf = wbuf; u < SPACE7_DIM1; u++)
|
||||
@ -7337,7 +7337,7 @@ test_select_fill_hyper_regular(hssize_t *offset)
|
||||
|
||||
/* Allocate memory buffer */
|
||||
wbuf = (unsigned *)HDmalloc(sizeof(unsigned) * SPACE7_DIM1 * SPACE7_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
|
||||
/* Initialize memory buffer */
|
||||
for(u = 0, tbuf = wbuf; u < SPACE7_DIM1; u++)
|
||||
@ -7456,7 +7456,7 @@ test_select_fill_hyper_irregular(hssize_t *offset)
|
||||
|
||||
/* Allocate memory buffer */
|
||||
wbuf = (unsigned *)HDmalloc(sizeof(unsigned) * SPACE7_DIM1 * SPACE7_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
|
||||
/* Initialize memory buffer */
|
||||
for(u = 0, tbuf = wbuf; u < SPACE7_DIM1; u++)
|
||||
@ -7558,9 +7558,9 @@ test_select_none(void)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf = (uint8_t *)HDmalloc(sizeof(uint8_t) * SPACE7_DIM1 * SPACE7_DIM2);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (uint8_t *)HDcalloc(sizeof(uint8_t), SPACE7_DIM1 * SPACE7_DIM2);
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize write buffer */
|
||||
for(i=0, tbuf=wbuf; i<SPACE7_DIM1; i++)
|
||||
@ -7661,9 +7661,9 @@ test_scalar_select(void)
|
||||
|
||||
/* Allocate write & read buffers */
|
||||
wbuf_uint8 = (uint8_t *)HDmalloc(sizeof(uint8_t) * SPACE7_DIM1 * SPACE7_DIM2);
|
||||
CHECK(wbuf_uint8, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf_uint8, "HDmalloc");
|
||||
wbuf_ushort = (unsigned short *)HDmalloc(sizeof(unsigned short) * SPACE7_DIM1 * SPACE7_DIM2);
|
||||
CHECK(wbuf_ushort, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf_ushort, "HDmalloc");
|
||||
|
||||
/* Initialize write buffers */
|
||||
for(i=0, tbuf_uint8=wbuf_uint8, tbuf_ushort=wbuf_ushort; i<SPACE7_DIM1; i++)
|
||||
@ -12581,9 +12581,9 @@ test_select_hyper_chunk_offset(void)
|
||||
|
||||
/* Allocate buffers */
|
||||
wbuf = (int *)HDmalloc(sizeof(int) * SPACE10_DIM1);
|
||||
CHECK(wbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(wbuf, "HDmalloc");
|
||||
rbuf = (int *)HDcalloc(sizeof(int), SPACE10_DIM1);
|
||||
CHECK(rbuf, NULL, "HDcalloc");
|
||||
CHECK_PTR(rbuf, "HDcalloc");
|
||||
|
||||
/* Initialize the write buffer */
|
||||
for(i=0; i<SPACE10_DIM1; i++)
|
||||
|
156
test/tskiplist.c
156
test/tskiplist.c
@ -66,11 +66,11 @@ test_skiplist_init(void)
|
||||
|
||||
/* Allocate arrays */
|
||||
rand_num = (int *)HDmalloc(sizeof(int) * NUM_ELEMS);
|
||||
CHECK(rand_num, NULL, "HDmalloc");
|
||||
CHECK_PTR(rand_num, "HDmalloc");
|
||||
sort_rand_num = (int *)HDmalloc(sizeof(int) * NUM_ELEMS);
|
||||
CHECK(sort_rand_num, NULL, "HDmalloc");
|
||||
CHECK_PTR(sort_rand_num, "HDmalloc");
|
||||
rev_sort_rand_num = (int *)HDmalloc(sizeof(int) * NUM_ELEMS);
|
||||
CHECK(rev_sort_rand_num, NULL, "HDmalloc");
|
||||
CHECK_PTR(rev_sort_rand_num, "HDmalloc");
|
||||
|
||||
/* Initialize random number seed */
|
||||
curr_time = HDtime(NULL);
|
||||
@ -125,7 +125,7 @@ test_skiplist_create(void)
|
||||
|
||||
/* Try creating a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_INT, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Try closing the skip list */
|
||||
ret=H5SL_close(slist);
|
||||
@ -155,7 +155,7 @@ test_skiplist_insert(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_INT, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Check that the skip list has no elements */
|
||||
num=H5SL_count(slist);
|
||||
@ -164,7 +164,7 @@ test_skiplist_insert(void)
|
||||
/* Try searching for item in empty skip list */
|
||||
key=37;
|
||||
found_item=(int *)H5SL_search(slist,&key);
|
||||
VERIFY(found_item, NULL, "H5SL_search");
|
||||
CHECK_PTR_NULL(found_item, "H5SL_search");
|
||||
|
||||
/* Insert an object into the skip list */
|
||||
key=2; item=10;
|
||||
@ -177,13 +177,13 @@ test_skiplist_insert(void)
|
||||
|
||||
/* Search for the item just inserted */
|
||||
found_item=(int *)H5SL_search(slist,&key);
|
||||
CHECK(found_item, NULL, "H5SL_search");
|
||||
VERIFY(*found_item,item,"H5SL_search");
|
||||
CHECK_PTR(found_item, "H5SL_search");
|
||||
VERIFY(*found_item, item, "H5SL_search");
|
||||
|
||||
/* Search for an item not in list */
|
||||
search_key=37;
|
||||
found_item=(int *)H5SL_search(slist,&search_key);
|
||||
VERIFY(found_item, NULL, "H5SL_search");
|
||||
CHECK_PTR_NULL(found_item, "H5SL_search");
|
||||
|
||||
/* Attempt to insert duplicate key (should fail) */
|
||||
search_key=2;
|
||||
@ -216,7 +216,7 @@ test_skiplist_insert_many(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_INT, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Check that the skip list has no elements */
|
||||
num=H5SL_count(slist);
|
||||
@ -235,7 +235,7 @@ test_skiplist_insert_many(void)
|
||||
/* Search for all objects in the skip list */
|
||||
for(u=0; u<NUM_ELEMS; u++) {
|
||||
found_item=(int *)H5SL_search(slist,&rand_num[u]);
|
||||
CHECK(found_item, NULL, "H5SL_search");
|
||||
CHECK_PTR(found_item, "H5SL_search");
|
||||
VERIFY(*found_item,rand_num[u],"H5SL_search");
|
||||
} /* end for */
|
||||
|
||||
@ -290,7 +290,7 @@ test_skiplist_remove(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_INT, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Check that the skip list has no elements */
|
||||
num=H5SL_count(slist);
|
||||
@ -299,7 +299,7 @@ test_skiplist_remove(void)
|
||||
/* Try removing an item in empty skip list */
|
||||
search_key=37;
|
||||
found_item=(int *)H5SL_remove(slist,&search_key);
|
||||
VERIFY(found_item, NULL, "H5SL_remove");
|
||||
CHECK_PTR_NULL(found_item, "H5SL_remove");
|
||||
|
||||
/* Insert three objects into the skip list */
|
||||
key1=15;
|
||||
@ -321,18 +321,18 @@ test_skiplist_remove(void)
|
||||
/* Try removing items from skip list */
|
||||
search_key=key1;
|
||||
found_item=(int *)H5SL_remove(slist,&search_key);
|
||||
CHECK(found_item, NULL, "H5SL_remove");
|
||||
VERIFY(found_item, &key1, "H5SL_remove");
|
||||
CHECK_PTR(found_item, "H5SL_remove");
|
||||
CHECK_PTR_EQ(found_item, &key1, "H5SL_remove");
|
||||
|
||||
search_key=key2;
|
||||
found_item=(int *)H5SL_remove(slist,&search_key);
|
||||
CHECK(found_item, NULL, "H5SL_remove");
|
||||
VERIFY(found_item, &key2, "H5SL_remove");
|
||||
CHECK_PTR(found_item, "H5SL_remove");
|
||||
CHECK_PTR_EQ(found_item, &key2, "H5SL_remove");
|
||||
|
||||
search_key=key3;
|
||||
found_item=(int *)H5SL_remove(slist,&search_key);
|
||||
CHECK(found_item, NULL, "H5SL_remove");
|
||||
VERIFY(found_item, &key3, "H5SL_remove");
|
||||
CHECK_PTR(found_item, "H5SL_remove");
|
||||
CHECK_PTR_EQ(found_item, &key3, "H5SL_remove");
|
||||
|
||||
/* Check that the skip list has no elements */
|
||||
num=H5SL_count(slist);
|
||||
@ -341,7 +341,7 @@ test_skiplist_remove(void)
|
||||
/* Try removing items from empty skip list (after its been worked on) */
|
||||
search_key=key1;
|
||||
found_item=(int *)H5SL_remove(slist,&search_key);
|
||||
VERIFY(found_item, NULL, "H5SL_remove");
|
||||
CHECK_PTR_NULL(found_item, "H5SL_remove");
|
||||
|
||||
/* Close the skip list */
|
||||
ret=H5SL_close(slist);
|
||||
@ -369,7 +369,7 @@ test_skiplist_remove_many(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_INT, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Check that the skip list has no elements */
|
||||
num=H5SL_count(slist);
|
||||
@ -388,7 +388,7 @@ test_skiplist_remove_many(void)
|
||||
/* Remove all objects from the skip list (in random order) */
|
||||
for(u=0; u<NUM_ELEMS; u++) {
|
||||
found_item=(int *)H5SL_remove(slist,&rand_num[u]);
|
||||
CHECK(found_item, NULL, "H5SL_remove");
|
||||
CHECK_PTR(found_item, "H5SL_remove");
|
||||
VERIFY(*found_item,rand_num[u],"H5SL_remove");
|
||||
} /* end for */
|
||||
|
||||
@ -411,7 +411,7 @@ test_skiplist_remove_many(void)
|
||||
/* Remove all objects from the skip list */
|
||||
for(u=0; u<NUM_ELEMS; u++) {
|
||||
found_item=(int *)H5SL_remove(slist,&sort_rand_num[u]);
|
||||
CHECK(found_item, NULL, "H5SL_remove");
|
||||
CHECK_PTR(found_item, "H5SL_remove");
|
||||
VERIFY(*found_item,sort_rand_num[u],"H5SL_remove");
|
||||
} /* end for */
|
||||
|
||||
@ -434,7 +434,7 @@ test_skiplist_remove_many(void)
|
||||
/* Remove all objects from the skip list */
|
||||
for(u=0; u<NUM_ELEMS; u++) {
|
||||
found_item=(int *)H5SL_remove(slist,&rev_sort_rand_num[u]);
|
||||
CHECK(found_item, NULL, "H5SL_remove");
|
||||
CHECK_PTR(found_item, "H5SL_remove");
|
||||
VERIFY(*found_item,rev_sort_rand_num[u],"H5SL_remove");
|
||||
} /* end for */
|
||||
|
||||
@ -469,7 +469,7 @@ test_skiplist_firstnext(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_INT, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Check that the skip list has no elements */
|
||||
num=H5SL_count(slist);
|
||||
@ -477,7 +477,7 @@ test_skiplist_firstnext(void)
|
||||
VERIFY(num, 0, "H5SL_count");
|
||||
/* Check that the list appears empty */
|
||||
node=H5SL_first(slist);
|
||||
VERIFY(node, NULL, "H5SL_first");
|
||||
CHECK_PTR_NULL(node, "H5SL_first");
|
||||
|
||||
/* Insert many objects into the skip list */
|
||||
for(u=0; u<NUM_ELEMS; u++) {
|
||||
@ -491,7 +491,7 @@ test_skiplist_firstnext(void)
|
||||
|
||||
/* Iterate over all the nodes in the skip list */
|
||||
node=H5SL_first(slist);
|
||||
CHECK(node, NULL, "H5SL_first");
|
||||
CHECK_PTR(node, "H5SL_first");
|
||||
u=0;
|
||||
while(node!=NULL) {
|
||||
found_item=(int *)H5SL_item(node);
|
||||
@ -506,7 +506,7 @@ test_skiplist_firstnext(void)
|
||||
|
||||
/* Check that the list appears empty again */
|
||||
node=H5SL_first(slist);
|
||||
VERIFY(node, NULL, "H5SL_first");
|
||||
CHECK_PTR_NULL(node, "H5SL_first");
|
||||
|
||||
/* Close the skip list */
|
||||
ret=H5SL_close(slist);
|
||||
@ -562,7 +562,7 @@ test_skiplist_string(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_STR, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Check that the skip list has no elements */
|
||||
num=H5SL_count(slist);
|
||||
@ -624,7 +624,7 @@ test_skiplist_iterate(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_INT, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Check that the skip list has no elements */
|
||||
num=H5SL_count(slist);
|
||||
@ -674,7 +674,7 @@ test_skiplist_hsize(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_HSIZE, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Check that the skip list has no elements */
|
||||
num=H5SL_count(slist);
|
||||
@ -729,7 +729,7 @@ test_skiplist_unsigned(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_UNSIGNED, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Check that the skip list has no elements */
|
||||
num=H5SL_count(slist);
|
||||
@ -784,7 +784,7 @@ test_skiplist_obj(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_OBJ, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Check that the skip list has no elements */
|
||||
num=H5SL_count(slist);
|
||||
@ -862,7 +862,7 @@ test_skiplist_generic(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_GENERIC, test_skiplist_generic_cmp);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Check that the skip list has no elements */
|
||||
num=H5SL_count(slist);
|
||||
@ -916,7 +916,7 @@ test_skiplist_lastprev(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_INT, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Check that the skip list has no elements */
|
||||
num=H5SL_count(slist);
|
||||
@ -924,7 +924,7 @@ test_skiplist_lastprev(void)
|
||||
|
||||
/* Check that the list appears empty */
|
||||
node=H5SL_last(slist);
|
||||
VERIFY(node, NULL, "H5SL_last");
|
||||
CHECK_PTR_NULL(node, "H5SL_last");
|
||||
|
||||
/* Insert many objects into the skip list */
|
||||
for(u=0; u<NUM_ELEMS; u++) {
|
||||
@ -938,7 +938,7 @@ test_skiplist_lastprev(void)
|
||||
|
||||
/* Iterate over all the nodes in the skip list */
|
||||
node=H5SL_last(slist);
|
||||
CHECK(node, NULL, "H5SL_last");
|
||||
CHECK_PTR(node, "H5SL_last");
|
||||
u=NUM_ELEMS-1;
|
||||
while(node!=NULL) {
|
||||
found_item=(int *)H5SL_item(node);
|
||||
@ -953,7 +953,7 @@ test_skiplist_lastprev(void)
|
||||
|
||||
/* Check that the list appears empty again */
|
||||
node=H5SL_last(slist);
|
||||
VERIFY(node, NULL, "H5SL_last");
|
||||
CHECK_PTR_NULL(node, "H5SL_last");
|
||||
|
||||
/* Close the skip list */
|
||||
ret=H5SL_close(slist);
|
||||
@ -984,7 +984,7 @@ test_skiplist_find(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_UNSIGNED, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Insert objects into the skip list */
|
||||
for(u=0; u<10; u++) {
|
||||
@ -995,7 +995,7 @@ test_skiplist_find(void)
|
||||
/* Find the element with key==30 in the skip list */
|
||||
find_item=30;
|
||||
node=H5SL_find(slist,&find_item);
|
||||
CHECK(node, NULL, "H5SL_find");
|
||||
CHECK_PTR(node, "H5SL_find");
|
||||
|
||||
/* Iterate over the rest of the nodes in the skip list */
|
||||
u=4;
|
||||
@ -1009,7 +1009,7 @@ test_skiplist_find(void)
|
||||
/* Check for trying to locate non-existent item */
|
||||
find_item=81;
|
||||
node=H5SL_find(slist,&find_item);
|
||||
VERIFY(node, NULL, "H5SL_find");
|
||||
CHECK_PTR_NULL(node, "H5SL_find");
|
||||
|
||||
/* Close the skip list */
|
||||
ret=H5SL_close(slist);
|
||||
@ -1040,7 +1040,7 @@ test_skiplist_add(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_UNSIGNED, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Insert objects into the skip list */
|
||||
for(u=0; u<10; u++) {
|
||||
@ -1051,11 +1051,11 @@ test_skiplist_add(void)
|
||||
/* Add the element with key==12 in the skip list */
|
||||
new_item=12;
|
||||
node=H5SL_add(slist,&new_item,&new_item);
|
||||
CHECK(node, NULL, "H5SL_add");
|
||||
CHECK_PTR(node, "H5SL_add");
|
||||
|
||||
/* Advance to next node in list */
|
||||
node=H5SL_next(node);
|
||||
CHECK(node, NULL, "H5SL_next");
|
||||
CHECK_PTR(node, "H5SL_next");
|
||||
|
||||
/* Iterate over the rest of the nodes in the skip list */
|
||||
u=2;
|
||||
@ -1102,7 +1102,7 @@ test_skiplist_destroy(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_INT, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Insert objects into the skip list */
|
||||
for(u=0; u<NUM_ELEMS; u++) {
|
||||
@ -1138,7 +1138,7 @@ test_skiplist_free(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_INT, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Insert objects into the skip list */
|
||||
for(u=0; u<NUM_ELEMS; u++) {
|
||||
@ -1210,8 +1210,8 @@ static herr_t test_tfs_iter(void *_obj, void *key, void *_udata) {
|
||||
test_tfs_it_ud_t *udata = (test_tfs_it_ud_t *)_udata;
|
||||
|
||||
/* Check consistency */
|
||||
VERIFY((void *)&obj->idx, key, "obj->idx");
|
||||
VERIFY(obj, &udata->obj_list->list[obj->idx], "obj_list->list[obj->idx]");
|
||||
CHECK_PTR_EQ((void *)&obj->idx, key, "obj->idx");
|
||||
CHECK_PTR_EQ(obj, &udata->obj_list->list[obj->idx], "obj_list->list[obj->idx]");
|
||||
|
||||
/* Increment number of calls */
|
||||
udata->ncalls++;
|
||||
@ -1236,8 +1236,8 @@ static htri_t test_tfs_free(void *_obj, void *key, void *_obj_list) {
|
||||
htri_t ret_value;
|
||||
|
||||
/* Check consistency */
|
||||
VERIFY((void *)&obj->idx, key, "obj->idx");
|
||||
VERIFY(obj, &obj_list->list[obj->idx], "obj_list->list[obj->idx]");
|
||||
CHECK_PTR_EQ((void *)&obj->idx, key, "obj->idx");
|
||||
CHECK_PTR_EQ(obj, &obj_list->list[obj->idx], "obj_list->list[obj->idx]");
|
||||
|
||||
/* Mark this object as freed (to make sure it isn't recursively freed, that
|
||||
* is not something we support, we will undo this if we decide later not to
|
||||
@ -1269,7 +1269,7 @@ static htri_t test_tfs_free(void *_obj, void *key, void *_obj_list) {
|
||||
else {
|
||||
/* Remove the object */
|
||||
obj_ret = (test_tfs_obj_t *)H5SL_remove(obj_list->slist, &j);
|
||||
CHECK(obj_ret, NULL, "H5SL_remove");
|
||||
CHECK_PTR(obj_ret, "H5SL_remove");
|
||||
obj_ret->nfrees++;
|
||||
obj_list->nobjs_rem--;
|
||||
} /* end else */
|
||||
@ -1324,7 +1324,7 @@ test_skiplist_try_free_safe(void)
|
||||
|
||||
/* Create a skip list */
|
||||
obj_list.slist = H5SL_create(H5SL_TYPE_INT, NULL);
|
||||
CHECK(obj_list.slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(obj_list.slist, "H5SL_create");
|
||||
|
||||
/* Init obj_list.list */
|
||||
obj_list.list = list;
|
||||
@ -1396,7 +1396,7 @@ test_skiplist_less(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_UNSIGNED, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Insert objects into the skip list */
|
||||
for(u=0; u<10; u++) {
|
||||
@ -1430,7 +1430,7 @@ test_skiplist_less(void)
|
||||
VERIFY(*found_item,5,"H5SL_less");
|
||||
find_item=4;
|
||||
found_item=(unsigned *)H5SL_less(slist,&find_item);
|
||||
VERIFY(found_item,NULL,"H5SL_less");
|
||||
CHECK_PTR_NULL(found_item, "H5SL_less");
|
||||
|
||||
/* Close the skip list */
|
||||
ret=H5SL_close(slist);
|
||||
@ -1460,7 +1460,7 @@ test_skiplist_greater(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_UNSIGNED, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Insert objects into the skip list */
|
||||
for(u = 0; u < 10; u++) {
|
||||
@ -1488,7 +1488,7 @@ test_skiplist_greater(void)
|
||||
VERIFY(*found_item, 90, "H5SL_greater");
|
||||
find_item = 100;
|
||||
found_item = (unsigned *)H5SL_greater(slist, &find_item);
|
||||
VERIFY(found_item, NULL, "H5SL_greater");
|
||||
CHECK_PTR_NULL(found_item, "H5SL_greater");
|
||||
find_item = 6;
|
||||
found_item = (unsigned *)H5SL_greater(slist, &find_item);
|
||||
VERIFY(*found_item, 10, "H5SL_greater");
|
||||
@ -1525,7 +1525,7 @@ test_skiplist_below(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_UNSIGNED, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Insert objects into the skip list */
|
||||
for(u = 0; u < 10; u++) {
|
||||
@ -1536,44 +1536,44 @@ test_skiplist_below(void)
|
||||
/* Check for exact match of items in various positions */
|
||||
find_item = 20;
|
||||
node = H5SL_below(slist, &find_item);
|
||||
CHECK(node, NULL, "H5SL_below");
|
||||
CHECK_PTR(node, "H5SL_below");
|
||||
found_item = (unsigned *)H5SL_item(node);
|
||||
VERIFY(*found_item, find_item, "H5SL_below");
|
||||
find_item = 90;
|
||||
node = H5SL_below(slist, &find_item);
|
||||
CHECK(node, NULL, "H5SL_below");
|
||||
CHECK_PTR(node, "H5SL_below");
|
||||
found_item = (unsigned *)H5SL_item(node);
|
||||
VERIFY(*found_item, find_item, "H5SL_below");
|
||||
find_item = 5;
|
||||
node = H5SL_below(slist, &find_item);
|
||||
CHECK(node, NULL, "H5SL_below");
|
||||
CHECK_PTR(node, "H5SL_below");
|
||||
found_item = (unsigned *)H5SL_item(node);
|
||||
VERIFY(*found_item, find_item, "H5SL_below");
|
||||
|
||||
/* Find item less than a missing key, in various positions */
|
||||
find_item = 19;
|
||||
node = H5SL_below(slist, &find_item);
|
||||
CHECK(node, NULL, "H5SL_below");
|
||||
CHECK_PTR(node, "H5SL_below");
|
||||
found_item = (unsigned *)H5SL_item(node);
|
||||
VERIFY(*found_item, 15, "H5SL_below");
|
||||
find_item = 89;
|
||||
node = H5SL_below(slist, &find_item);
|
||||
CHECK(node, NULL, "H5SL_below");
|
||||
CHECK_PTR(node, "H5SL_below");
|
||||
found_item = (unsigned *)H5SL_item(node);
|
||||
VERIFY(*found_item, 80, "H5SL_below");
|
||||
find_item = 100;
|
||||
node = H5SL_below(slist, &find_item);
|
||||
CHECK(node, NULL, "H5SL_below");
|
||||
CHECK_PTR(node, "H5SL_below");
|
||||
found_item = (unsigned *)H5SL_item(node);
|
||||
VERIFY(*found_item, 90, "H5SL_below");
|
||||
find_item = 9;
|
||||
node = H5SL_below(slist, &find_item);
|
||||
CHECK(node, NULL, "H5SL_below");
|
||||
CHECK_PTR(node, "H5SL_below");
|
||||
found_item = (unsigned *)H5SL_item(node);
|
||||
VERIFY(*found_item, 5, "H5SL_below");
|
||||
find_item = 4;
|
||||
node = (H5SL_node_t *)H5SL_less(slist, &find_item);
|
||||
VERIFY(node, NULL, "H5SL_below");
|
||||
CHECK_PTR_NULL(node, "H5SL_below");
|
||||
|
||||
/* Close the skip list */
|
||||
ret = H5SL_close(slist);
|
||||
@ -1604,7 +1604,7 @@ test_skiplist_above(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_UNSIGNED, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Insert objects into the skip list */
|
||||
for(u = 0; u < 10; u++) {
|
||||
@ -1615,42 +1615,42 @@ test_skiplist_above(void)
|
||||
/* Check for exact match of items in various positions */
|
||||
find_item = 20;
|
||||
node = H5SL_above(slist, &find_item);
|
||||
CHECK(node, NULL, "H5SL_above");
|
||||
CHECK_PTR(node, "H5SL_above");
|
||||
found_item = (unsigned *)H5SL_item(node);
|
||||
VERIFY(*found_item, find_item, "H5SL_above");
|
||||
find_item = 90;
|
||||
node = H5SL_above(slist, &find_item);
|
||||
CHECK(node, NULL, "H5SL_above");
|
||||
CHECK_PTR(node, "H5SL_above");
|
||||
found_item = (unsigned *)H5SL_item(node);
|
||||
VERIFY(*found_item, find_item, "H5SL_above");
|
||||
find_item = 5;
|
||||
node = H5SL_above(slist, &find_item);
|
||||
CHECK(node, NULL, "H5SL_above");
|
||||
CHECK_PTR(node, "H5SL_above");
|
||||
found_item = (unsigned *)H5SL_item(node);
|
||||
VERIFY(*found_item, find_item, "H5SL_above");
|
||||
|
||||
/* Find item greater than a missing key, in various positions */
|
||||
find_item = 19;
|
||||
node = H5SL_above(slist, &find_item);
|
||||
CHECK(node, NULL, "H5SL_above");
|
||||
CHECK_PTR(node, "H5SL_above");
|
||||
found_item = (unsigned *)H5SL_item(node);
|
||||
VERIFY(*found_item, 20, "H5SL_above");
|
||||
find_item = 89;
|
||||
node = H5SL_above(slist, &find_item);
|
||||
CHECK(node, NULL, "H5SL_above");
|
||||
CHECK_PTR(node, "H5SL_above");
|
||||
found_item = (unsigned *)H5SL_item(node);
|
||||
VERIFY(*found_item, 90, "H5SL_above");
|
||||
find_item = 100;
|
||||
node = H5SL_above(slist, &find_item);
|
||||
VERIFY(node, NULL, "H5SL_above");
|
||||
CHECK_PTR_NULL(node, "H5SL_above");
|
||||
find_item = 6;
|
||||
node = H5SL_above(slist, &find_item);
|
||||
CHECK(node, NULL, "H5SL_above");
|
||||
CHECK_PTR(node, "H5SL_above");
|
||||
found_item = (unsigned *)H5SL_item(node);
|
||||
VERIFY(*found_item, 10, "H5SL_above");
|
||||
find_item = 4;
|
||||
node = H5SL_above(slist, &find_item);
|
||||
CHECK(node, NULL, "H5SL_above");
|
||||
CHECK_PTR(node, "H5SL_above");
|
||||
found_item = (unsigned *)H5SL_item(node);
|
||||
VERIFY(*found_item, 5, "H5SL_above");
|
||||
|
||||
@ -1681,7 +1681,7 @@ test_skiplist_remove_first(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_UNSIGNED, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Insert objects into the skip list */
|
||||
for(u = 0; u < 10; u++) {
|
||||
@ -1697,7 +1697,7 @@ test_skiplist_remove_first(void)
|
||||
|
||||
/* Check for removing object from empty list */
|
||||
found_item = (unsigned *)H5SL_remove_first(slist);
|
||||
VERIFY(found_item, NULL, "H5SL_remove_first");
|
||||
CHECK_PTR_NULL(found_item, "H5SL_remove_first");
|
||||
|
||||
/* Close the skip list */
|
||||
ret = H5SL_close(slist);
|
||||
@ -1725,7 +1725,7 @@ test_skiplist_remove_first_many(void)
|
||||
|
||||
/* Create a skip list */
|
||||
slist = H5SL_create(H5SL_TYPE_INT, NULL);
|
||||
CHECK(slist, NULL, "H5SL_create");
|
||||
CHECK_PTR(slist, "H5SL_create");
|
||||
|
||||
/* Insert objects into the skip list */
|
||||
for(u = 0; u < NUM_ELEMS; u++) {
|
||||
@ -1742,7 +1742,7 @@ test_skiplist_remove_first_many(void)
|
||||
|
||||
/* Check for removing object from empty list */
|
||||
found_item = (int *)H5SL_remove_first(slist);
|
||||
VERIFY(found_item, NULL, "H5SL_remove_first");
|
||||
CHECK_PTR_NULL(found_item, "H5SL_remove_first");
|
||||
|
||||
/* Close the skip list */
|
||||
ret = H5SL_close(slist);
|
||||
|
18
test/ttst.c
18
test/ttst.c
@ -157,7 +157,7 @@ test_tst_create(void)
|
||||
|
||||
/* Try creating a TST */
|
||||
tree=H5ST_create();
|
||||
CHECK(tree, NULL, "H5ST_create");
|
||||
CHECK_PTR(tree, "H5ST_create");
|
||||
|
||||
/* Try closing a real tree */
|
||||
ret=H5ST_close(tree);
|
||||
@ -186,7 +186,7 @@ test_tst_insert(void)
|
||||
|
||||
/* Create the TST */
|
||||
tree=H5ST_create();
|
||||
CHECK(tree, NULL, "H5ST_create");
|
||||
CHECK_PTR(tree, "H5ST_create");
|
||||
|
||||
/* Insert unique words into TST, in random order */
|
||||
for(u=0; u<num_uniq_words; u++) {
|
||||
@ -202,13 +202,13 @@ test_tst_insert(void)
|
||||
|
||||
/* Check that the value "payloads" are correct */
|
||||
found=H5ST_find(tree,uniq_words[u]);
|
||||
CHECK(found, NULL, "H5ST_find");
|
||||
CHECK_PTR(found, "H5ST_find");
|
||||
|
||||
if(HDstrcmp((const char *)found->eqkid,uniq_words[u]))
|
||||
TestErrPrintf("%d: TST node values don't match!, found->eqkid=%s, uniq_words[%u]=%s\n",__LINE__,(char *)found->eqkid,(unsigned)u,uniq_words[u]);
|
||||
|
||||
obj=H5ST_locate(tree,uniq_words[u]);
|
||||
CHECK(obj, NULL, "H5ST_locate");
|
||||
CHECK_PTR(obj, "H5ST_locate");
|
||||
|
||||
if(HDstrcmp((const char *)obj,uniq_words[u]))
|
||||
TestErrPrintf("%d: TST objects don't match!, obj=%s, uniq_words[%u]=%s\n",__LINE__,(char *)obj,(unsigned)u,uniq_words[u]);
|
||||
@ -246,7 +246,7 @@ test_tst_iterate(void)
|
||||
|
||||
/* Create the TST */
|
||||
tree=H5ST_create();
|
||||
CHECK(tree, NULL, "H5ST_create");
|
||||
CHECK_PTR(tree, "H5ST_create");
|
||||
|
||||
/* Insert unique words into TST, in random order */
|
||||
for(u=0; u<num_uniq_words; u++) {
|
||||
@ -256,7 +256,7 @@ test_tst_iterate(void)
|
||||
|
||||
/* Use findfirst/findnext calls to iterate through TST */
|
||||
found=H5ST_findfirst(tree);
|
||||
CHECK(found, NULL, "H5ST_findfirst");
|
||||
CHECK_PTR(found, "H5ST_findfirst");
|
||||
u=0;
|
||||
do {
|
||||
/* Check that the strings in the TST are in the correct order */
|
||||
@ -294,7 +294,7 @@ test_tst_remove(void)
|
||||
|
||||
/* Create the TST */
|
||||
tree=H5ST_create();
|
||||
CHECK(tree, NULL, "H5ST_create");
|
||||
CHECK_PTR(tree, "H5ST_create");
|
||||
|
||||
/* Insert unique words into TST, in random order */
|
||||
for(u=0; u<num_uniq_words; u++) {
|
||||
@ -305,7 +305,7 @@ test_tst_remove(void)
|
||||
/* Remove strings from TST in random order */
|
||||
for(u=0; u<num_uniq_words; u++) {
|
||||
obj=H5ST_remove(tree,rand_uniq_words[u]);
|
||||
CHECK(obj, NULL, "H5ST_remove");
|
||||
CHECK_PTR(obj, "H5ST_remove");
|
||||
|
||||
/* Check that the correct string was removed from TST */
|
||||
if(HDstrcmp((const char *)obj,rand_uniq_words[u]))
|
||||
@ -326,7 +326,7 @@ test_tst_remove(void)
|
||||
for(u=0; u<num_uniq_words; u++) {
|
||||
/* Get the pointer to the node to delete */
|
||||
found=H5ST_find(tree,rand_uniq_words[u]);
|
||||
CHECK(found, NULL, "H5ST_find");
|
||||
CHECK_PTR(found, "H5ST_find");
|
||||
|
||||
/* Check that the correct object will be removed from TST */
|
||||
if(HDstrcmp((const char *)found->eqkid,rand_uniq_words[u]))
|
||||
|
@ -1015,9 +1015,9 @@ test_vltypes_compound_vlen_vlen(void)
|
||||
|
||||
/* Allocate and initialize VL data to write */
|
||||
wdata = (s1 *)HDmalloc(sizeof(s1) * SPACE3_DIM1);
|
||||
CHECK(wdata, NULL, "HDmalloc");
|
||||
CHECK_PTR(wdata, "HDmalloc");
|
||||
rdata = (s1 *)HDmalloc(sizeof(s1) * SPACE3_DIM1);
|
||||
CHECK(rdata, NULL, "HDmalloc");
|
||||
CHECK_PTR(rdata, "HDmalloc");
|
||||
for(i = 0; i < SPACE3_DIM1; i++) {
|
||||
wdata[i].i = (int)(i * 10);
|
||||
wdata[i].f = (float)(i * 20) / 3.0F;
|
||||
@ -2503,7 +2503,7 @@ test_vltypes_fill_value(void)
|
||||
|
||||
/* Allocate space for the buffer to read data */
|
||||
rbuf = (dtype1_struct *)HDmalloc(SPACE4_DIM_LARGE * sizeof(dtype1_struct));
|
||||
CHECK(rbuf, NULL, "HDmalloc");
|
||||
CHECK_PTR(rbuf, "HDmalloc");
|
||||
|
||||
|
||||
/* Create the small & large dataspaces to use */
|
||||
|
@ -115,14 +115,17 @@ void parse_command_line(int argc,
|
||||
default:
|
||||
usage();
|
||||
h5diff_exit(EXIT_FAILURE);
|
||||
break;
|
||||
|
||||
case 'h':
|
||||
usage();
|
||||
h5diff_exit(EXIT_SUCCESS);
|
||||
break;
|
||||
|
||||
case 'V':
|
||||
print_version(h5tools_getprogname());
|
||||
h5diff_exit(EXIT_SUCCESS);
|
||||
break;
|
||||
|
||||
case 'v':
|
||||
opts->m_verbose = 1;
|
||||
|
@ -179,9 +179,11 @@ parse_command_line (int argc, const char *argv[])
|
||||
case 'h':
|
||||
usage (h5tools_getprogname());
|
||||
leave (EXIT_SUCCESS);
|
||||
break;
|
||||
case 'V':
|
||||
print_version (h5tools_getprogname());
|
||||
leave (EXIT_SUCCESS);
|
||||
break;
|
||||
case '?':
|
||||
default:
|
||||
usage (h5tools_getprogname());
|
||||
@ -198,10 +200,6 @@ parse_command_line (int argc, const char *argv[])
|
||||
* Return: Success: 0
|
||||
* Failure: 1
|
||||
*
|
||||
* Programmer:
|
||||
*
|
||||
* Modifications:
|
||||
*
|
||||
*-------------------------------------------------------------------------
|
||||
*/
|
||||
int
|
||||
|
@ -2709,6 +2709,7 @@ main(int argc, const char *argv[])
|
||||
case 'h': /* --help */
|
||||
usage();
|
||||
leave(EXIT_SUCCESS);
|
||||
break;
|
||||
|
||||
case 'a': /* --address */
|
||||
address_g = TRUE;
|
||||
@ -2759,6 +2760,7 @@ main(int argc, const char *argv[])
|
||||
case 'V': /* --version */
|
||||
print_version(h5tools_getprogname());
|
||||
leave(EXIT_SUCCESS);
|
||||
break;
|
||||
|
||||
case 'x': /* --hexdump */
|
||||
hexdump_g = TRUE;
|
||||
|
@ -42,7 +42,7 @@ static int aux_copy_obj(hid_t dcpl_id, /* dataset creation property list */
|
||||
H5D_layout_t layout;
|
||||
int rank; /* rank of dataset */
|
||||
hsize_t chsize[64]; /* chunk size in elements */
|
||||
unsigned int i, j;
|
||||
unsigned int i;
|
||||
|
||||
/* get information about input filters */
|
||||
if ((nfilters = H5Pget_nfilters(dcpl_id)) < 0)
|
||||
@ -240,7 +240,7 @@ int apply_filters(const char* name, /* object name from traverse list */
|
||||
int nfilters; /* number of filters in DCPL */
|
||||
hsize_t chsize[64]; /* chunk size in elements */
|
||||
H5D_layout_t layout;
|
||||
int i, j;
|
||||
int i;
|
||||
pack_info_t obj;
|
||||
pack_info_t filtobj;
|
||||
|
||||
|
@ -129,6 +129,7 @@ parse_command_line(int argc, const char *argv[], param_t *parms)
|
||||
case 'h':
|
||||
usage();
|
||||
leave(EXIT_SUCCESS);
|
||||
break;
|
||||
|
||||
/* Create objects with the latest version of the format */
|
||||
case 'l':
|
||||
@ -149,6 +150,7 @@ parse_command_line(int argc, const char *argv[], param_t *parms)
|
||||
case 'V':
|
||||
print_version(h5tools_getprogname());
|
||||
leave(EXIT_SUCCESS);
|
||||
break;
|
||||
|
||||
/* Bad command line argument */
|
||||
default:
|
||||
|
@ -52,10 +52,7 @@ if HAVE_SHARED_CONDITIONAL
|
||||
# Build it as shared library if configure is enabled for shared library.
|
||||
noinst_LTLIBRARIES=libdynlibdiff.la
|
||||
libdynlibdiff_la_SOURCES=dynlib_diff.c
|
||||
libdynlibdiff_la_LDFLAGS = -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
|
||||
libdynlibdiff.la: $(libdynlibdiff_la_OBJECTS) $(libdynlibdiff_la_DEPENDENCIES) $(EXTRA_libdynlibdiff_la_DEPENDENCIES)
|
||||
$(AM_V_CCLD)$(libdynlibdiff_la_LINK) $(am_libdynlibdiff_la_rpath) $(libdynlibdiff_la_OBJECTS) $(libdynlibdiff_la_LIBADD)
|
||||
libdynlibdiff_la_LDFLAGS=$(AM_LDFLAGS) -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
endif
|
||||
|
||||
# Temporary files. *.h5 are generated by h5diff. They should
|
||||
|
@ -41,10 +41,7 @@ if HAVE_SHARED_CONDITIONAL
|
||||
# Build it as shared library if configure is enabled for shared library.
|
||||
noinst_LTLIBRARIES=libdynlibdump.la
|
||||
libdynlibdump_la_SOURCES=dynlib_dump.c
|
||||
libdynlibdump_la_LDFLAGS = -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
|
||||
libdynlibdump.la: $(libdynlibdump_la_OBJECTS) $(libdynlibdump_la_DEPENDENCIES) $(EXTRA_libdynlibdump_la_DEPENDENCIES)
|
||||
$(AM_V_CCLD)$(libdynlibdump_la_LINK) $(am_libdynlibdump_la_rpath) $(libdynlibdump_la_OBJECTS) $(libdynlibdump_la_LIBADD)
|
||||
libdynlibdump_la_LDFLAGS=$(AM_LDFLAGS) -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
endif
|
||||
|
||||
# Temporary files. *.h5 are generated by h5dumpgentest. They should
|
||||
|
@ -14,7 +14,7 @@ HDF5-DIAG: Error detected in HDF5 (version (number)) thread (IDs):
|
||||
#004: (file name) line (number) in H5Z_pipeline(): required filter 'filter_fail_test' is not registered
|
||||
major: Data filters
|
||||
minor: Read failed
|
||||
#005: (file name) line (number) in H5PL_load(): required dynamically loaded plugin filter '312' is not available
|
||||
#005: (file name) line (number) in H5PL_load(): filter plugins disabled
|
||||
major: Plugin for dynamically loaded library
|
||||
minor: Unable to load metadata into cache
|
||||
h5dump error: unable to print data
|
||||
|
@ -38,10 +38,7 @@ if HAVE_SHARED_CONDITIONAL
|
||||
# Build it as shared library if configure is enabled for shared library.
|
||||
noinst_LTLIBRARIES=libdynlibls.la
|
||||
libdynlibls_la_SOURCES=dynlib_ls.c
|
||||
libdynlibls_la_LDFLAGS = -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
|
||||
libdynlibls.la: $(libdynlibls_la_OBJECTS) $(libdynlibls_la_DEPENDENCIES) $(EXTRA_libdynlibls_la_DEPENDENCIES)
|
||||
$(AM_V_CCLD)$(libdynlibls_la_LINK) $(am_libdynlibls_la_rpath) $(libdynlibls_la_OBJECTS) $(libdynlibls_la_LIBADD)
|
||||
libdynlibls_la_LDFLAGS=$(AM_LDFLAGS) -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
endif
|
||||
|
||||
|
||||
|
@ -48,13 +48,8 @@ if HAVE_SHARED_CONDITIONAL
|
||||
noinst_LTLIBRARIES=libdynlibadd.la libdynlibvers.la
|
||||
libdynlibadd_la_SOURCES=dynlib_rpk.c
|
||||
libdynlibvers_la_SOURCES=dynlib_vrpk.c
|
||||
libdynlibadd_la_LDFLAGS = -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
libdynlibvers_la_LDFLAGS = -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
|
||||
libdynlibadd.la: $(libdynlibadd_la_OBJECTS) $(libdynlibadd_la_DEPENDENCIES) $(EXTRA_libdynlibadd_la_DEPENDENCIES)
|
||||
$(AM_V_CCLD)$(libdynlibadd_la_LINK) $(am_libdynlibadd_la_rpath) $(libdynlibadd_la_OBJECTS) $(libdynlibadd_la_LIBADD)
|
||||
libdynlibvers.la: $(libdynlibvers_la_OBJECTS) $(libdynlibvers_la_DEPENDENCIES) $(EXTRA_libdynlibvers_la_DEPENDENCIES)
|
||||
$(AM_V_CCLD)$(libdynlibvers_la_LINK) $(am_libdynlibvers_la_rpath) $(libdynlibvers_la_OBJECTS) $(libdynlibvers_la_LIBADD)
|
||||
libdynlibadd_la_LDFLAGS=$(AM_LDFLAGS) -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
libdynlibvers_la_LDFLAGS=$(AM_LDFLAGS) -avoid-version -module -shared -export-dynamic -rpath /nowhere
|
||||
endif
|
||||
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user