netcdf-c/nc_test4/tst_h_vl2.c
2018-12-06 15:27:32 -07:00

129 lines
4.3 KiB
C

/* This is part of the netCDF package. Copyright 2018 University
Corporation for Atmospheric Research/Unidata See COPYRIGHT file for
conditions of use.
This program excersizes HDF5 variable length array code.
@author Ed Hartnett
*/
#include <nc_tests.h>
#include <hdf5.h>
#include <nc_logging.h>
#define FILE_NAME "tst_h_vl.nc"
int
main()
{
printf("\n*** Checking HDF5 VLEN types even more.\n");
printf("*** Reading file created by netcdf-4 tests tst_vl...");
{
hid_t fileid, grpid, fapl_id, hdf_typeid = 0, base_hdf_typeid = 0, attid = 0;
hid_t file_typeid, spaceid, native_typeid;
H5O_info_t obj_info;
char obj_name[NC_MAX_NAME + 1];
hsize_t num_obj, i;
int obj_class;
H5T_class_t class;
size_t size, type_size;
hssize_t att_npoints;
int att_ndims;
hsize_t dims[1];
void *vldata;
/* Open the file and read the vlen data. */
if ((fapl_id = H5Pcreate(H5P_FILE_ACCESS)) < 0) ERR;
if (H5Pset_fclose_degree(fapl_id, H5F_CLOSE_SEMI)) ERR;
if (H5Pset_libver_bounds(fapl_id, H5F_LIBVER_LATEST, H5F_LIBVER_LATEST) < 0) ERR;
if ((fileid = H5Fopen(FILE_NAME, H5F_ACC_RDONLY, fapl_id)) < 0) ERR;
if ((grpid = H5Gopen(fileid, "/")) < 0) ERR;
if (H5Gget_num_objs(grpid, &num_obj) < 0) ERR;
for (i = 0; i < num_obj; i++)
{
if (H5Oget_info_by_idx(grpid, ".", H5_INDEX_CRT_ORDER, H5_ITER_INC,
i, &obj_info, H5P_DEFAULT) < 0) ERR_RET;
obj_class = obj_info.type;
if ((size = H5Lget_name_by_idx(grpid, ".", H5_INDEX_CRT_ORDER, H5_ITER_INC, i,
NULL, 0, H5P_DEFAULT)) < 0) ERR_RET;
if (size > NC_MAX_NAME) ERR_RET;
if (H5Lget_name_by_idx(grpid, ".", H5_INDEX_CRT_ORDER, H5_ITER_INC, i,
obj_name, size+1, H5P_DEFAULT) < 0) ERR_RET;
/*printf("nc4_rec_read_metadata: encountered HDF5 object obj_class %d obj_name %s.\n",
obj_class, obj_name);*/
/* Deal with groups and datasets. */
switch (obj_class)
{
case H5O_TYPE_GROUP:
break;
case H5O_TYPE_DATASET:
break;
case H5O_TYPE_NAMED_DATATYPE:
if ((hdf_typeid = H5Topen2(grpid, obj_name, H5P_DEFAULT)) < 0) ERR_RET;
if ((class = H5Tget_class(hdf_typeid)) < 0) ERR_RET;
switch (class)
{
case H5T_VLEN:
/* Find the base type of this vlen (i.e. what is this a * vlen of?) and its size. */
if (!(base_hdf_typeid = H5Tget_super(hdf_typeid))) ERR_RET;
if (!(type_size = H5Tget_size(base_hdf_typeid))) ERR_RET;
break;
default:
LOG((0, "unknown datatype class"));
return NC_EBADCLASS;
}
break;
case H5G_LINK:
break;
default:
LOG((0, "Unknown object class %d in nc4_rec_read_metadata!",
obj_class));
}
}
num_obj = H5Aget_num_attrs(grpid);
for (i = 0; i < num_obj; i++)
{
if (attid > 0)
H5Aclose(attid);
if ((attid = H5Aopen_idx(grpid, (unsigned int)i)) < 0) ERR_RET;
if (H5Aget_name(attid, NC_MAX_NAME + 1, obj_name) < 0) ERR_RET;
LOG((4, "reading attribute of _netCDF group, named %s", obj_name));
if ((attid && H5Aclose(attid))) ERR_RET;
}
/* Open the HDF5 attribute. */
if ((attid = H5Aopen_name(grpid, obj_name)) < 0) ERR;
/* Get type of attribute in file. */
if ((file_typeid = H5Aget_type(attid)) < 0) ERR;
if ((class = H5Tget_class(file_typeid)) < 0) ERR;
if (class != H5T_VLEN) ERR;
/* Get len. */
if ((spaceid = H5Aget_space(attid)) < 0) ERR;
if ((att_ndims = H5Sget_simple_extent_ndims(spaceid)) < 0) ERR;
if (att_ndims != 1) ERR;
if ((att_npoints = H5Sget_simple_extent_npoints(spaceid)) < 0) ERR;
if (H5Sget_simple_extent_dims(spaceid, dims, NULL) < 0) ERR;
if (dims[0] != 3) ERR;
if ((native_typeid = H5Tget_native_type(file_typeid, H5T_DIR_DEFAULT)) < 0) ERR;
if (!(vldata = malloc((unsigned int)(dims[0] * sizeof(hvl_t))))) ERR;
if (H5Aread(attid, native_typeid, vldata) < 0) ERR;
if (H5Tclose(native_typeid) < 0) ERR;
if (H5Tclose(file_typeid) < 0) ERR;
if (hdf_typeid && H5Tclose(hdf_typeid) < 0) ERR;
if (base_hdf_typeid && H5Tclose(base_hdf_typeid) < 0) ERR;
if (H5Aclose(attid) ||
H5Gclose(grpid) < 0 ||
H5Fclose(fileid) < 0) ERR;
}
SUMMARIZE_ERR;
FINAL_RESULTS;
}