From 0151c07c081dba20642f7a580c814afc629d1970 Mon Sep 17 00:00:00 2001 From: Osyotr Date: Thu, 30 May 2024 19:53:46 +0300 Subject: [PATCH] [boost-math] Fix build on x64-linux-dynamic, add feature legacy (#38728) Fixes #38725 Fixes #38714 Fixed https://github.com/microsoft/vcpkg/issues/38955 --- ports/autodock-vina/CMakeLists.txt | 3 --- ports/autodock-vina/vcpkg.json | 2 +- ports/boost-math/build-old-libs.patch | 8 ++++++-- ports/boost-math/features.cmake | 10 ++++++++++ ports/boost-math/portfile.cmake | 1 + ports/boost-math/vcpkg.json | 9 +++++++-- ports/cctag/vcpkg.json | 9 +++++++-- ports/vcpkg-boost/boost-install.cmake | 2 +- ports/vcpkg-boost/vcpkg.json | 2 +- scripts/boost/generate-ports.ps1 | 8 ++++++++ versions/a-/autodock-vina.json | 5 +++++ versions/b-/boost-math.json | 5 +++++ versions/baseline.json | 8 ++++---- versions/c-/cctag.json | 5 +++++ versions/v-/vcpkg-boost.json | 5 +++++ 15 files changed, 66 insertions(+), 16 deletions(-) create mode 100644 ports/boost-math/features.cmake diff --git a/ports/autodock-vina/CMakeLists.txt b/ports/autodock-vina/CMakeLists.txt index f5ceca6b68..251ce5119f 100644 --- a/ports/autodock-vina/CMakeLists.txt +++ b/ports/autodock-vina/CMakeLists.txt @@ -9,7 +9,6 @@ set(CMAKE_CXX_STANDARD 11) find_package(Boost REQUIRED COMPONENTS filesystem log - math_tr1 program_options random serialization @@ -63,7 +62,6 @@ target_link_libraries(vina Boost::boost Boost::filesystem Boost::log - Boost::math_tr1 Boost::program_options Boost::random Boost::serialization @@ -76,7 +74,6 @@ target_link_libraries(vina_split Boost::boost Boost::filesystem Boost::log - Boost::math_tr1 Boost::program_options Boost::random Boost::serialization diff --git a/ports/autodock-vina/vcpkg.json b/ports/autodock-vina/vcpkg.json index ff36a0c8b7..44f683ce12 100644 --- a/ports/autodock-vina/vcpkg.json +++ b/ports/autodock-vina/vcpkg.json @@ -1,7 +1,7 @@ { "name": "autodock-vina", "version-semver": "1.2.5", - "port-version": 2, + "port-version": 3, "description": "AutoDock Vina is one of the fastest and most widely used open-source docking engines.", "homepage": "http://vina.scripps.edu/", "dependencies": [ diff --git a/ports/boost-math/build-old-libs.patch b/ports/boost-math/build-old-libs.patch index 8349fd2a45..49c58cbc4e 100644 --- a/ports/boost-math/build-old-libs.patch +++ b/ports/boost-math/build-old-libs.patch @@ -2,10 +2,12 @@ diff --git a/CMakeLists.txt b/CMakeLists.txt index 7e7790271c..cd08a77e4a 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt -@@ -41,6 +41,104 @@ else() +@@ -41,6 +41,108 @@ else() endif() ++option(BOOST_MATH_BUILD_WITH_LEGACY_FUNCTIONS "" OFF) ++if(BOOST_MATH_BUILD_WITH_LEGACY_FUNCTIONS) +include(CheckCXXSourceCompiles) +set(CMAKE_REQUIRED_LIBRARIES Boost::config) +set(CMAKE_REQUIRED_INCLUDES "${CMAKE_CURRENT_SOURCE_DIR}/include") @@ -80,9 +82,11 @@ index 7e7790271c..cd08a77e4a 100644 + +foreach(type IN LISTS types) + add_library(boost_math_tr1${type} ${TR1_SOURCES${type}}) ++ target_link_libraries(boost_math_tr1${type} PUBLIC Boost::config) + target_include_directories(boost_math_tr1${type} PRIVATE src/tr1) + target_include_directories(boost_math_tr1${type} PRIVATE include) + add_library(boost_math_c99${type} ${C99_SOURCES${type}}) ++ target_link_libraries(boost_math_c99${type} PUBLIC Boost::config) + target_include_directories(boost_math_c99${type} PRIVATE src/tr1) + target_include_directories(boost_math_c99${type} PRIVATE include) + if(BUILD_SHARED_LIBS) @@ -102,7 +106,7 @@ index 7e7790271c..cd08a77e4a 100644 + boost_install_target(TARGET boost_math_tr1${type} VERSION ${BOOST_SUPERPROJECT_VERSION}) + boost_install_target(TARGET boost_math_c99${type} VERSION ${BOOST_SUPERPROJECT_VERSION}) +endforeach() -+ ++endif() + # Only enable tests when we're the root project if(CMAKE_SOURCE_DIR STREQUAL CMAKE_CURRENT_SOURCE_DIR) diff --git a/ports/boost-math/features.cmake b/ports/boost-math/features.cmake new file mode 100644 index 0000000000..c63efe8374 --- /dev/null +++ b/ports/boost-math/features.cmake @@ -0,0 +1,10 @@ +vcpkg_check_features( + OUT_FEATURE_OPTIONS + FEATURE_OPTIONS + FEATURES + "legacy" BOOST_MATH_BUILD_WITH_LEGACY_FUNCTIONS +) + +if(NOT BOOST_MATH_BUILD_WITH_LEGACY_FUNCTIONS) + set(Z_VCPKG_BOOST_FORCE_HEADER_ONLY ON) +endif() diff --git a/ports/boost-math/portfile.cmake b/ports/boost-math/portfile.cmake index 1b5f9f3ea5..b9aa932097 100644 --- a/ports/boost-math/portfile.cmake +++ b/ports/boost-math/portfile.cmake @@ -12,6 +12,7 @@ vcpkg_from_github( ) set(FEATURE_OPTIONS "") +include("${CMAKE_CURRENT_LIST_DIR}/features.cmake") boost_configure_and_install( SOURCE_PATH "${SOURCE_PATH}" OPTIONS ${FEATURE_OPTIONS} diff --git a/ports/boost-math/vcpkg.json b/ports/boost-math/vcpkg.json index 757cfe0208..b5f5d864fd 100644 --- a/ports/boost-math/vcpkg.json +++ b/ports/boost-math/vcpkg.json @@ -2,7 +2,7 @@ "$comment": "Automatically generated by scripts/boost/generate-ports.ps1", "name": "boost-math", "version": "1.85.0", - "port-version": 1, + "port-version": 2, "description": "Boost math module", "homepage": "https://www.boost.org/libs/math", "license": "BSL-1.0", @@ -56,5 +56,10 @@ "name": "boost-throw-exception", "version>=": "1.85.0" } - ] + ], + "features": { + "legacy": { + "description": "Build the legacy C99 and TR1 libraries" + } + } } diff --git a/ports/cctag/vcpkg.json b/ports/cctag/vcpkg.json index 0946bf8d09..167bbfebba 100644 --- a/ports/cctag/vcpkg.json +++ b/ports/cctag/vcpkg.json @@ -1,7 +1,7 @@ { "name": "cctag", "version-semver": "1.0.2", - "port-version": 6, + "port-version": 7, "maintainers": "alicevision-team@googlegroups.com", "description": "Computer vision library for detecting CCTag markers made up of concentric circles", "homepage": "https://github.com/alicevision/CCTag", @@ -18,7 +18,12 @@ "boost-foreach", "boost-iterator", "boost-lexical-cast", - "boost-math", + { + "name": "boost-math", + "features": [ + "legacy" + ] + }, "boost-mpl", "boost-multi-array", "boost-program-options", diff --git a/ports/vcpkg-boost/boost-install.cmake b/ports/vcpkg-boost/boost-install.cmake index 4a0255a3a2..9cae95eb19 100644 --- a/ports/vcpkg-boost/boost-install.cmake +++ b/ports/vcpkg-boost/boost-install.cmake @@ -8,7 +8,7 @@ function(boost_configure_and_install) set(boost_lib_name_config "${boost_lib_name}") set(headers_only OFF) - if(NOT EXISTS "${arg_SOURCE_PATH}/src") # regex|system|math are header only and only install libs due to compat + if(NOT EXISTS "${arg_SOURCE_PATH}/src" OR Z_VCPKG_BOOST_FORCE_HEADER_ONLY) # regex|system|math are header only and only install libs due to compat set(headers_only ON) set(VCPKG_BUILD_TYPE release) endif() diff --git a/ports/vcpkg-boost/vcpkg.json b/ports/vcpkg-boost/vcpkg.json index 781a6c0013..e85bef9609 100644 --- a/ports/vcpkg-boost/vcpkg.json +++ b/ports/vcpkg-boost/vcpkg.json @@ -1,5 +1,5 @@ { "name": "vcpkg-boost", - "version-date": "2024-04-25", + "version-date": "2024-05-15", "license": "MIT" } diff --git a/scripts/boost/generate-ports.ps1 b/scripts/boost/generate-ports.ps1 index 8ed8d3f07e..2c05742de5 100644 --- a/scripts/boost/generate-ports.ps1 +++ b/scripts/boost/generate-ports.ps1 @@ -29,6 +29,7 @@ $semverVersion = ($version -replace "(\d+(\.\d+){1,3}).*", "`$1") $defaultPortVersion = 1 $portVersions = @{ 'boost-container' = 1; + 'boost-math' = 2; } function Get-PortVersion { @@ -108,6 +109,13 @@ $portData = @{ } }; "boost-log" = @{ "supports" = "!uwp & !emscripten" }; + "boost-math" = @{ + "features" = @{ + "legacy" = @{ + "description" = "Build the legacy C99 and TR1 libraries"; + } + } + }; "boost-mpi" = @{ "dependencies" = @("mpi"); "supports" = "!uwp"; diff --git a/versions/a-/autodock-vina.json b/versions/a-/autodock-vina.json index 788e48d361..470fc0d3e5 100644 --- a/versions/a-/autodock-vina.json +++ b/versions/a-/autodock-vina.json @@ -1,5 +1,10 @@ { "versions": [ + { + "git-tree": "17529fd4b800ef3453f99cf2607e64fea59f6481", + "version-semver": "1.2.5", + "port-version": 3 + }, { "git-tree": "0a1f8b9271d163893c7bcb8f7097e38be9888519", "version-semver": "1.2.5", diff --git a/versions/b-/boost-math.json b/versions/b-/boost-math.json index c25cda0a0d..0a7b420ed2 100644 --- a/versions/b-/boost-math.json +++ b/versions/b-/boost-math.json @@ -1,5 +1,10 @@ { "versions": [ + { + "git-tree": "ac6833c403ae80c2a96e0a04795df91b1197999c", + "version": "1.85.0", + "port-version": 2 + }, { "git-tree": "073abacf431a555a65b186e63482d3ff47b0e615", "version": "1.85.0", diff --git a/versions/baseline.json b/versions/baseline.json index 66a57c7aba..6cdaae6d8f 100644 --- a/versions/baseline.json +++ b/versions/baseline.json @@ -350,7 +350,7 @@ }, "autodock-vina": { "baseline": "1.2.5", - "port-version": 2 + "port-version": 3 }, "avcpp": { "baseline": "2.4.0", @@ -1022,7 +1022,7 @@ }, "boost-math": { "baseline": "1.85.0", - "port-version": 1 + "port-version": 2 }, "boost-metaparse": { "baseline": "1.85.0", @@ -1526,7 +1526,7 @@ }, "cctag": { "baseline": "1.0.2", - "port-version": 6 + "port-version": 7 }, "cctz": { "baseline": "2.4", @@ -9061,7 +9061,7 @@ "port-version": 0 }, "vcpkg-boost": { - "baseline": "2024-04-25", + "baseline": "2024-05-15", "port-version": 0 }, "vcpkg-cmake": { diff --git a/versions/c-/cctag.json b/versions/c-/cctag.json index 1e38808d96..ba3eee9d82 100644 --- a/versions/c-/cctag.json +++ b/versions/c-/cctag.json @@ -1,5 +1,10 @@ { "versions": [ + { + "git-tree": "bc6878b6e5119f0b4b5f90b4b09e02bd50c9b213", + "version-semver": "1.0.2", + "port-version": 7 + }, { "git-tree": "56e88632d9e1fd1d826e9486e66533cb8baddef8", "version-semver": "1.0.2", diff --git a/versions/v-/vcpkg-boost.json b/versions/v-/vcpkg-boost.json index 07087c205b..0fdcf686e6 100644 --- a/versions/v-/vcpkg-boost.json +++ b/versions/v-/vcpkg-boost.json @@ -1,5 +1,10 @@ { "versions": [ + { + "git-tree": "aca8ab6ec76d120c4482a629de23cad5ad7e4643", + "version-date": "2024-05-15", + "port-version": 0 + }, { "git-tree": "885223b657578128c0556fe6b53cfec8cbf50e12", "version-date": "2024-04-25",