early-access version 2853
This commit is contained in:
31
externals/vcpkg/ports/hdf5/hdf5_config.patch
vendored
Executable file
31
externals/vcpkg/ports/hdf5/hdf5_config.patch
vendored
Executable file
@@ -0,0 +1,31 @@
|
||||
diff --git a/config/cmake/hdf5-config.cmake.in b/config/cmake/hdf5-config.cmake.in
|
||||
index 4d02c9c..8c10d2d 100644
|
||||
--- a/config/cmake/hdf5-config.cmake.in
|
||||
+++ b/config/cmake/hdf5-config.cmake.in
|
||||
@@ -55,7 +55,10 @@ set (${HDF5_PACKAGE_NAME}_PARALLEL_FILTERED_WRITES "@PARALLEL_FILTERED_WRITES@")
|
||||
#-----------------------------------------------------------------------------
|
||||
# Dependencies
|
||||
#-----------------------------------------------------------------------------
|
||||
+include(CMakeFindDependencyMacro)
|
||||
+
|
||||
if (${HDF5_PACKAGE_NAME}_ENABLE_PARALLEL)
|
||||
+ find_dependency(MPI)
|
||||
set (${HDF5_PACKAGE_NAME}_MPI_C_INCLUDE_PATH "@MPI_C_INCLUDE_DIRS@")
|
||||
set (${HDF5_PACKAGE_NAME}_MPI_C_LIBRARIES "@MPI_C_LIBRARIES@")
|
||||
if (${HDF5_PACKAGE_NAME}_BUILD_FORTRAN)
|
||||
@@ -111,11 +114,11 @@ set (${HDF5_PACKAGE_NAME}_VERSION_MINOR @HDF5_VERSION_MINOR@)
|
||||
# project which has already built hdf5 as a subproject
|
||||
#-----------------------------------------------------------------------------
|
||||
if (NOT TARGET "@HDF5_PACKAGE@")
|
||||
- if (${HDF5_PACKAGE_NAME}_ENABLE_Z_LIB_SUPPORT AND ${HDF5_PACKAGE_NAME}_PACKAGE_EXTLIBS)
|
||||
- include (@PACKAGE_SHARE_INSTALL_DIR@/@ZLIB_PACKAGE_NAME@@HDF_PACKAGE_EXT@-targets.cmake)
|
||||
+ if (${HDF5_PACKAGE_NAME}_ENABLE_Z_LIB_SUPPORT)
|
||||
+ find_dependency(ZLIB)
|
||||
endif ()
|
||||
- if (${HDF5_PACKAGE_NAME}_ENABLE_SZIP_SUPPORT AND ${HDF5_PACKAGE_NAME}_PACKAGE_EXTLIBS)
|
||||
- include (@PACKAGE_SHARE_INSTALL_DIR@/@SZIP_PACKAGE_NAME@@HDF_PACKAGE_EXT@-targets.cmake)
|
||||
+ if (${HDF5_PACKAGE_NAME}_ENABLE_SZIP_SUPPORT)
|
||||
+ find_dependency(szip)
|
||||
endif ()
|
||||
include (@PACKAGE_SHARE_INSTALL_DIR@/@HDF5_PACKAGE@@HDF_PACKAGE_EXT@-targets.cmake)
|
||||
endif ()
|
||||
11
externals/vcpkg/ports/hdf5/pkgconfig-link-order.patch
vendored
Executable file
11
externals/vcpkg/ports/hdf5/pkgconfig-link-order.patch
vendored
Executable file
@@ -0,0 +1,11 @@
|
||||
diff --git a/config/libhdf5.pc.in b/config/libhdf5.pc.in
|
||||
index 4a2ebaa..3cb42d2 100644
|
||||
--- a/config/libhdf5.pc.in
|
||||
+++ b/config/libhdf5.pc.in
|
||||
@@ -10,5 +10,5 @@ Version: @_PKG_CONFIG_VERSION@
|
||||
Cflags: -I${includedir}
|
||||
Libs: -L${libdir} @_PKG_CONFIG_SH_LIBS@
|
||||
Requires: @_PKG_CONFIG_REQUIRES@
|
||||
-Libs.private: @_PKG_CONFIG_LIBS_PRIVATE@ @_PKG_CONFIG_LIBS@
|
||||
+Libs.private: @_PKG_CONFIG_LIBS@ @_PKG_CONFIG_LIBS_PRIVATE@
|
||||
Requires.private: @_PKG_CONFIG_REQUIRES_PRIVATE@
|
||||
192
externals/vcpkg/ports/hdf5/pkgconfig-requires.patch
vendored
Executable file
192
externals/vcpkg/ports/hdf5/pkgconfig-requires.patch
vendored
Executable file
@@ -0,0 +1,192 @@
|
||||
diff --git a/CMakeFilters.cmake b/CMakeFilters.cmake
|
||||
index 141ab44..66b7efa 100644
|
||||
--- a/CMakeFilters.cmake
|
||||
+++ b/CMakeFilters.cmake
|
||||
@@ -74,6 +74,7 @@ if (HDF5_ENABLE_Z_LIB_SUPPORT)
|
||||
set (H5_ZLIB_HEADER "zlib.h")
|
||||
set (ZLIB_INCLUDE_DIR_GEN ${ZLIB_INCLUDE_DIR})
|
||||
set (ZLIB_INCLUDE_DIRS ${ZLIB_INCLUDE_DIRS} ${ZLIB_INCLUDE_DIR})
|
||||
+ set (zlib_PC_LIBS_PRIVATE "${ZLIB_LIBRARIES}")
|
||||
else ()
|
||||
if (HDF5_ALLOW_EXTERNAL_SUPPORT MATCHES "GIT" OR HDF5_ALLOW_EXTERNAL_SUPPORT MATCHES "TGZ")
|
||||
EXTERNAL_ZLIB_LIBRARY (${HDF5_ALLOW_EXTERNAL_SUPPORT})
|
||||
@@ -134,6 +135,7 @@ if (HDF5_ENABLE_SZIP_SUPPORT)
|
||||
else()
|
||||
set(SZIP_STATIC_LIBRARY szip-static)
|
||||
endif()
|
||||
+ set(szip_PC_LIBS_PRIVATE "${SZIP_STATIC_LIBRARY}")
|
||||
else ()
|
||||
if (HDF5_ALLOW_EXTERNAL_SUPPORT MATCHES "GIT" OR HDF5_ALLOW_EXTERNAL_SUPPORT MATCHES "TGZ")
|
||||
EXTERNAL_SZIP_LIBRARY (${HDF5_ALLOW_EXTERNAL_SUPPORT} ${HDF5_ENABLE_SZIP_ENCODING})
|
||||
diff --git a/CMakeLists.txt b/CMakeLists.txt
|
||||
index b75fdd2..a2e88fd 100644
|
||||
--- a/CMakeLists.txt
|
||||
+++ b/CMakeLists.txt
|
||||
@@ -750,6 +750,9 @@ if (H5_HAVE_PARALLEL)
|
||||
if (MPI_C_LINK_FLAGS)
|
||||
set (CMAKE_EXE_LINKER_FLAGS "${MPI_C_LINK_FLAGS} ${CMAKE_EXE_LINKER_FLAGS}")
|
||||
endif ()
|
||||
+ if(UNIX)
|
||||
+ set(ompi-c_PC_LIBS_PRIVATE ${MPI_C_LIBRARIES})
|
||||
+ endif()
|
||||
endif ()
|
||||
|
||||
#option (DEFAULT_API_VERSION "Enable v1.12 API (v16, v18, v110, v112)" "v112")
|
||||
diff --git a/c++/src/CMakeLists.txt b/c++/src/CMakeLists.txt
|
||||
index 835d422..9a7176f 100644
|
||||
--- a/c++/src/CMakeLists.txt
|
||||
+++ b/c++/src/CMakeLists.txt
|
||||
@@ -188,14 +188,14 @@ set (_PKG_CONFIG_VERSION "${HDF5_PACKAGE_VERSION}")
|
||||
set (_PKG_CONFIG_LIBS_PRIVATE)
|
||||
|
||||
if (NOT ONLY_SHARED_LIBS)
|
||||
- set (_PKG_CONFIG_LIBS "${_PKG_CONFIG_LIBS} -l${HDF5_CPP_LIB_CORENAME}")
|
||||
+ set (_PKG_CONFIG_LIBS "${_PKG_CONFIG_LIBS} -l${HDF5_CPP_LIB_CORENAME}${CMAKE_DEBUG_POSTFIX}")
|
||||
endif ()
|
||||
if (BUILD_SHARED_LIBS)
|
||||
- set (_PKG_CONFIG_SH_LIBS "${_PKG_CONFIG_SH_LIBS} -l${HDF5_CPP_LIB_CORENAME}")
|
||||
+ set (_PKG_CONFIG_SH_LIBS "${_PKG_CONFIG_SH_LIBS} -l${HDF5_CPP_LIB_CORENAME}${CMAKE_DEBUG_POSTFIX}")
|
||||
endif ()
|
||||
|
||||
-set (_PKG_CONFIG_REQUIRES "${HDF5_LIB_CORENAME}-${HDF5_PACKAGE_VERSION}")
|
||||
-set (_PKG_CONFIG_REQUIRES_PRIVATE "${HDF5_LIB_CORENAME}-${HDF5_PACKAGE_VERSION}")
|
||||
+set (_PKG_CONFIG_REQUIRES "${HDF5_LIB_CORENAME}")
|
||||
+set (_PKG_CONFIG_REQUIRES_PRIVATE "${HDF5_LIB_CORENAME}")
|
||||
|
||||
configure_file (
|
||||
${HDF_CONFIG_DIR}/libhdf5.pc.in
|
||||
diff --git a/config/cmake_ext_mod/HDFMacros.cmake b/config/cmake_ext_mod/HDFMacros.cmake
|
||||
index ae0ebca..095fae4 100644
|
||||
--- a/config/cmake_ext_mod/HDFMacros.cmake
|
||||
+++ b/config/cmake_ext_mod/HDFMacros.cmake
|
||||
@@ -384,7 +384,7 @@ macro (HDF_DIR_PATHS package_prefix)
|
||||
endif ()
|
||||
|
||||
#set the default debug suffix for all library targets
|
||||
- if(NOT CMAKE_DEBUG_POSTFIX)
|
||||
+ if(NOT DEFINED CMAKE_DEBUG_POSTFIX)
|
||||
if (WIN32)
|
||||
set (CMAKE_DEBUG_POSTFIX "_D")
|
||||
else ()
|
||||
diff --git a/fortran/src/CMakeLists.txt b/fortran/src/CMakeLists.txt
|
||||
index e59a829..8da64dd 100644
|
||||
--- a/fortran/src/CMakeLists.txt
|
||||
+++ b/fortran/src/CMakeLists.txt
|
||||
@@ -545,14 +545,14 @@ set (_PKG_CONFIG_VERSION "${HDF5_PACKAGE_VERSION}")
|
||||
set (_PKG_CONFIG_LIBS_PRIVATE)
|
||||
|
||||
if (NOT ONLY_SHARED_LIBS)
|
||||
- set (_PKG_CONFIG_LIBS "${_PKG_CONFIG_LIBS} -l${HDF5_F90_LIB_CORENAME}")
|
||||
+ set (_PKG_CONFIG_LIBS "${_PKG_CONFIG_LIBS} -l${HDF5_F90_LIB_CORENAME}${CMAKE_DEBUG_POSTFIX}")
|
||||
endif ()
|
||||
if (BUILD_SHARED_LIBS)
|
||||
- set (_PKG_CONFIG_SH_LIBS "${_PKG_CONFIG_SH_LIBS} -l${HDF5_F90_LIB_CORENAME}")
|
||||
+ set (_PKG_CONFIG_SH_LIBS "${_PKG_CONFIG_SH_LIBS} -l${HDF5_F90_LIB_CORENAME}${CMAKE_DEBUG_POSTFIX}")
|
||||
endif ()
|
||||
|
||||
-set (_PKG_CONFIG_REQUIRES "${HDF5_LIB_CORENAME}-${HDF5_PACKAGE_VERSION}")
|
||||
-set (_PKG_CONFIG_REQUIRES_PRIVATE "${HDF5_LIB_CORENAME}-${HDF5_PACKAGE_VERSION}")
|
||||
+set (_PKG_CONFIG_REQUIRES "${HDF5_LIB_CORENAME}")
|
||||
+set (_PKG_CONFIG_REQUIRES_PRIVATE "${HDF5_LIB_CORENAME}")
|
||||
|
||||
configure_file (
|
||||
${HDF_CONFIG_DIR}/libhdf5.pc.in
|
||||
diff --git a/hl/c++/src/CMakeLists.txt b/hl/c++/src/CMakeLists.txt
|
||||
index c516df1..89bd31f 100644
|
||||
--- a/hl/c++/src/CMakeLists.txt
|
||||
+++ b/hl/c++/src/CMakeLists.txt
|
||||
@@ -99,14 +99,14 @@ set (_PKG_CONFIG_VERSION "${HDF5_PACKAGE_VERSION}")
|
||||
set (_PKG_CONFIG_LIBS_PRIVATE)
|
||||
|
||||
if (NOT ONLY_SHARED_LIBS)
|
||||
- set (_PKG_CONFIG_LIBS "${_PKG_CONFIG_LIBS} -l${HDF5_HL_CPP_LIB_CORENAME}")
|
||||
+ set (_PKG_CONFIG_LIBS "${_PKG_CONFIG_LIBS} -l${HDF5_HL_CPP_LIB_CORENAME}${CMAKE_DEBUG_POSTFIX}")
|
||||
endif ()
|
||||
if (BUILD_SHARED_LIBS)
|
||||
- set (_PKG_CONFIG_SH_LIBS "${_PKG_CONFIG_SH_LIBS} -l${HDF5_HL_CPP_LIB_CORENAME}")
|
||||
+ set (_PKG_CONFIG_SH_LIBS "${_PKG_CONFIG_SH_LIBS} -l${HDF5_HL_CPP_LIB_CORENAME}${CMAKE_DEBUG_POSTFIX}")
|
||||
endif ()
|
||||
|
||||
-set (_PKG_CONFIG_REQUIRES "${HDF5_HL_LIB_CORENAME}-${HDF5_PACKAGE_VERSION}")
|
||||
-set (_PKG_CONFIG_REQUIRES_PRIVATE "${HDF5_HL_LIB_CORENAME}-${HDF5_PACKAGE_VERSION}")
|
||||
+set (_PKG_CONFIG_REQUIRES "${HDF5_HL_LIB_CORENAME}")
|
||||
+set (_PKG_CONFIG_REQUIRES_PRIVATE "${HDF5_HL_LIB_CORENAME}")
|
||||
|
||||
configure_file (
|
||||
${HDF_CONFIG_DIR}/libhdf5.pc.in
|
||||
diff --git a/hl/fortran/src/CMakeLists.txt b/hl/fortran/src/CMakeLists.txt
|
||||
index 973299f..8eadfe5 100644
|
||||
--- a/hl/fortran/src/CMakeLists.txt
|
||||
+++ b/hl/fortran/src/CMakeLists.txt
|
||||
@@ -332,14 +332,14 @@ set (_PKG_CONFIG_VERSION "${HDF5_PACKAGE_VERSION}")
|
||||
set (_PKG_CONFIG_LIBS_PRIVATE)
|
||||
|
||||
if (NOT ONLY_SHARED_LIBS)
|
||||
- set (_PKG_CONFIG_LIBS "${_PKG_CONFIG_LIBS} -l${HDF5_HL_F90_LIB_CORENAME}")
|
||||
+ set (_PKG_CONFIG_LIBS "${_PKG_CONFIG_LIBS} -l${HDF5_HL_F90_LIB_CORENAME}${CMAKE_DEBUG_POSTFIX}")
|
||||
endif ()
|
||||
if (BUILD_SHARED_LIBS)
|
||||
- set (_PKG_CONFIG_SH_LIBS "${_PKG_CONFIG_SH_LIBS} -l${HDF5_HL_F90_LIB_CORENAME}")
|
||||
+ set (_PKG_CONFIG_SH_LIBS "${_PKG_CONFIG_SH_LIBS} -l${HDF5_HL_F90_LIB_CORENAME}${CMAKE_DEBUG_POSTFIX}")
|
||||
endif ()
|
||||
|
||||
-set (_PKG_CONFIG_REQUIRES "${HDF5_F90_LIB_CORENAME}-${HDF5_PACKAGE_VERSION}")
|
||||
-set (_PKG_CONFIG_REQUIRES_PRIVATE "${HDF5_F90_LIB_CORENAME}-${HDF5_PACKAGE_VERSION}")
|
||||
+set (_PKG_CONFIG_REQUIRES "${HDF5_F90_LIB_CORENAME}")
|
||||
+set (_PKG_CONFIG_REQUIRES_PRIVATE "${HDF5_F90_LIB_CORENAME}")
|
||||
|
||||
configure_file (
|
||||
${HDF_CONFIG_DIR}/libhdf5.pc.in
|
||||
diff --git a/hl/src/CMakeLists.txt b/hl/src/CMakeLists.txt
|
||||
index 7678de8..2d398cc 100644
|
||||
--- a/hl/src/CMakeLists.txt
|
||||
+++ b/hl/src/CMakeLists.txt
|
||||
@@ -131,14 +131,14 @@ set (_PKG_CONFIG_VERSION "${HDF5_PACKAGE_VERSION}")
|
||||
set (_PKG_CONFIG_LIBS_PRIVATE)
|
||||
|
||||
if (NOT ONLY_SHARED_LIBS)
|
||||
- set (_PKG_CONFIG_LIBS "${_PKG_CONFIG_LIBS} -l${HDF5_HL_LIB_CORENAME}")
|
||||
+ set (_PKG_CONFIG_LIBS "${_PKG_CONFIG_LIBS} -l${HDF5_HL_LIB_CORENAME}${CMAKE_DEBUG_POSTFIX}")
|
||||
endif ()
|
||||
if (BUILD_SHARED_LIBS)
|
||||
- set (_PKG_CONFIG_SH_LIBS "${_PKG_CONFIG_SH_LIBS} -l${HDF5_HL_LIB_CORENAME}")
|
||||
+ set (_PKG_CONFIG_SH_LIBS "${_PKG_CONFIG_SH_LIBS} -l${HDF5_HL_LIB_CORENAME}${CMAKE_DEBUG_POSTFIX}")
|
||||
endif ()
|
||||
|
||||
-set (_PKG_CONFIG_REQUIRES "${HDF5_LIB_CORENAME}-${HDF5_PACKAGE_VERSION}")
|
||||
-set (_PKG_CONFIG_REQUIRES_PRIVATE "${HDF5_LIB_CORENAME}-${HDF5_PACKAGE_VERSION}")
|
||||
+set (_PKG_CONFIG_REQUIRES "${HDF5_LIB_CORENAME}")
|
||||
+set (_PKG_CONFIG_REQUIRES_PRIVATE "${HDF5_LIB_CORENAME}")
|
||||
|
||||
configure_file (
|
||||
${HDF_CONFIG_DIR}/libhdf5.pc.in
|
||||
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
|
||||
index b3c2226..ea80d60 100644
|
||||
--- a/src/CMakeLists.txt
|
||||
+++ b/src/CMakeLists.txt
|
||||
@@ -1321,14 +1321,23 @@ foreach (libs ${LINK_LIBS} ${LINK_COMP_LIBS})
|
||||
endforeach ()
|
||||
|
||||
if (NOT ONLY_SHARED_LIBS)
|
||||
- set (_PKG_CONFIG_LIBS "${_PKG_CONFIG_LIBS} -l${HDF5_LIB_CORENAME}")
|
||||
+ set (_PKG_CONFIG_LIBS "${_PKG_CONFIG_LIBS} -l${HDF5_LIB_CORENAME}${CMAKE_DEBUG_POSTFIX}")
|
||||
endif ()
|
||||
if (BUILD_SHARED_LIBS)
|
||||
- set (_PKG_CONFIG_SH_LIBS "${_PKG_CONFIG_SH_LIBS} -l${HDF5_LIB_CORENAME}")
|
||||
+ set (_PKG_CONFIG_SH_LIBS "${_PKG_CONFIG_SH_LIBS} -l${HDF5_LIB_CORENAME}${CMAKE_DEBUG_POSTFIX}")
|
||||
endif ()
|
||||
|
||||
set (_PKG_CONFIG_REQUIRES)
|
||||
set (_PKG_CONFIG_REQUIRES_PRIVATE)
|
||||
+set(_PKG_CONFIG_LIBS_PRIVATE " ${_PKG_CONFIG_LIBS_PRIVATE} ")
|
||||
+foreach(_module IN ITEMS ompi-c szip zlib)
|
||||
+ if(${_module}_PC_LIBS_PRIVATE)
|
||||
+ foreach(_lib IN LISTS ${_module}_PC_LIBS_PRIVATE)
|
||||
+ string(REPLACE " -l${_lib} " " " _PKG_CONFIG_LIBS_PRIVATE "${_PKG_CONFIG_LIBS_PRIVATE}")
|
||||
+ endforeach()
|
||||
+ string(APPEND _PKG_CONFIG_REQUIRES_PRIVATE " ${_module}")
|
||||
+ endif()
|
||||
+endforeach()
|
||||
|
||||
configure_file (
|
||||
${HDF_CONFIG_DIR}/libhdf5.pc.in
|
||||
148
externals/vcpkg/ports/hdf5/portfile.cmake
vendored
Executable file
148
externals/vcpkg/ports/hdf5/portfile.cmake
vendored
Executable file
@@ -0,0 +1,148 @@
|
||||
# highfive should be updated together with hdf5
|
||||
|
||||
vcpkg_from_github(
|
||||
OUT_SOURCE_PATH SOURCE_PATH
|
||||
REPO HDFGroup/hdf5
|
||||
REF hdf5-1_12_2
|
||||
SHA512 8f110e035a9bd5b07687b30fb944ed72e5b6a6e0ea74ee650250f40f0d4ff81e304366a76129a50a2d37c7f4c59a57356d0d9eed18db6cb90e924c62273d17a4
|
||||
HEAD_REF develop
|
||||
PATCHES
|
||||
hdf5_config.patch
|
||||
szip.patch
|
||||
pkgconfig-requires.patch
|
||||
pkgconfig-link-order.patch
|
||||
)
|
||||
|
||||
set(ALLOW_UNSUPPORTED OFF)
|
||||
if ("parallel" IN_LIST FEATURES AND "cpp" IN_LIST FEATURES)
|
||||
message(WARNING "Feature 'Parallel' and 'cpp' are mutually exclusive, enable feature 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, enable feature ALLOW_UNSUPPORTED automatically to enable them both.")
|
||||
set(ALLOW_UNSUPPORTED ON)
|
||||
endif()
|
||||
|
||||
if ("fortran" IN_LIST FEATURE)
|
||||
message(WARNING "Feature 'fortran' is not yet official 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
|
||||
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
|
||||
)
|
||||
|
||||
file(REMOVE "${SOURCE_PATH}/config/cmake_ext_mod/FindSZIP.cmake")#Outdated; does not find debug szip
|
||||
|
||||
if("tools" IN_LIST FEATURES AND VCPKG_CRT_LINKAGE STREQUAL "static")
|
||||
list(APPEND FEATURE_OPTIONS -DBUILD_STATIC_EXECS=ON)
|
||||
endif()
|
||||
|
||||
if(NOT VCPKG_LIBRARY_LINKAGE STREQUAL "static")
|
||||
list(APPEND FEATURE_OPTIONS
|
||||
-DBUILD_STATIC_LIBS=OFF
|
||||
-DONLY_SHARED_LIBS=ON)
|
||||
endif()
|
||||
|
||||
vcpkg_cmake_configure(
|
||||
SOURCE_PATH "${SOURCE_PATH}"
|
||||
DISABLE_PARALLEL_CONFIGURE
|
||||
OPTIONS
|
||||
${FEATURE_OPTIONS}
|
||||
-DBUILD_TESTING=OFF
|
||||
-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
|
||||
-DSZIP_USE_EXTERNAL=ON
|
||||
-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")
|
||||
endif()
|
||||
if(VCPKG_TARGET_IS_WINDOWS)
|
||||
vcpkg_replace_string("${file}" "/msmpi.lib\"" "/msmpi\"")
|
||||
endif()
|
||||
endforeach()
|
||||
|
||||
file(READ "${CURRENT_PACKAGES_DIR}/share/hdf5/hdf5-config.cmake" contents)
|
||||
string(REPLACE [[${HDF5_PACKAGE_NAME}_TOOLS_DIR "${PACKAGE_PREFIX_DIR}/bin"]]
|
||||
[[${HDF5_PACKAGE_NAME}_TOOLS_DIR "${PACKAGE_PREFIX_DIR}/tools/hdf5"]]
|
||||
contents ${contents}
|
||||
)
|
||||
file(WRITE "${CURRENT_PACKAGES_DIR}/share/hdf5/hdf5-config.cmake" ${contents})
|
||||
|
||||
if("tools" IN_LIST FEATURES)
|
||||
set(HDF5_TOOLS h5cc h5hlcc h5c++ h5hlc++ h5copy h5diff h5dump h5ls h5stat gif2h5 h52gif h5clear h5debug
|
||||
h5format_convert h5jam h5unjam h5ls h5mkgrp h5repack h5repart h5watch ph5diff h5import
|
||||
)
|
||||
|
||||
if(VCPKG_LIBRARY_LINKAGE STREQUAL "dynamic")
|
||||
list(TRANSFORM HDF5_TOOLS REPLACE "^(.+)$" "\\1-shared")
|
||||
else()
|
||||
endif()
|
||||
|
||||
foreach(HDF5_TOOL IN LISTS HDF5_TOOLS)
|
||||
if (NOT EXISTS "${CURRENT_PACKAGES_DIR}/bin/${HDF5_TOOL}${VCPKG_TARGET_EXECUTABLE_SUFFIX}"
|
||||
OR NOT EXISTS "${CURRENT_PACKAGES_DIR}/debug/bin/${HDF5_TOOL}${VCPKG_TARGET_EXECUTABLE_SUFFIX}")
|
||||
list(REMOVE_ITEM HDF5_TOOLS "${HDF5_TOOL}")
|
||||
endif()
|
||||
endforeach()
|
||||
|
||||
if("parallel" IN_LIST FEATURES)
|
||||
list(APPEND HDF5_TOOLS h5perf)
|
||||
else()
|
||||
list(APPEND HDF5_TOOLS h5perf_serial)
|
||||
endif()
|
||||
|
||||
vcpkg_copy_tools(TOOL_NAMES ${HDF5_TOOLS} AUTO_CLEAN)
|
||||
endif()
|
||||
|
||||
if ("utils" IN_LIST FEATURES)
|
||||
vcpkg_copy_tools(
|
||||
TOOL_NAMES mirror_server mirror_server_stop
|
||||
AUTO_CLEAN
|
||||
)
|
||||
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)
|
||||
|
||||
file(RENAME "${CURRENT_PACKAGES_DIR}/share/${PORT}/data/COPYING" "${CURRENT_PACKAGES_DIR}/share/${PORT}/copyright")
|
||||
21
externals/vcpkg/ports/hdf5/szip.patch
vendored
Executable file
21
externals/vcpkg/ports/hdf5/szip.patch
vendored
Executable file
@@ -0,0 +1,21 @@
|
||||
diff --git a/CMakeFilters.cmake b/CMakeFilters.cmake
|
||||
index d5f801e..141ab44 100644
|
||||
--- a/CMakeFilters.cmake
|
||||
+++ b/CMakeFilters.cmake
|
||||
@@ -124,6 +124,16 @@ if (HDF5_ENABLE_SZIP_SUPPORT)
|
||||
set (H5_HAVE_LIBSZ 1)
|
||||
set (SZIP_INCLUDE_DIR_GEN ${SZIP_INCLUDE_DIR})
|
||||
set (SZIP_INCLUDE_DIRS ${SZIP_INCLUDE_DIRS} ${SZIP_INCLUDE_DIR})
|
||||
+ elseif(1)
|
||||
+ find_package(szip CONFIG REQUIRED)
|
||||
+ set(SZIP_INCLUDE_DIRS "")
|
||||
+ # SZIP_STATIC_LIBRARY will be used in linking, in cmake and in pkgconfig,
|
||||
+ # but the actual linkage doesn't matter.
|
||||
+ if (TARGET szip-shared)
|
||||
+ set(SZIP_STATIC_LIBRARY szip-shared)
|
||||
+ else()
|
||||
+ set(SZIP_STATIC_LIBRARY szip-static)
|
||||
+ endif()
|
||||
else ()
|
||||
if (HDF5_ALLOW_EXTERNAL_SUPPORT MATCHES "GIT" OR HDF5_ALLOW_EXTERNAL_SUPPORT MATCHES "TGZ")
|
||||
EXTERNAL_SZIP_LIBRARY (${HDF5_ALLOW_EXTERNAL_SUPPORT} ${HDF5_ENABLE_SZIP_ENCODING})
|
||||
17
externals/vcpkg/ports/hdf5/vcpkg-cmake-wrapper.cmake
vendored
Executable file
17
externals/vcpkg/ports/hdf5/vcpkg-cmake-wrapper.cmake
vendored
Executable file
@@ -0,0 +1,17 @@
|
||||
|
||||
if(CMAKE_VERSION VERSION_GREATER_EQUAL 3.3)
|
||||
cmake_policy(PUSH)
|
||||
cmake_policy(SET CMP0057 NEW)
|
||||
if(NOT "CONFIG" IN_LIST ARGS AND NOT "NO_MODULE" IN_LIST ARGS AND "HDF5" IN_LIST ARGS)
|
||||
# The caller hasn't said "CONFIG", so they want the built-in FindHDF5.cmake behavior. Set configurations macros to ensure the built-in script finds us.
|
||||
if("@VCPKG_LIBRARY_LINKAGE@" STREQUAL "static")
|
||||
set(HDF5_USE_STATIC_LIBRARIES ON)
|
||||
add_compile_definitions(H5_BUILT_AS_STATIC_LIB)
|
||||
else()
|
||||
set(HDF5_USE_STATIC_LIBRARIES OFF)
|
||||
add_compile_definitions(H5_BUILT_AS_DYNAMIC_LIB)
|
||||
endif()
|
||||
endif()
|
||||
cmake_policy(POP)
|
||||
endif()
|
||||
_find_package(${ARGS})
|
||||
61
externals/vcpkg/ports/hdf5/vcpkg.json
vendored
Executable file
61
externals/vcpkg/ports/hdf5/vcpkg.json
vendored
Executable file
@@ -0,0 +1,61 @@
|
||||
{
|
||||
"name": "hdf5",
|
||||
"version": "1.12.2",
|
||||
"port-version": 1,
|
||||
"description": "HDF5 is a data model, library, and file format for storing and managing data",
|
||||
"homepage": "https://www.hdfgroup.org/downloads/hdf5/",
|
||||
"license": "BSD-3-Clause",
|
||||
"supports": "!uwp",
|
||||
"dependencies": [
|
||||
{
|
||||
"name": "vcpkg-cmake",
|
||||
"host": true
|
||||
},
|
||||
{
|
||||
"name": "vcpkg-cmake-config",
|
||||
"host": true
|
||||
}
|
||||
],
|
||||
"default-features": [
|
||||
"szip",
|
||||
"zlib"
|
||||
],
|
||||
"features": {
|
||||
"cpp": {
|
||||
"description": "Builds cpp lib"
|
||||
},
|
||||
"fortran": {
|
||||
"description": "Build with fortran"
|
||||
},
|
||||
"parallel": {
|
||||
"description": "parallel support for HDF5",
|
||||
"dependencies": [
|
||||
"mpi"
|
||||
]
|
||||
},
|
||||
"szip": {
|
||||
"description": "Build with szip",
|
||||
"dependencies": [
|
||||
"szip"
|
||||
]
|
||||
},
|
||||
"threadsafe": {
|
||||
"description": "thread safety for HDF5",
|
||||
"dependencies": [
|
||||
"pthreads"
|
||||
]
|
||||
},
|
||||
"tools": {
|
||||
"description": "Build hdf tools"
|
||||
},
|
||||
"utils": {
|
||||
"description": "Build HDF5 Utils"
|
||||
},
|
||||
"zlib": {
|
||||
"description": "Build with zlib",
|
||||
"dependencies": [
|
||||
"zlib"
|
||||
]
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user