Skip to content

Commit

Permalink
CMake: Find HDF5 header we can safely include for other checks
Browse files Browse the repository at this point in the history
  • Loading branch information
ZedThree committed Oct 6, 2023
1 parent b62da98 commit 274c14f
Show file tree
Hide file tree
Showing 2 changed files with 57 additions and 15 deletions.
19 changes: 4 additions & 15 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -849,16 +849,13 @@ IF(USE_HDF5)

set (CMAKE_REQUIRED_INCLUDES ${HDF5_INCLUDE_DIR})

include(cmake/check_hdf5.cmake)

# Check to ensure that HDF5 was built with zlib.
# This needs to be near the beginning since we
# need to know whether to add "-lz" to the symbol
# tests below.
CHECK_C_SOURCE_COMPILES("#include <H5pubconf.h>
#if !H5_HAVE_ZLIB_H
#error
#endif
int main() {
int x = 1;}" HAVE_HDF5_ZLIB)
check_hdf5_feature(HAVE_HDF5_ZLIB H5_HAVE_ZLIB_H)
IF(NOT HAVE_HDF5_ZLIB)
MESSAGE(FATAL_ERROR "HDF5 was built without zlib. Rebuild HDF5 with zlib.")
ELSE()
Expand All @@ -876,15 +873,7 @@ IF(USE_HDF5)
ENDIF()

#Check to see if H5Z_SZIP exists in HDF5_Libraries. If so, we must use szip library.
CHECK_C_SOURCE_COMPILES("#include <H5pubconf.h>
#if !H5_HAVE_FILTER_SZIP
#error
#endif
int main() {
int x = 1;}" USE_HDF5_SZIP)
IF(USE_HDF5_SZIP)
SET(HAVE_H5Z_SZIP yes)
ENDIF()
check_hdf5_feature(HAVE_H5Z_SZIP H5_HAVE_FILTER_SZIP)

####
# Check to see if HDF5 library is 1.10.6 or greater.
Expand Down
53 changes: 53 additions & 0 deletions cmake/check_hdf5.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
# Work out which HDF5 config header we can safely include
#
# We'd like to just use H5public.h, but if HDF5 was built against MPI, this
# might require us to have found MPI already. The next best file is H5pubconf.h,
# which actually has all the feature macros we want to check, but some
# distributions rename this for multiarch, so we've got to check some different
# names.
#
# HDF5_INCLUDE_DIR should already be set before calling this
function(check_hdf5_feature_header)
if (_H5_FEATURE_HEADER)
return()
endif()

include(CheckIncludeFile)

set(CMAKE_REQUIRED_INCLUDES ${HDF5_INCLUDE_DIR})

message(STATUS "Checking for HDF5 config header")
foreach(_h5_header "H5public.h" "H5pubconf.h" "H5pubconf-64.h" "H5pubconf-32.h")
check_include_file(${_h5_header} _can_include_h5_header)

if (_can_include_h5_header)
message(STATUS "Using ${_h5_header} to check for feature macros")
set(_H5_FEATURE_HEADER ${_h5_header} CACHE INTERNAL "")
return()
endif()
endforeach()

message(FATAL_ERROR "Could not include any HDF5 config headers")
endfunction()


# Check for an HDF5 feature macro named FEATURE and store the result in VAR
#
# This just wraps `check_c_source_compiles` but ensures we use the correct header
function(check_hdf5_feature VAR FEATURE)
if (NOT _H5_FEATURE_HEADER)
check_hdf5_feature_header()
endif()

include(CheckCSourceCompiles)
message(STATUS "Checking for ${FEATURE}")
check_c_source_compiles("
#include <${_H5_FEATURE_HEADER}>
#if !${FEATURE}
#error
#endif
int main() {}"
_has_${FEATURE})

set(${VAR} ${_has_${FEATURE}} PARENT_SCOPE)
endfunction()

0 comments on commit 274c14f

Please sign in to comment.