Page tree

 

JAVA

FORTRAN

C++

C

 

Link

H5_VERSION_LE

Determines whether the version of the library being used is less than or equal to the specified version

Procedure:

H5_VERSION_LE(maj, min, rel)

Signature:

H5_VERSION_LE
(
    int maj,
    int min,
    int rel
)

Parameters:
int maj    IN: Major version number
A non-negative integer value
int minIN: Minor version number
A non-negative integer value
int relIN: Release number
A non-negative integer value

Description:

The H5_VERSION_GE and H5_VERSION_LE macros are used at compile time to conditionally include or exclude code based on the version of the HDF5 library against which an application will be linked.

The H5_VERSION_LE macro compares the version of the HDF5 library being used against the version number specified in the parameters.

For more information about release versioning, see HDF5 Library Release Version Numbers.

Returns:

A value of 1 is returned  if the library version is less than or equal to the version number specified.

A value of 0 is returned if the library version is greater than the version number specified.

A library version is less than the specified version number if its major version is smaller than the specified major version number. If the major version numbers are the same, it is less than the specified version number if its minor version is smaller than the specified minor version number. If the minor version numbers are the same, then a library version would be less than the specified version number if its release number is smaller than the specified release number.

Example:
Suppose an application wants to call different functions based on the version of the HDF5 library to which an application will be linked. For example, the link functions, H5Lxxx, are new in the 1.8 versions of HDF5, and some group functions, H5Gxxx, are deprecated in the 1.8 versions. The following code uses H5Gunlink if the library version is 1.6.10 or earlier or uses H5Ldelete if the library version is not 1.6.10 or earlier. Similarly, the code calls H5Gopen or H5Lexists to make sure the group has been deleted.

 

    #if H5_VERSION_LE(1,6,10)
        ret = H5Gunlink(file, "Group");
        CHECK(ret, FAIL, "H5Gunlink");

        H5E_BEGIN_TRY {
            grp = H5Gopen(file, "Group");
        } H5E_END_TRY;
        VERIFY(grp, FAIL, "H5Gopen");
    #else
        ret = H5Ldelete(file, "Group", H5P_DEFAULT);
        CHECK(ret, FAIL, "H5Lunlink");

        status = H5Lexists(file, "Group", H5P_DEFAULT);
        VERIFY(status, FALSE, "H5Lexists");
    #endif      

History:
Release    Change
1.8.7C macro introduced in this release.

--- Last Modified: June 02, 2020 | 10:33 AM