From 3fd9721c11df427a9c2ca6b0d7c33fed48fd5634 Mon Sep 17 00:00:00 2001 From: Alexander Neumann <30894796+Neumann-A@users.noreply.github.com> Date: Wed, 8 Jan 2025 09:13:18 +0100 Subject: [PATCH] Fix more ports --- ports/icu/portfile.cmake | 1 + ports/libgcrypt/portfile.cmake | 4 ++++ .../port-customization/gettext-libintl.cmake | 2 ++ triplets/x64-win-llvm/x64-win-llvm-toolchain.cmake | 14 +++++--------- .../port-customization/quickfast.cmake | 2 ++ 5 files changed, 14 insertions(+), 9 deletions(-) create mode 100644 triplets/x64-win-llvm/port-customization/gettext-libintl.cmake create mode 100644 triplets/x64-win-msvc/port-customization/quickfast.cmake diff --git a/ports/icu/portfile.cmake b/ports/icu/portfile.cmake index 26015d26585783..7c85d6741f45a5 100644 --- a/ports/icu/portfile.cmake +++ b/ports/icu/portfile.cmake @@ -158,6 +158,7 @@ vcpkg_copy_pdbs() vcpkg_fixup_pkgconfig() vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/tools/icu/bin/icu-config" "${CURRENT_INSTALLED_DIR}" "`dirname $0`/../../../" IGNORE_UNCHANGED) +vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/tools/icu/bin/icu-config" "${CURRENT_HOST_INSTALLED_DIR}" "`dirname $0`/../../../../${_HOST_TRIPLET}/" IGNORE_UNCHANGED) file(INSTALL "${CMAKE_CURRENT_LIST_DIR}/vcpkg-cmake-wrapper.cmake" DESTINATION "${CURRENT_PACKAGES_DIR}/share/${PORT}") vcpkg_install_copyright(FILE_LIST "${SOURCE_PATH}/LICENSE") diff --git a/ports/libgcrypt/portfile.cmake b/ports/libgcrypt/portfile.cmake index 37e7271d5fbf2b..3310d965d4fdf5 100644 --- a/ports/libgcrypt/portfile.cmake +++ b/ports/libgcrypt/portfile.cmake @@ -49,12 +49,16 @@ if(NOT VCPKG_CROSSCOMPILING) endif() set(install_prefix "${CURRENT_INSTALLED_DIR}") +set(host_install_prefix "${CURRENT_HOST_INSTALLED_DIR}") if(VCPKG_HOST_IS_WINDOWS) string(REGEX REPLACE "^([a-zA-Z]):/" "/\\1/" install_prefix "${install_prefix}") + string(REGEX REPLACE "^([a-zA-Z]):/" "/\\1/" host_install_prefix "${host_install_prefix}") endif() vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/tools/${PORT}/bin/libgcrypt-config" "${install_prefix}" "`dirname $0`/../../..") +vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/tools/${PORT}/bin/libgcrypt-config" "${host_install_prefix}" "`dirname $0`/../../../../${_HOST_TRIPLET}") if(NOT VCPKG_BUILD_TYPE) vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/tools/${PORT}/debug/bin/libgcrypt-config" "${install_prefix}" "`dirname $0`/../../../..") + vcpkg_replace_string("${CURRENT_PACKAGES_DIR}/tools/${PORT}/debug/bin/libgcrypt-config" "${host_install_prefix}" "`dirname $0`/../../../../../${_HOST_TRIPLET}") endif() file(REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/debug/share") diff --git a/triplets/x64-win-llvm/port-customization/gettext-libintl.cmake b/triplets/x64-win-llvm/port-customization/gettext-libintl.cmake new file mode 100644 index 00000000000000..eddec382ebea11 --- /dev/null +++ b/triplets/x64-win-llvm/port-customization/gettext-libintl.cmake @@ -0,0 +1,2 @@ +list(APPEND VCPKG_CMAKE_CONFIGURE_OPTIONS "-DCMAKE_AR=llvm-ar.exe") +set(ENV{AR} "llvm-ar.exe") \ No newline at end of file diff --git a/triplets/x64-win-llvm/x64-win-llvm-toolchain.cmake b/triplets/x64-win-llvm/x64-win-llvm-toolchain.cmake index 22e73174a36e9c..25a1488631b7b5 100644 --- a/triplets/x64-win-llvm/x64-win-llvm-toolchain.cmake +++ b/triplets/x64-win-llvm/x64-win-llvm-toolchain.cmake @@ -128,19 +128,15 @@ if(NOT _VCPKG_WINDOWS_TOOLCHAIN) message(FATAL_ERROR "Invalid setting for VCPKG_CRT_LINKAGE: \"${VCPKG_CRT_LINKAGE}\". It must be \"static\" or \"dynamic\"") endif() - set(CHARSET_FLAG "/utf-8") - if (NOT VCPKG_SET_CHARSET_FLAG OR VCPKG_PLATFORM_TOOLSET MATCHES "v120") - # VS 2013 does not support /utf-8 + set(CHARSET_FLAG " /utf-8") + if (NOT VCPKG_SET_CHARSET_FLAG) set(CHARSET_FLAG "") endif() - set(MP_BUILD_FLAG "") - if(NOT (CMAKE_CXX_COMPILER MATCHES "clang-cl.exe")) - set(MP_BUILD_FLAG "/MP ") - endif() + set(common_flags "/nologo /DWIN32 /D_WINDOWS -Wno-implicit-function-declaration${CHARSET_FLAG}") - set(CMAKE_CXX_FLAGS " /nologo /DWIN32 /D_WINDOWS ${CHARSET_FLAG} /GR /EHsc ${MP_BUILD_FLAG}${VCPKG_CXX_FLAGS}" CACHE STRING "") - set(CMAKE_C_FLAGS " /nologo /DWIN32 /D_WINDOWS ${CHARSET_FLAG} ${MP_BUILD_FLAG}${VCPKG_C_FLAGS}" CACHE STRING "") + set(CMAKE_CXX_FLAGS "${common_flags} /GR /EHsc ${VCPKG_CXX_FLAGS}" CACHE STRING "") + set(CMAKE_C_FLAGS "${common_flags} ${VCPKG_C_FLAGS}" CACHE STRING "") if(VCPKG_TARGET_ARCHITECTURE STREQUAL "arm64ec") string(APPEND CMAKE_CXX_FLAGS " /arm64EC /D_AMD64_ /DAMD64 /D_ARM64EC_ /DARM64EC") diff --git a/triplets/x64-win-msvc/port-customization/quickfast.cmake b/triplets/x64-win-msvc/port-customization/quickfast.cmake new file mode 100644 index 00000000000000..c8d8b2eb439a37 --- /dev/null +++ b/triplets/x64-win-msvc/port-customization/quickfast.cmake @@ -0,0 +1,2 @@ +set(ENV{CMAKE_WINDOWS_KITS_10_DIR} "$ENV{WindowsSdkDir}") +list(APPEND VCPKG_CMAKE_CONFIGURE_OPTIONS "-DCMAKE_POLICY_DEFAULT_CMP0149=NEW")