aboutsummaryrefslogtreecommitdiff
path: root/vcpkg/ports/hdf5/portfile.cmake
diff options
context:
space:
mode:
Diffstat (limited to 'vcpkg/ports/hdf5/portfile.cmake')
-rw-r--r--vcpkg/ports/hdf5/portfile.cmake168
1 files changed, 168 insertions, 0 deletions
diff --git a/vcpkg/ports/hdf5/portfile.cmake b/vcpkg/ports/hdf5/portfile.cmake
new file mode 100644
index 0000000..08b58f6
--- /dev/null
+++ b/vcpkg/ports/hdf5/portfile.cmake
@@ -0,0 +1,168 @@
+# highfive should be updated together with hdf5
+
+string(REPLACE "." "." hdf5_ref "hdf5_${VERSION}")
+vcpkg_from_github(
+ OUT_SOURCE_PATH SOURCE_PATH
+ REPO HDFGroup/hdf5
+ REF "${hdf5_ref}"
+ SHA512 f3907abb530c4818cd9c0eb78b43073f3133260baa008ed52478e50e6bf9f1520365882acba21e0206e72c37c3e564d450def4edc3d2eef46275a41a2ad3f34b
+ HEAD_REF develop
+ PATCHES
+ hdf5_config.patch
+ pkgconfig.patch
+)
+
+set(ALLOW_UNSUPPORTED OFF)
+if ("parallel" IN_LIST FEATURES AND "cpp" IN_LIST FEATURES)
+ message(WARNING "Feature 'Parallel' and 'cpp' are mutually exclusive, enabling option ALLOW_UNSUPPORTED automatically to enable them both.")
+ set(ALLOW_UNSUPPORTED ON)
+endif()
+
+if ("threadsafe" IN_LIST FEATURES AND
+ ("parallel" IN_LIST FEATURES
+ OR "fortran" IN_LIST FEATURES
+ OR "cpp" IN_LIST FEATURES)
+ )
+ message(WARNING "Feture 'threadsafe' and other features are mutually exclusive, enabling feature ALLOW_UNSUPPORTED automatically to enable them both.")
+ set(ALLOW_UNSUPPORTED ON)
+endif()
+
+if ("fortran" IN_LIST FEATURES)
+ message(WARNING "Feature 'fortran' is not yet officially supported within VCPKG. Build will most likly fail if ninja 1.10 and a Fortran compiler are not available.")
+endif()
+
+vcpkg_check_features(OUT_FEATURE_OPTIONS FEATURE_OPTIONS
+ FEATURES
+ parallel HDF5_ENABLE_PARALLEL
+ tools HDF5_BUILD_TOOLS
+ tools HDF5_BUILD_HL_GIF_TOOLS
+ cpp HDF5_BUILD_CPP_LIB
+ szip HDF5_ENABLE_SZIP_SUPPORT
+ szip HDF5_ENABLE_SZIP_ENCODING
+ zlib HDF5_ENABLE_Z_LIB_SUPPORT
+ fortran HDF5_BUILD_FORTRAN
+ threadsafe HDF5_ENABLE_THREADSAFE
+ utils HDF5_BUILD_UTILS
+ map HDF5_ENABLE_MAP_API
+)
+
+if("tools" IN_LIST FEATURES AND VCPKG_CRT_LINKAGE STREQUAL "static")
+ list(APPEND FEATURE_OPTIONS -DBUILD_STATIC_EXECS=ON)
+endif()
+
+if(VCPKG_LIBRARY_LINKAGE STREQUAL "dynamic")
+ list(APPEND FEATURE_OPTIONS -DONLY_SHARED_LIBS=ON)
+endif()
+
+vcpkg_cmake_configure(
+ SOURCE_PATH "${SOURCE_PATH}"
+ DISABLE_PARALLEL_CONFIGURE
+ OPTIONS
+ ${FEATURE_OPTIONS}
+ -DBUILD_TESTING=OFF
+ -DHDF5_ALLOW_EXTERNAL_SUPPORT=NO
+ -DHDF5_BUILD_EXAMPLES=OFF
+ -DHDF5_INSTALL_DATA_DIR=share/hdf5/data
+ -DHDF5_INSTALL_CMAKE_DIR=share/hdf5
+ -DHDF_PACKAGE_NAMESPACE:STRING=hdf5::
+ -DHDF5_MSVC_NAMING_CONVENTION=OFF
+ -DALLOW_UNSUPPORTED=${ALLOW_UNSUPPORTED}
+ OPTIONS_RELEASE
+ -DCMAKE_DEBUG_POSTFIX= # For lib name in pkgconfig files
+)
+
+vcpkg_cmake_install()
+vcpkg_copy_pdbs()
+vcpkg_cmake_config_fixup()
+
+set(debug_suffix debug)
+if(VCPKG_TARGET_IS_WINDOWS)
+ set(debug_suffix D)
+endif()
+
+vcpkg_fixup_pkgconfig()
+
+file(GLOB pc_files "${CURRENT_PACKAGES_DIR}/lib/pkgconfig/*.pc" "${CURRENT_PACKAGES_DIR}/debug/lib/pkgconfig/*.pc")
+foreach(file IN LISTS pc_files)
+ if(VCPKG_TARGET_IS_WINDOWS AND NOT VCPKG_TARGET_IS_MINGW AND VCPKG_LIBRARY_LINKAGE STREQUAL "static")
+ vcpkg_replace_string("${file}" " -lhdf5" " -llibhdf5" IGNORE_UNCHANGED)
+ endif()
+ if(VCPKG_TARGET_IS_WINDOWS)
+ vcpkg_replace_string("${file}" "/msmpi.lib\"" "/msmpi\"" IGNORE_UNCHANGED)
+ endif()
+endforeach()
+
+vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/share/hdf5/hdf5-config.cmake"
+ [[${HDF5_PACKAGE_NAME}_TOOLS_DIR "${PACKAGE_PREFIX_DIR}/bin"]]
+ [[${HDF5_PACKAGE_NAME}_TOOLS_DIR "${PACKAGE_PREFIX_DIR}/tools/hdf5"]]
+)
+if("parallel" IN_LIST FEATURES AND NOT VCPKG_BUILD_TYPE)
+ vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/share/hdf5/hdf5-config.cmake"
+ [[..HDF5_PACKAGE_NAME._MPI_C_LIBRARIES "..VCPKG_IMPORT_PREFIX.(/lib/[^"]*)"]]
+ [[${HDF5_PACKAGE_NAME}_MPI_C_LIBRARIES optimized "${VCPKG_IMPORT_PREFIX}\1" debug "${VCPKG_IMPORT_PREFIX}/debug\1"]]
+ REGEX
+ )
+endif()
+
+set(HDF5_TOOLS "")
+if("tools" IN_LIST FEATURES)
+ list(APPEND HDF5_TOOLS h5copy h5diff h5dump h5ls h5stat gif2h5 h52gif h5clear h5debug
+ h5format_convert h5jam h5unjam h5mkgrp h5repack h5repart h5watch h5import h5delete
+ h5perf_serial
+ )
+
+ if("parallel" IN_LIST FEATURES)
+ list(APPEND HDF5_TOOLS ph5diff)
+ endif()
+
+
+ if(NOT VCPKG_TARGET_IS_WINDOWS)
+ list(APPEND HDF5_TOOLS h5cc h5hlcc)
+ if("cpp" IN_LIST FEATURES)
+ list(APPEND HDF5_TOOLS h5c++ h5hlc++)
+ endif()
+ endif()
+
+ if("parallel" IN_LIST FEATURES)
+ list(APPEND HDF5_TOOLS h5perf )
+ if(NOT VCPKG_TARGET_IS_WINDOWS)
+ list(APPEND HDF5_TOOLS h5pcc)
+ endif()
+ endif()
+endif()
+
+if ("utils" IN_LIST FEATURES)
+ list(APPEND HDF5_TOOLS mirror_server mirror_server_stop)
+endif()
+
+if(HDF5_TOOLS)
+ vcpkg_copy_tools(TOOL_NAMES ${HDF5_TOOLS} AUTO_CLEAN)
+ foreach(tool h5cc h5pcc h5hlcc)
+ if(EXISTS "${CURRENT_PACKAGES_DIR}/tools/${PORT}/${tool}")
+ vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/tools/${PORT}/${tool}" "${CURRENT_INSTALLED_DIR}" "$(dirname \"$0\")/../.." IGNORE_UNCHANGED)
+ endif()
+ endforeach()
+ if(EXISTS "${CURRENT_PACKAGES_DIR}/bin/h5fuse.sh")
+ file(RENAME "${CURRENT_PACKAGES_DIR}/bin/h5fuse.sh" "${CURRENT_PACKAGES_DIR}/tools/${PORT}/h5fuse.sh")
+ file(REMOVE "${CURRENT_PACKAGES_DIR}/debug/bin/h5fuse.sh")
+ endif()
+endif()
+
+if(VCPKG_LIBRARY_LINKAGE STREQUAL static)
+ file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/bin" "${CURRENT_PACKAGES_DIR}/debug/bin")
+endif()
+
+# Clean up
+file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/debug/share")
+file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/debug/include")
+
+configure_file("${CMAKE_CURRENT_LIST_DIR}/vcpkg-cmake-wrapper.cmake" "${CURRENT_PACKAGES_DIR}/share/${PORT}/vcpkg-cmake-wrapper.cmake" @ONLY)
+if("parallel" IN_LIST FEATURES)
+ file(INSTALL "${CMAKE_CURRENT_LIST_DIR}/vcpkg-port-config.cmake" DESTINATION "${CURRENT_PACKAGES_DIR}/share/${PORT}")
+endif()
+
+if(VCPKG_LIBRARY_LINKAGE STREQUAL "dynamic")
+ vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/include/H5public.h" "#define H5public_H" "#define H5public_H\n#ifndef H5_BUILT_AS_DYNAMIC_LIB\n#define H5_BUILT_AS_DYNAMIC_LIB\n#endif\n")
+endif()
+
+file(RENAME "${CURRENT_PACKAGES_DIR}/share/${PORT}/data/COPYING" "${CURRENT_PACKAGES_DIR}/share/${PORT}/copyright")