/* 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 #include #include #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; #if H5_VERSION_GE(1,12,0) H5O_info2_t obj_info; #else H5O_info_t obj_info; #endif 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_WEAK)) 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 = H5Gopen1(fileid, "/")) < 0) ERR; if (H5Gget_num_objs(grpid, &num_obj) < 0) ERR; for (i = 0; i < num_obj; i++) { #if H5_VERSION_GE(1,12,0) if (H5Oget_info_by_idx3(grpid, ".", H5_INDEX_CRT_ORDER, H5_ITER_INC, i, &obj_info, H5O_INFO_BASIC, H5P_DEFAULT) < 0) ERR_RET; #else if (H5Oget_info_by_idx(grpid, ".", H5_INDEX_CRT_ORDER, H5_ITER_INC, i, &obj_info, H5P_DEFAULT) < 0) ERR_RET; #endif 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; }