summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--test/.distdep140
-rw-r--r--test/Makefile.in8
-rw-r--r--test/dsets.c2
-rw-r--r--test/tattr.c32
-rw-r--r--test/testhdf5.c1
-rw-r--r--test/testhdf5.h2
-rw-r--r--test/th5s.c66
-rw-r--r--test/tselect.c143
8 files changed, 282 insertions, 112 deletions
diff --git a/test/.distdep b/test/.distdep
index e99e3c0..78faef0 100644
--- a/test/.distdep
+++ b/test/.distdep
@@ -1,27 +1,9 @@
-tattr.o: \
- tattr.c \
+testhdf5.o: \
+ testhdf5.c \
testhdf5.h \
../src/H5private.h \
../src/H5public.h \
- ../src/H5config.h \
- ../src/H5Eprivate.h \
- ../src/H5Epublic.h \
- ../src/H5Ipublic.h \
- ../src/hdf5.h \
- ../src/H5Apublic.h \
- ../src/H5ACpublic.h \
- ../src/H5Bpublic.h \
- ../src/H5Dpublic.h \
- ../src/H5Fpublic.h \
- ../src/H5Gpublic.h \
- ../src/H5HGpublic.h \
- ../src/H5HLpublic.h \
- ../src/H5MFpublic.h \
- ../src/H5MMpublic.h \
- ../src/H5Opublic.h \
- ../src/H5Ppublic.h \
- ../src/H5Zpublic.h \
- ../src/H5Spublic.h
+ ../src/H5config.h
tfile.o: \
tfile.c \
testhdf5.h \
@@ -124,33 +106,34 @@ tstab.o: \
../src/H5Tpublic.h \
../src/H5Sprivate.h \
../src/H5Spublic.h
-th5s.o: \
- th5s.c \
- testhdf5.h \
- ../src/H5private.h \
+dtypes.o: \
+ dtypes.c \
+ ../src/hdf5.h \
../src/H5public.h \
../src/H5config.h \
- ../src/H5Eprivate.h \
- ../src/H5Epublic.h \
../src/H5Ipublic.h \
- ../src/H5Bprivate.h \
+ ../src/H5Apublic.h \
+ ../src/H5ACpublic.h \
../src/H5Bpublic.h \
- ../src/H5Fprivate.h \
- ../src/H5Fpublic.h \
../src/H5Dpublic.h \
- ../src/H5Sprivate.h \
- ../src/H5Spublic.h \
- ../src/H5Gprivate.h \
+ ../src/H5Epublic.h \
+ ../src/H5Fpublic.h \
../src/H5Gpublic.h \
- ../src/H5Oprivate.h \
+ ../src/H5HGpublic.h \
+ ../src/H5HLpublic.h \
+ ../src/H5MFpublic.h \
+ ../src/H5MMpublic.h \
../src/H5Opublic.h \
+ ../src/H5Ppublic.h \
+ ../src/H5Zpublic.h \
+ ../src/H5Spublic.h \
+ ../src/H5Tpublic.h \
+ ../src/H5Tpkg.h \
../src/H5HGprivate.h \
- ../src/H5HGpublic.h \
+ ../src/H5Fprivate.h \
+ ../src/H5private.h \
../src/H5Tprivate.h \
- ../src/H5Tpublic.h \
- ../src/H5Zprivate.h \
- ../src/H5Zpublic.h \
- ../src/H5Pprivate.h
+ ../src/H5Gprivate.h
hyperslab.o: \
hyperslab.c \
../src/H5private.h \
@@ -182,8 +165,8 @@ istore.o: \
../src/H5Tprivate.h \
../src/H5Tpublic.h \
../src/H5Sprivate.h
-dsets.o: \
- dsets.c \
+cmpd_dset.o: \
+ cmpd_dset.c \
../src/hdf5.h \
../src/H5public.h \
../src/H5config.h \
@@ -202,8 +185,7 @@ dsets.o: \
../src/H5Opublic.h \
../src/H5Ppublic.h \
../src/H5Zpublic.h \
- ../src/H5Spublic.h \
- ../src/H5Tpublic.h
+ ../src/H5Spublic.h
extend.o: \
extend.c \
../src/hdf5.h \
@@ -391,17 +373,44 @@ bittests.o: \
../src/H5Gprivate.h \
../src/H5Gpublic.h \
../src/H5Bprivate.h
-cmpd_dset.o: \
- cmpd_dset.c \
- ../src/hdf5.h \
+tattr.o: \
+ tattr.c \
+ testhdf5.h \
+ ../src/H5private.h \
../src/H5public.h \
../src/H5config.h \
+ ../src/H5Eprivate.h \
+ ../src/H5Epublic.h \
../src/H5Ipublic.h \
+ ../src/hdf5.h \
../src/H5Apublic.h \
../src/H5ACpublic.h \
../src/H5Bpublic.h \
../src/H5Dpublic.h \
+ ../src/H5Fpublic.h \
+ ../src/H5Gpublic.h \
+ ../src/H5HGpublic.h \
+ ../src/H5HLpublic.h \
+ ../src/H5MFpublic.h \
+ ../src/H5MMpublic.h \
+ ../src/H5Opublic.h \
+ ../src/H5Ppublic.h \
+ ../src/H5Zpublic.h \
+ ../src/H5Spublic.h
+tselect.o: \
+ tselect.c \
+ testhdf5.h \
+ ../src/H5private.h \
+ ../src/H5public.h \
+ ../src/H5config.h \
+ ../src/H5Eprivate.h \
../src/H5Epublic.h \
+ ../src/H5Ipublic.h \
+ ../src/hdf5.h \
+ ../src/H5Apublic.h \
+ ../src/H5ACpublic.h \
+ ../src/H5Bpublic.h \
+ ../src/H5Dpublic.h \
../src/H5Fpublic.h \
../src/H5Gpublic.h \
../src/H5HGpublic.h \
@@ -412,14 +421,35 @@ cmpd_dset.o: \
../src/H5Ppublic.h \
../src/H5Zpublic.h \
../src/H5Spublic.h
-testhdf5.o: \
- testhdf5.c \
+th5s.o: \
+ th5s.c \
testhdf5.h \
../src/H5private.h \
../src/H5public.h \
- ../src/H5config.h
-dtypes.o: \
- dtypes.c \
+ ../src/H5config.h \
+ ../src/H5Eprivate.h \
+ ../src/H5Epublic.h \
+ ../src/H5Ipublic.h \
+ ../src/H5Bprivate.h \
+ ../src/H5Bpublic.h \
+ ../src/H5Fprivate.h \
+ ../src/H5Fpublic.h \
+ ../src/H5Dpublic.h \
+ ../src/H5Sprivate.h \
+ ../src/H5Spublic.h \
+ ../src/H5Gprivate.h \
+ ../src/H5Gpublic.h \
+ ../src/H5Oprivate.h \
+ ../src/H5Opublic.h \
+ ../src/H5HGprivate.h \
+ ../src/H5HGpublic.h \
+ ../src/H5Tprivate.h \
+ ../src/H5Tpublic.h \
+ ../src/H5Zprivate.h \
+ ../src/H5Zpublic.h \
+ ../src/H5Pprivate.h
+dsets.o: \
+ dsets.c \
../src/hdf5.h \
../src/H5public.h \
../src/H5config.h \
@@ -439,10 +469,4 @@ dtypes.o: \
../src/H5Ppublic.h \
../src/H5Zpublic.h \
../src/H5Spublic.h \
- ../src/H5Tpublic.h \
- ../src/H5Tpkg.h \
- ../src/H5HGprivate.h \
- ../src/H5Fprivate.h \
- ../src/H5private.h \
- ../src/H5Tprivate.h \
- ../src/H5Gprivate.h
+ ../src/H5Tpublic.h
diff --git a/test/Makefile.in b/test/Makefile.in
index 8ddd2d8..d3aa02f 100644
--- a/test/Makefile.in
+++ b/test/Makefile.in
@@ -28,9 +28,9 @@ MOSTLYCLEAN=cmpd_dset.h5 dataset.h5 extend.h5 istore.h5 tfile1.h5 tfile2.h5 \
# source files and is used for things like dependencies, archiving, etc. The
# other source lists are for the individual tests, the files of which may
# overlap with other tests.
-TEST_SRC=testhdf5.c tattr.c tfile.c theap.c tmeta.c tohdr.c tstab.c th5s.c \
- dtypes.c hyperslab.c istore.c dsets.c cmpd_dset.c extend.c external.c \
- iopipe.c gheap.c shtype.c big.c links.c chunk.c bittests.c
+TEST_SRC=testhdf5.c tattr.c tfile.c theap.c tmeta.c tohdr.c tselect.c tstab.c \
+ th5s.c dtypes.c hyperslab.c istore.c dsets.c cmpd_dset.c extend.c \
+ external.c iopipe.c gheap.c shtype.c big.c links.c chunk.c bittests.c
TEST_OBJ=$(PROG_SRC:.c=.o)
# Private header files (not to be installed)...
@@ -47,7 +47,7 @@ timings _timings: $(TIMINGS)
done;
# How to build the programs...
-TESTHDF5_OBJ=testhdf5.o tattr.o tfile.o theap.o tmeta.o tohdr.o tstab.o th5s.o
+TESTHDF5_OBJ=testhdf5.o tattr.o tfile.o theap.o tmeta.o tohdr.o tselect.o tstab.o th5s.o
testhdf5: $(TESTHDF5_OBJ) ../src/libhdf5.a
$(CC) $(CFLAGS) -o $@ $(TESTHDF5_OBJ) ../src/libhdf5.a $(LIBS)
diff --git a/test/dsets.c b/test/dsets.c
index 9eccc2d..4d0477f 100644
--- a/test/dsets.c
+++ b/test/dsets.c
@@ -704,7 +704,7 @@ test_multiopen (hid_t file)
/* Get the size from the second handle */
if ((space = H5Dget_space (dset2))<0) goto error;
- if (H5Sget_dims (space, tmp_size, NULL)<0) goto error;
+ if (H5Sextent_dims (space, tmp_size, NULL)<0) goto error;
if (cur_size[0]!=tmp_size[0]) {
puts ("*FAILED*");
printf (" Got %d instead of %d!\n",
diff --git a/test/tattr.c b/test/tattr.c
index 4f4e7b4..b9cfa0f 100644
--- a/test/tattr.c
+++ b/test/tattr.c
@@ -412,10 +412,10 @@ test_attr_compound_read(void)
/* Verify Dataspace */
space=H5Aget_space(attr);
CHECK(space, FAIL, "H5Aget_space");
- rank=H5Sget_ndims(space);
- VERIFY(rank, ATTR4_RANK, "H5Sget_ndims");
- ret=H5Sget_dims(space,dims, NULL);
- CHECK(ret, FAIL, "H5Sget_dims");
+ rank=H5Sextent_ndims(space);
+ VERIFY(rank, ATTR4_RANK, "H5Sextent_ndims");
+ ret=H5Sextent_dims(space,dims, NULL);
+ CHECK(ret, FAIL, "H5Sextent_dims");
if(dims[0]!=ATTR4_DIM1) {
printf("attribute dimensions different: dims[0]=%d, should be %d\n",(int)dims[0],ATTR4_DIM1);
num_errs++;
@@ -797,10 +797,10 @@ test_attr_mult_read(void)
/* Verify Dataspace */
space=H5Aget_space(attr);
CHECK(space, FAIL, "H5Aget_space");
- rank=H5Sget_ndims(space);
- VERIFY(rank, ATTR1_RANK, "H5Sget_ndims");
- ret=H5Sget_dims(space,dims, NULL);
- CHECK(ret, FAIL, "H5Sget_dims");
+ rank=H5Sextent_ndims(space);
+ VERIFY(rank, ATTR1_RANK, "H5Sextent_ndims");
+ ret=H5Sextent_dims(space,dims, NULL);
+ CHECK(ret, FAIL, "H5Sextent_dims");
if(dims[0]!=ATTR1_DIM1) {
printf("attribute dimensions different: dims[0]=%d, should be %d\n",(int)dims[0],ATTR1_DIM1);
num_errs++;
@@ -858,10 +858,10 @@ test_attr_mult_read(void)
/* Verify Dataspace */
space=H5Aget_space(attr);
CHECK(space, FAIL, "H5Aget_space");
- rank=H5Sget_ndims(space);
- VERIFY(rank, ATTR2_RANK, "H5Sget_ndims");
- ret=H5Sget_dims(space,dims, NULL);
- CHECK(ret, FAIL, "H5Sget_dims");
+ rank=H5Sextent_ndims(space);
+ VERIFY(rank, ATTR2_RANK, "H5Sextent_ndims");
+ ret=H5Sextent_dims(space,dims, NULL);
+ CHECK(ret, FAIL, "H5Sextent_dims");
if(dims[0]!=ATTR2_DIM1) {
printf("attribute dimensions different: dims[0]=%d, should be %d\n",(int)dims[0],ATTR2_DIM1);
num_errs++;
@@ -924,10 +924,10 @@ test_attr_mult_read(void)
/* Verify Dataspace */
space=H5Aget_space(attr);
CHECK(space, FAIL, "H5Aget_space");
- rank=H5Sget_ndims(space);
- VERIFY(rank, ATTR3_RANK, "H5Sget_ndims");
- ret=H5Sget_dims(space,dims, NULL);
- CHECK(ret, FAIL, "H5Sget_dims");
+ rank=H5Sextent_ndims(space);
+ VERIFY(rank, ATTR3_RANK, "H5Sextent_ndims");
+ ret=H5Sextent_dims(space,dims, NULL);
+ CHECK(ret, FAIL, "H5Sextent_dims");
if(dims[0]!=ATTR3_DIM1) {
printf("attribute dimensions different: dims[0]=%d, should be %d\n",(int)dims[0],ATTR3_DIM1);
num_errs++;
diff --git a/test/testhdf5.c b/test/testhdf5.c
index fb880e0..0847e4d 100644
--- a/test/testhdf5.c
+++ b/test/testhdf5.c
@@ -169,6 +169,7 @@ main(int argc, char *argv[])
InitTest("stab", test_stab, cleanup_stab, "Symbol Tables");
InitTest("h5s", test_h5s, cleanup_h5s, "Dataspaces");
InitTest("attr", test_attr, cleanup_attr, "Attributes");
+ InitTest("select", test_select, cleanup_select, "Selections");
Verbosity = 4; /* Default Verbosity is Low */
H5version(&major, &minor, &release, &patch);
diff --git a/test/testhdf5.h b/test/testhdf5.h
index 04ee954..c455b2b 100644
--- a/test/testhdf5.h
+++ b/test/testhdf5.h
@@ -138,6 +138,7 @@ void test_h5t(void);
void test_h5s(void);
void test_h5d(void);
void test_attr(void);
+void test_select(void);
/* Prototypes for the cleanup routines */
void cleanup_metadata(void);
@@ -147,5 +148,6 @@ void cleanup_ohdr(void);
void cleanup_stab(void);
void cleanup_h5s(void);
void cleanup_attr(void);
+void cleanup_select(void);
#endif /* HDF5cleanup_H */
diff --git a/test/th5s.c b/test/th5s.c
index 5ac9ff1..000ca2f 100644
--- a/test/th5s.c
+++ b/test/th5s.c
@@ -108,14 +108,14 @@ test_h5s_basic(void)
CHECK(n, UFAIL, "H5Sextent_npoints");
VERIFY(n, SPACE1_DIM1 * SPACE1_DIM2 * SPACE1_DIM3, "H5Sextent_npoints");
- rank = H5Sget_ndims(sid1);
- CHECK(rank, UFAIL, "H5Sget_lrank");
- VERIFY(rank, SPACE1_RANK, "H5Sget_lrank");
+ rank = H5Sextent_ndims(sid1);
+ CHECK(rank, UFAIL, "H5Sextent_ndims");
+ VERIFY(rank, SPACE1_RANK, "H5Sextent_ndims");
- ret = H5Sget_dims(sid1, tdims, NULL);
- CHECK(ret, FAIL, "H5Sget_ldims");
+ ret = H5Sextent_dims(sid1, tdims, NULL);
+ CHECK(ret, FAIL, "H5Sextent_dims");
VERIFY(HDmemcmp(tdims, dims1, SPACE1_RANK * sizeof(unsigned)), 0,
- "H5Sget_ldims");
+ "H5Sextent_dims");
sid2 = H5Screate_simple(SPACE2_RANK, dims2, max2);
CHECK(sid2, FAIL, "H5Screate_simple");
@@ -125,16 +125,16 @@ test_h5s_basic(void)
VERIFY(n, SPACE2_DIM1 * SPACE2_DIM2 * SPACE2_DIM3 * SPACE2_DIM4,
"H5Sextent_npoints");
- rank = H5Sget_ndims(sid2);
- CHECK(rank, UFAIL, "H5Sget_lrank");
- VERIFY(rank, SPACE2_RANK, "H5Sget_lrank");
+ rank = H5Sextent_ndims(sid2);
+ CHECK(rank, UFAIL, "H5Sextent_ndims");
+ VERIFY(rank, SPACE2_RANK, "H5Sextent_ndims");
- ret = H5Sget_dims(sid2, tdims, tmax);
- CHECK(ret, FAIL, "H5Sget_ldims");
+ ret = H5Sextent_dims(sid2, tdims, tmax);
+ CHECK(ret, FAIL, "H5Sextent_dims");
VERIFY(HDmemcmp(tdims, dims2, SPACE2_RANK * sizeof(unsigned)), 0,
- "H5Sget_ldims");
+ "H5Sextent_dims");
VERIFY(HDmemcmp(tmax, max2, SPACE2_RANK * sizeof(unsigned)), 0,
- "H5Sget_ldims");
+ "H5Sextent_dims");
ret = H5Sclose(sid1);
CHECK(ret, FAIL, "H5Sclose");
@@ -178,12 +178,12 @@ test_h5s_scalar_write(void)
CHECK(n, UFAIL, "H5Sextent_npoints");
VERIFY(n, 1, "H5Sextent_npoints");
- rank = H5Sget_ndims(sid1);
- CHECK(rank, UFAIL, "H5Sget_lrank");
- VERIFY(rank, SPACE3_RANK, "H5Sget_lrank");
+ rank = H5Sextent_ndims(sid1);
+ CHECK(rank, UFAIL, "H5Sextent_ndims");
+ VERIFY(rank, SPACE3_RANK, "H5Sextent_ndims");
- ret = H5Sget_dims(sid1, tdims, NULL);
- VERIFY(ret, 0, "H5Sget_dims");
+ ret = H5Sextent_dims(sid1, tdims, NULL);
+ VERIFY(ret, 0, "H5Sextent_dims");
/* Create a dataset */
dataset=H5Dcreate(fid1,"Dataset1",H5T_NATIVE_UINT,sid1,H5P_DEFAULT);
@@ -240,12 +240,12 @@ test_h5s_scalar_read(void)
CHECK(n, UFAIL, "H5Sextent_npoints");
VERIFY(n, 1, "H5Sextent_npoints");
- rank = H5Sget_ndims(sid1);
- CHECK(rank, UFAIL, "H5Sget_lrank");
- VERIFY(rank, SPACE3_RANK, "H5Sget_lrank");
+ rank = H5Sextent_ndims(sid1);
+ CHECK(rank, UFAIL, "H5Sextent_ndims");
+ VERIFY(rank, SPACE3_RANK, "H5Sextent_ndims");
- ret = H5Sget_dims(sid1, tdims, NULL);
- VERIFY(ret, 0, "H5Sget_dims");
+ ret = H5Sextent_dims(sid1, tdims, NULL);
+ VERIFY(ret, 0, "H5Sextent_dims");
ret = H5Dread(dataset, H5T_NATIVE_UINT, H5S_ALL, H5S_ALL, H5P_DEFAULT, &rdata);
CHECK(ret, FAIL, "H5Dread");
@@ -317,12 +317,12 @@ test_h5s_compound_scalar_write(void)
CHECK(n, UFAIL, "H5Sextent_npoints");
VERIFY(n, 1, "H5Sextent_npoints");
- rank = H5Sget_ndims(sid1);
- CHECK(rank, UFAIL, "H5Sget_lrank");
- VERIFY(rank, SPACE3_RANK, "H5Sget_lrank");
+ rank = H5Sextent_ndims(sid1);
+ CHECK(rank, UFAIL, "H5Sextent_ndims");
+ VERIFY(rank, SPACE3_RANK, "H5Sextent_ndims");
- ret = H5Sget_dims(sid1, tdims, NULL);
- VERIFY(ret, 0, "H5Sget_dims");
+ ret = H5Sextent_dims(sid1, tdims, NULL);
+ VERIFY(ret, 0, "H5Sextent_dims");
/* Create a dataset */
dataset=H5Dcreate(fid1,"Dataset1",tid1,sid1,H5P_DEFAULT);
@@ -381,12 +381,12 @@ test_h5s_compound_scalar_read(void)
CHECK(n, UFAIL, "H5Sextent_npoints");
VERIFY(n, 1, "H5Sextent_npoints");
- rank = H5Sget_ndims(sid1);
- CHECK(rank, UFAIL, "H5Sget_lrank");
- VERIFY(rank, SPACE3_RANK, "H5Sget_lrank");
+ rank = H5Sextent_ndims(sid1);
+ CHECK(rank, UFAIL, "H5Sextent_ndims");
+ VERIFY(rank, SPACE3_RANK, "H5Sextent_ndims");
- ret = H5Sget_dims(sid1, tdims, NULL);
- VERIFY(ret, 0, "H5Sget_dims");
+ ret = H5Sextent_dims(sid1, tdims, NULL);
+ VERIFY(ret, 0, "H5Sextent_dims");
type=H5Dget_type(dataset);
CHECK(type, FAIL, "H5Dget_type");
diff --git a/test/tselect.c b/test/tselect.c
new file mode 100644
index 0000000..6b0d46d
--- /dev/null
+++ b/test/tselect.c
@@ -0,0 +1,143 @@
+/****************************************************************************
+ * NCSA HDF *
+ * Software Development Group *
+ * National Center for Supercomputing Applications *
+ * University of Illinois at Urbana-Champaign *
+ * 605 E. Springfield, Champaign IL 61820 *
+ * *
+ * For conditions of distribution and use, see the accompanying *
+ * hdf/COPYING file. *
+ * *
+ ****************************************************************************/
+
+#ifdef RCSID
+static char RcsId[] = "$Revision$";
+#endif
+
+/* $Id$ */
+
+/***********************************************************
+*
+* Test program: tselect
+*
+* Test the dataspace selection functionality
+*
+*************************************************************/
+
+#include <testhdf5.h>
+
+#include <hdf5.h>
+
+#define FILE "tselect.h5"
+
+/* 3-D dataset with fixed dimensions */
+#define SPACE1_NAME "Space1"
+#define SPACE1_RANK 3
+#define SPACE1_DIM1 3
+#define SPACE1_DIM2 15
+#define SPACE1_DIM3 13
+
+/* 2-D dataset with fixed dimensions */
+#define SPACE2_NAME "Space2"
+#define SPACE2_RANK 2
+#define SPACE2_DIM1 30
+#define SPACE2_DIM2 26
+
+/* 2-D dataset with fixed dimensions */
+#define SPACE3_NAME "Space3"
+#define SPACE3_RANK 2
+#define SPACE3_DIM1 15
+#define SPACE3_DIM2 26
+
+/****************************************************************
+**
+** test_select_hyper(): Test basic H5S (dataspace) selection code.
+** Tests hyperslabs of various sizes and dimensionalities.
+**
+****************************************************************/
+static void
+test_select_hyper(void)
+{
+ hid_t fid1; /* HDF5 File IDs */
+ hid_t dataset; /* Dataset ID */
+ hid_t group; /* Group ID */
+ hid_t sid1,sid2; /* Dataspace ID */
+ hid_t attr; /* Attribute ID */
+ hsize_t dims1[] = {SPACE1_DIM1, SPACE1_DIM2, SPACE1_DIM3};
+ hsize_t dims2[] = {SPACE2_DIM1, SPACE2_DIM2};
+ hsize_t dims3[] = {SPACE3_DIM1, SPACE3_DIM2};
+ uint8 *wbuf, /* buffer to write to disk */
+ *rbuf; /* buffer read from disk */
+ herr_t ret; /* Generic return value */
+
+ /* Output message about test being performed */
+ MESSAGE(5, ("Testing Hyperslab Selection Functions\n"));
+
+ /* Allocate write & read buffers */
+ wbuf=malloc(sizeof(uint8)*SPACE2_DIM1*SPACE2_DIM2);
+ rbuf=malloc(sizeof(uint8)*SPACE3_DIM1*SPACE3_DIM2);
+
+ /* Create file */
+ fid1 = H5Fcreate(FILE, H5F_ACC_TRUNC, H5P_DEFAULT, H5P_DEFAULT);
+ CHECK(fid1, FAIL, "H5Fcreate");
+
+ /* Create dataspace for dataset */
+ sid1 = H5Screate_simple(SPACE1_RANK, dims1, NULL);
+ CHECK(sid1, FAIL, "H5Screate_simple");
+
+ /* Create dataspace for memory */
+ sid2 = H5Screate_simple(SPACE2_RANK, dims2, NULL);
+ CHECK(sid2, FAIL, "H5Screate_simple");
+
+ /* Create a dataset */
+ dataset=H5Dcreate(fid1,"Dataset1",H5T_NATIVE_UCHAR,sid1,H5P_DEFAULT);
+
+ ret = H5Sclose(sid1);
+ CHECK(ret, FAIL, "H5Sclose");
+
+ /* Close Dataset */
+ ret = H5Dclose(dataset);
+ CHECK(ret, FAIL, "H5Dclose");
+
+ /* Close file */
+ ret = H5Fclose(fid1);
+ CHECK(ret, FAIL, "H5Fclose");
+} /* test_select_hyper() */
+
+/****************************************************************
+**
+** test_select(): Main H5S selection testing routine.
+**
+****************************************************************/
+void
+test_select(void)
+{
+ /* Output message about test being performed */
+ MESSAGE(5, ("Testing Selections\n"));
+
+ /* These next two tests use the same file information */
+ test_select_hyper(); /* Test basic H5S hyperslab selection code */
+
+} /* test_select() */
+
+
+/*-------------------------------------------------------------------------
+ * Function: cleanup_select
+ *
+ * Purpose: Cleanup temporary test files
+ *
+ * Return: none
+ *
+ * Programmer: Albert Cheng
+ * July 2, 1998
+ *
+ * Modifications:
+ *
+ *-------------------------------------------------------------------------
+ */
+void
+cleanup_select(void)
+{
+ remove(FILE);
+}
+