mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-03-31 17:10:47 +08:00
[svn-r2887] Purpose:
Backward compatibility additions Description: Test HDF5 v1.2 compatibility API functions (H5Tget_member_dims & H5Tinsert_array) when they are built into the library. Platforms tested: FreeBSD 4.1.1 (hawkwind)
This commit is contained in:
parent
0eb88a48d7
commit
bf9a8a39c8
@ -699,6 +699,9 @@ test_array_compound_array(void)
|
||||
typedef struct { /* Typedef for compound datatype */
|
||||
int i;
|
||||
float f[ARRAY1_DIM1];
|
||||
#ifdef WANT_H5_V1_2_COMPAT
|
||||
double d[ARRAY1_DIM1];
|
||||
#endif /* WANT_H5_V1_2_COMPAT */
|
||||
} s1_t;
|
||||
s1_t wdata[SPACE1_DIM1][ARRAY1_DIM1]; /* Information to write */
|
||||
s1_t rdata[SPACE1_DIM1][ARRAY1_DIM1]; /* Information read in */
|
||||
@ -710,8 +713,14 @@ test_array_compound_array(void)
|
||||
hid_t tid3; /* Nested Array Datatype ID */
|
||||
hsize_t sdims1[] = {SPACE1_DIM1};
|
||||
hsize_t tdims1[] = {ARRAY1_DIM1};
|
||||
#ifdef WANT_H5_V1_2_COMPAT
|
||||
size_t otdims1[] = {ARRAY1_DIM1};
|
||||
#endif /* WANT_H5_V1_2_COMPAT */
|
||||
int ndims; /* Array rank for reading */
|
||||
hsize_t rdims1[H5S_MAX_RANK]; /* Array dimensions for reading */
|
||||
#ifdef WANT_H5_V1_2_COMPAT
|
||||
size_t ordims1[H5S_MAX_RANK]; /* Array dimensions for reading */
|
||||
#endif /* WANT_H5_V1_2_COMPAT */
|
||||
int nmemb; /* Number of compound members */
|
||||
char *mname; /* Name of compound field */
|
||||
size_t off; /* Offset of compound field */
|
||||
@ -729,6 +738,10 @@ test_array_compound_array(void)
|
||||
wdata[i][j].i=i*10+j;
|
||||
for(k=0; k<ARRAY1_DIM1; k++)
|
||||
wdata[i][j].f[k]=i*10+j*2.5+k;
|
||||
#ifdef WANT_H5_V1_2_COMPAT
|
||||
for(k=0; k<ARRAY1_DIM1; k++)
|
||||
wdata[i][j].d[k]=i*15+j*7.5+k;
|
||||
#endif /* WANT_H5_V1_2_COMPAT */
|
||||
} /* end for */
|
||||
|
||||
/* Create file */
|
||||
@ -759,6 +772,13 @@ test_array_compound_array(void)
|
||||
ret=H5Tclose(tid3);
|
||||
CHECK(ret, FAIL, "H5Tclose");
|
||||
|
||||
/* Compatibility code to verify that the old API functions are still working */
|
||||
#ifdef WANT_H5_V1_2_COMPAT
|
||||
/* Insert float array field */
|
||||
ret = H5Tinsert_array (tid2, "d", HOFFSET(s1_t,d), ARRAY1_RANK,otdims1,NULL,H5T_NATIVE_DOUBLE);
|
||||
CHECK(ret, FAIL, "H5Tinsert_array");
|
||||
#endif /* WANT_H5_V1_2_COMPAT */
|
||||
|
||||
/* Create an array datatype to refer to */
|
||||
tid1 = H5Tarray_create (tid2,ARRAY1_RANK,tdims1,NULL);
|
||||
CHECK(tid1, FAIL, "H5Tarray_create");
|
||||
@ -826,7 +846,11 @@ test_array_compound_array(void)
|
||||
|
||||
/* Check the number of members */
|
||||
nmemb=H5Tget_nmembers(tid2);
|
||||
#ifdef WANT_H5_V1_2_COMPAT
|
||||
VERIFY(nmemb,3,"H5Tget_nmembers");
|
||||
#else /* WANT_H5_V1_2_COMPAT */
|
||||
VERIFY(nmemb,2,"H5Tget_nmembers");
|
||||
#endif /* WANT_H5_V1_2_COMPAT */
|
||||
|
||||
/* Check the 1st field's name */
|
||||
mname=H5Tget_member_name(tid2,0);
|
||||
@ -905,6 +929,34 @@ test_array_compound_array(void)
|
||||
ret=H5Tclose(mtid);
|
||||
CHECK(mtid, FAIL, "H5Tclose");
|
||||
|
||||
/* Compatibility code to verify that the old API functions are still working */
|
||||
#ifdef WANT_H5_V1_2_COMPAT
|
||||
/* Check the 3rd field's name */
|
||||
mname=H5Tget_member_name(tid2,2);
|
||||
CHECK(mname, NULL, "H5Tget_member_name");
|
||||
if(HDstrcmp(mname,"d")!=0) {
|
||||
num_errs++;
|
||||
printf("Compound field name doesn't match!, mname=%s\n",mname);
|
||||
} /* end if */
|
||||
free(mname);
|
||||
|
||||
/* Check the 3rd field's offset */
|
||||
off=H5Tget_member_offset(tid2,2);
|
||||
VERIFY(off, HOFFSET(s1_t,d), "H5Tget_member_offset");
|
||||
|
||||
/* Check the array rank */
|
||||
ndims=H5Tget_member_dims(tid2,2,ordims1,NULL);
|
||||
VERIFY(ndims,ARRAY1_RANK,"H5Tget_member_dims");
|
||||
|
||||
/* Check the array dimensions */
|
||||
for(i=0; i<ndims; i++)
|
||||
if(ordims1[i]!=otdims1[i]) {
|
||||
num_errs++;
|
||||
printf("Nested array dimension information doesn't match!, ordims1[%d]=%d, otdims1[%d]=%d\n",(int)i,(int)ordims1[i],(int)i,(int)otdims1[i]);
|
||||
continue;
|
||||
} /* end if */
|
||||
#endif /* WANT_H5_V1_2_COMPAT */
|
||||
|
||||
/* Close Compound Datatype */
|
||||
ret = H5Tclose(tid2);
|
||||
CHECK(ret, FAIL, "H5Tclose");
|
||||
|
Loading…
x
Reference in New Issue
Block a user