diff --git a/src/h5/errorhandling_private.h b/src/h5/errorhandling_private.h index 1379b51..4e9c855 100644 --- a/src/h5/errorhandling_private.h +++ b/src/h5/errorhandling_private.h @@ -1,137 +1,143 @@ #ifndef __ERRORHANDLING_PRIVATE_H #define __ERRORHANDLING_PRIVATE_H +#define HANDLE_H5_ERR_NOT_IMPLEMENTED \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ + H5_ERR_NOT_IMPLEMENTED, \ + "Function not yet implemented!" ); + #define HANDLE_H5G_OPEN_ERR( s ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot open group \"%s\".", s ); #define CHECK_LAYOUT( f ) \ if ( ! f->block->have_layout ) \ - return (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + return (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5PART_ERR_LAYOUT, \ "No layout defined." ) #define HANDLE_H5_LAYOUT_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5PART_ERR_LAYOUT, \ "Bad layout." ); #define HANDLE_H5_NOENT_ERR( name ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5PART_ERR_NOENT, \ "Object \"%s\" doesn't exists.", name ); #define HANDLE_H5_DATASET_RANK_ERR( m, n ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5PART_ERR_INVAL, \ "Wrong rank of dataset: Is %d, but should be %d", \ m, n ); #define HANDLE_H5_GROUP_EXISTS_ERR( name ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5PART_ERR_INVAL, \ "Group \"%s\" already exists", name ) #define HANDLE_H5_INTERNAL_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_INTERNAL, \ "Internal error: %s line %d!", __FILE__, __LINE__ ) /**************** H5 *********************/ #define HANDLE_H5_BADFD_ERR \ - (*H5_get_errorhandler())( \ - H5_get_funcname(), \ + (*h5_get_errorhandler())( \ + h5_get_funcname(), \ H5_ERR_BADFD, \ "Called with bad filehandle." ); #define HANDLE_H5_INIT_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_INIT, \ "Cannot initialize H5Part." ); #define HANDLE_H5_NOMEM_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_NOMEM, \ "Out of memory." ); #define HANDLE_H5_SETSTEP_ERR( rc, step ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ rc, \ "Cannont set time-step to %lld.", (long long)step ); #define HANDLE_H5_FILE_ACCESS_TYPE_ERR( flags ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_INVAL, \ "Invalid file access type \"%d\".", flags); #define HANDLE_H5_STEP_EXISTS_ERR( step ) \ - (*H5_get_errorhandler())( \ - H5_get_funcname(), \ + (*h5_get_errorhandler())( \ + h5_get_funcname(), \ H5_ERR_INVAL, \ "Step #%lld already exists, step cannot be set to an existing" \ " step in write and append mode", (long long)step ); #define HANDLE_H5_SET_VIEW_ERR( rc, start, end ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ rc, \ "Cannot set view to (%lld, %lld).", \ (long long)start, (long long)end ); #define HANDLE_H5_GET_NUM_PARTICLES_ERR( rc ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ rc, \ "Cannot get number of particles." ); #define HANDLE_H5_NOENTRY_ERR( group_name, type, idx ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_NOENTRY, \ "No entry with index %lld and type %d in group %s!", \ (long long)idx, type, group_name ); #define HANDLE_H5_UNDEF_MESH_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_INVAL, \ "Mesh not yet defined." ); #define HANDLE_H5_UNDEF_LEVEL_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_INVAL, \ "Level not yet defined." ); #define HANDLE_H5_OVERFLOW_ERR( otype, max ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_INVAL, \ "Cannot store more than %d %s", max, otype ); #define HANDLE_H5_PARENT_ID_ERR( otype, oid, pid ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_INVAL, \ "Impossible parent_id %d for %s with global id %d", \ pid, otype, oid ); #define HANDLE_H5_OUT_OF_RANGE_ERR( otype, oid ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_INVAL, \ "%s id %d out of range", \ otype, oid ); @@ -139,122 +145,122 @@ /**************** HDF5 *********************/ /* H5A: Attribute */ #define HANDLE_H5A_CLOSE_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot terminate access to attribute." ); #define HANDLE_H5A_CREATE_ERR( s ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot create attribute \"%s\".", s ); #define HANDLE_H5A_GET_NAME_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot get attribute name." ); #define HANDLE_H5A_GET_NUM_ATTRS_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot get number of attributes." ); #define HANDLE_H5A_GET_SPACE_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot get a copy of dataspace for attribute." ); #define HANDLE_H5A_GET_TYPE_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot get attribute datatype." ); #define HANDLE_H5A_OPEN_IDX_ERR( n ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot open attribute specified by index \"%lld\".", \ (long long)n ); #define HANDLE_H5A_OPEN_NAME_ERR( s ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot open attribute specified by name \"%s\".", s ); #define HANDLE_H5A_READ_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot read attribute" ); #define HANDLE_H5A_WRITE_ERR( s ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot write attribute \"%s\".", s ); /* H5D: Dataset */ #define HANDLE_H5D_CLOSE_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Close of dataset failed." ); #define HANDLE_H5D_CREATE_ERR( s ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot create dataset name \"%s\"", \ s ); #define HANDLE_H5D_GET_SPACE_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot get dataspace identifier."); #define HANDLE_H5D_GET_TYPE_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot determine dataset type."); #define HANDLE_H5D_OPEN_ERR( s ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot open dataset \"%s\".", s ); #define HANDLE_H5D_READ_ERR( s ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Read from dataset \"%s\".", \ s ); #define HANDLE_H5D_WRITE_ERR( s ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Write to dataset \"%s\" failed.", \ s ); /* H5F: file */ #define HANDLE_H5F_CLOSE_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot terminate access to file." ); #define HANDLE_H5F_OPEN_ERR( filename, flags ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot open file \"%s\" with mode \"%d\"", filename, flags ); @@ -262,153 +268,153 @@ /* H5G: group */ #define HANDLE_H5G_CLOSE_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot terminate access to datagroup." ); #define HANDLE_H5G_CREATE_ERR( s ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot create datagroup \"%s\".", s ); #define HANDLE_H5G_GET_OBJINFO_ERR( s ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot get information about object \"%s\".", s ); #define HANDLE_H5G_OPEN_ERR( s ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot open group \"%s\".", s ); /* H5P: property */ #define HANDLE_H5P_CLOSE_ERR( s ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot terminate access to property list \"%s\".", s ); #define HANDLE_H5P_CREATE_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot create property list." ); #define HANDLE_H5P_SET_DXPL_MPIO_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "MPI: Cannot set data transfer mode." ); #define HANDLE_H5P_SET_FAPL_MPIO_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot store IO communicator information to the " \ "file access property list."); /* H5S: dataspace */ #define HANDLE_H5S_CREATE_SIMPLE_ERR( rank ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5PART_ERR_HDF5, \ "Cannot create dataspace with rank %d.", \ rank ); #define HANDLE_H5S_CREATE_SIMPLE_3D_ERR( dims ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5PART_ERR_HDF5, \ "Cannot create 3d dataspace with dimension sizes " \ "\"(%lld,%lld,%lld)\".", \ (long long)dims[0], (long long)dims[1], (long long)dims[2] ); #define HANDLE_H5S_CLOSE_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot terminate access to dataspace." ); #define HANDLE_H5S_GET_SELECT_NPOINTS_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot determine the number of elements in dataspace selection." ); #define HANDLE_H5S_GET_SIMPLE_EXTENT_NPOINTS_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot determine number of elements in dataspace." ); #define HANDLE_H5S_SELECT_HYPERSLAB_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot set select hyperslap region or add the specified region" ); #define HANDLE_H5S_GET_SIMPLE_EXTENT_DIMS_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5PART_ERR_HDF5, \ "Cannot get dimension sizes of dataset" ); /* H5T: type */ #define HANDLE_H5T_ARRAY_CREATE_ERR( type_name, rank ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Can't create array datatype object with base datatype %s and rank %d", \ type_name, rank ); #define HANDLE_H5T_CREATE_ERR( class_name, obj_name ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Can't create datatype object of class %s to handle %s.", \ class_name, obj_name ); #define HANDLE_H5T_INSERT_ERR( field_name, type_name ) \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Can't insert field %s to compound datatype to handle %s", \ field_name, type_name ); #define HANDLE_H5T_CLOSE_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_HDF5, \ "Cannot release datatype." ); /* MPI */ #define HANDLE_MPI_ALLGATHER_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_MPI, \ "Cannot gather data." ); #define HANDLE_MPI_COMM_SIZE_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_MPI, \ "Cannot get number of processes in my group." ); #define HANDLE_MPI_COMM_RANK_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_MPI, \ "Cannot get rank of the calling process in my group." ); #define HANDLE_MPI_UNAVAILABLE_ERR \ - (*H5_get_errorhandler()) ( \ - H5_get_funcname(), \ + (*h5_get_errorhandler()) ( \ + h5_get_funcname(), \ H5_ERR_MPI, \ "MPI not available" );