diff options
author | Neil Fortner <nfortne2@hdfgroup.org> | 2019-12-13 19:48:03 (GMT) |
---|---|---|
committer | Neil Fortner <nfortne2@hdfgroup.org> | 2019-12-13 19:48:03 (GMT) |
commit | 8ae9bfa1d9f642afcc11e12bda5b1eeb2c9b7510 (patch) | |
tree | faf73a6fb72fcc9db151b39c635261050ef4794b /src/H5VL.c | |
parent | bbdb0306556459531d9e19bc6dae3c602341bdcf (diff) | |
parent | 5b751543ca7be96a91cd2db55976188f9ddbace1 (diff) | |
download | hdf5-8ae9bfa1d9f642afcc11e12bda5b1eeb2c9b7510.zip hdf5-8ae9bfa1d9f642afcc11e12bda5b1eeb2c9b7510.tar.gz hdf5-8ae9bfa1d9f642afcc11e12bda5b1eeb2c9b7510.tar.bz2 |
Merge pull request #2142 in HDFFV/hdf5 from ~NFORTNE2/hdf5_naf:tmp_112 to hdf5_1_12
* commit '5b751543ca7be96a91cd2db55976188f9ddbace1':
Modify H5VL initialization routines to initialize all VOL-managed object types. Modify H5VLwrap_register() to reject non-VOL-managed object types. Also fix overisights in h5trace.c from previous changes.
Diffstat (limited to 'src/H5VL.c')
-rw-r--r-- | src/H5VL.c | 33 |
1 files changed, 31 insertions, 2 deletions
@@ -477,6 +477,9 @@ done: * iteration routine callbacks (i.e. the callbacks from H5Aiterate*, * H5Literate* / H5Lvisit*, and H5Ovisit* ). * + * type must be a VOL-managed object class (H5I_FILE, + * H5I_GROUP, H5I_DATATYPE, H5I_DATASET, H5I_MAP, or H5I_ATTR). + * * Return: Success: Non-negative hid_t for the object. * Failure: Negative (H5I_INVALID_HID) * @@ -492,8 +495,34 @@ H5VLwrap_register(void *obj, H5I_type_t type) H5TRACE2("i", "*xIt", obj, type); /* Check args */ - if(type <= H5I_BADID || type >= H5I_NTYPES) - HGOTO_ERROR(H5E_VOL, H5E_BADRANGE, H5I_INVALID_HID, "invalid type number") + /* Use a switch here for (hopefully) better performance than a series of + * equality checks. We could also group these types together in H5I_type_t, + * make some assertions here to guarantee that, then just check the range. + */ + switch(type) { + case H5I_FILE: + case H5I_GROUP: + case H5I_DATATYPE: + case H5I_DATASET: + case H5I_MAP: + case H5I_ATTR: + /* VOL-managed objects, call is valid */ + break; + case H5I_UNINIT: + case H5I_BADID: + case H5I_DATASPACE: + case H5I_VFL: + case H5I_VOL: + case H5I_GENPROP_CLS: + case H5I_GENPROP_LST: + case H5I_ERROR_CLASS: + case H5I_ERROR_MSG: + case H5I_ERROR_STACK: + case H5I_SPACE_SEL_ITER: + case H5I_NTYPES: + default: + HGOTO_ERROR(H5E_VOL, H5E_BADRANGE, H5I_INVALID_HID, "invalid type number") + } /* end switch */ if(NULL == obj) HGOTO_ERROR(H5E_VOL, H5E_BADVALUE, H5I_INVALID_HID, "obj is NULL") |