aboutsummaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
authornicole mazzuca <mazzucan@outlook.com>2021-02-18 16:27:47 -0800
committerGitHub <noreply@github.com>2021-02-18 16:27:47 -0800
commit1bb5ea10a3ff03783b37369eb5180a50557f3b0f (patch)
tree577dc1d0894fec14aa218800dbdb996c2c9dc69a /scripts
parent3a588ab16c8ab57e86e033e62e9963fceb8b0365 (diff)
downloadvcpkg-1bb5ea10a3ff03783b37369eb5180a50557f3b0f.tar.gz
vcpkg-1bb5ea10a3ff03783b37369eb5180a50557f3b0f.zip
[scripts-audit] vcpkg.cmake (#16061)
* [vcpkg.cmake] modify to get in line with the audit See PR #16055 This also (attempts to) allow vcpkg.cmake to run with cmake 3.0; we had a VERSION_GREATER_EQUAL check, but that if keyword was added in cmake 3.7. * s/target_name/package_name in find_package * depend on z_vcpkg_function_arguments instead of a custom macro also, as a drive-by, switch to foreach(X IN LISTS ...) * split the utility macros/functions out additionally, move the options and settings to the top of the file * move more options and settings to the top * fix name of file * fix ras code comments * remove z_vcpkg_utilities due to export * add cmake_policy(PUSH|POP) * add VCPKG_INSTALLED_DIR input variable * add .cmakestamp to vcpkg_installed * fix osx ifs to use quotes also, remove spaces between if and (, to keep style consistent (mostly for ease of grepping...) * fix bug fixed by #16193 * move z_vcpkg_add_fatal_error up * fix RANGE for reals
Diffstat (limited to 'scripts')
-rw-r--r--scripts/buildsystems/vcpkg.cmake838
-rw-r--r--scripts/cmake/z_vcpkg_function_arguments.cmake3
2 files changed, 526 insertions, 315 deletions
diff --git a/scripts/buildsystems/vcpkg.cmake b/scripts/buildsystems/vcpkg.cmake
index 1ab9d033e..ef7a7a54d 100644
--- a/scripts/buildsystems/vcpkg.cmake
+++ b/scripts/buildsystems/vcpkg.cmake
@@ -1,75 +1,90 @@
# Mark variables as used so cmake doesn't complain about them
mark_as_advanced(CMAKE_TOOLCHAIN_FILE)
-# VCPKG toolchain options.
-option(VCPKG_VERBOSE "Enables messages from the VCPKG toolchain for debugging purposes." OFF)
-mark_as_advanced(VCPKG_VERBOSE)
-
-include(CMakeDependentOption)
+# NOTE: to figure out what cmake versions are required for different things,
+# grep for `CMake 3`. All version requirement comments should follow that format.
-function(_vcpkg_get_directory_name_of_file_above OUT DIRECTORY FILENAME)
- set(_vcpkg_get_dir_candidate ${DIRECTORY})
- while(IS_DIRECTORY ${_vcpkg_get_dir_candidate} AND NOT DEFINED _vcpkg_get_dir_out)
- if(EXISTS ${_vcpkg_get_dir_candidate}/${FILENAME})
- set(_vcpkg_get_dir_out ${_vcpkg_get_dir_candidate})
- else()
- get_filename_component(_vcpkg_get_dir_candidate_tmp ${_vcpkg_get_dir_candidate} DIRECTORY)
- if(_vcpkg_get_dir_candidate STREQUAL _vcpkg_get_dir_candidate_tmp) # we've reached the root
- set(_vcpkg_get_dir_out "${OUT}-NOTFOUND")
- else()
- set(_vcpkg_get_dir_candidate ${_vcpkg_get_dir_candidate_tmp})
- endif()
- endif()
- endwhile()
+#[===[.md:
+# z_vcpkg_add_fatal_error
+Add a fatal error.
- set(${OUT} ${_vcpkg_get_dir_out} CACHE INTERNAL "_vcpkg_get_directory_name_of_file_above: ${OUT}")
-endfunction()
+```cmake
+z_vcpkg_add_fatal_error(<message>...)
+```
-#[===[
We use this system, instead of `message(FATAL_ERROR)`,
since cmake prints a lot of nonsense if the toolchain errors out before it's found the build tools.
-This `_VCPKG_HAS_FATAL_ERROR` must be checked before any filesystem operations are done,
+This `Z_VCPKG_HAS_FATAL_ERROR` must be checked before any filesystem operations are done,
since otherwise you might be doing something with bad variables set up.
#]===]
-set(_VCPKG_FATAL_ERROR)
-set(_VCPKG_HAS_FATAL_ERROR OFF)
-function(_vcpkg_add_fatal_error ERROR)
- if(NOT _VCPKG_HAS_FATAL_ERROR)
- set(_VCPKG_HAS_FATAL_ERROR ON PARENT_SCOPE)
- set(_VCPKG_FATAL_ERROR "${ERROR}" PARENT_SCOPE)
+# this is defined above everything else so that it can be used.
+set(Z_VCPKG_FATAL_ERROR)
+set(Z_VCPKG_HAS_FATAL_ERROR OFF)
+function(z_vcpkg_add_fatal_error ERROR)
+ if(NOT Z_VCPKG_HAS_FATAL_ERROR)
+ set(Z_VCPKG_HAS_FATAL_ERROR ON PARENT_SCOPE)
+ set(Z_VCPKG_FATAL_ERROR "${ERROR}" PARENT_SCOPE)
else()
- string(APPEND _VCPKG_FATAL_ERROR "\n${ERROR}")
+ string(APPEND Z_VCPKG_FATAL_ERROR "\n${ERROR}")
endif()
endfunction()
+set(Z_VCPKG_CMAKE_REQUIRED_MINIMUM_VERSION "3.1")
+if(CMAKE_VERSION VERSION_LESS Z_VCPKG_CMAKE_REQUIRED_MINIMUM_VERSION)
+ message(FATAL_ERROR "vcpkg.cmake requires at least CMake ${Z_VCPKG_CMAKE_REQUIRED_MINIMUM_VERSION}.")
+endif()
+# this policy is required for this file; thus, CMake 3.1 is required.
+cmake_policy(PUSH)
+cmake_policy(SET CMP0054 NEW)
+
+include(CMakeDependentOption)
+
+# VCPKG toolchain options.
+option(VCPKG_VERBOSE "Enables messages from the VCPKG toolchain for debugging purposes." OFF)
+mark_as_advanced(VCPKG_VERBOSE)
+
+option(VCPKG_APPLOCAL_DEPS "Automatically copy dependencies into the output directory for executables." ON)
+option(X_VCPKG_APPLOCAL_DEPS_SERIALIZED "(experimental) Add USES_TERMINAL to VCPKG_APPLOCAL_DEPS to force serialization." OFF)
+option(X_VCPKG_APPLOCAL_DEPS_INSTALL "(experimental) Automatically copy dependencies into the install target directory for executables." OFF)
+
+# Manifest options and settings
if(NOT DEFINED VCPKG_MANIFEST_DIR)
if(EXISTS "${CMAKE_SOURCE_DIR}/vcpkg.json")
- set(_VCPKG_MANIFEST_DIR "${CMAKE_SOURCE_DIR}")
+ set(VCPKG_MANIFEST_DIR "${CMAKE_SOURCE_DIR}")
endif()
+endif()
+set(VCPKG_MANIFEST_DIR "${VCPKG_MANIFEST_DIR}"
+ CACHE PATH "The path to the vcpkg manifest directory." FORCE)
+
+if(DEFINED VCPKG_MANIFEST_DIR AND NOT VCPKG_MANIFEST_DIR STREQUAL "")
+ set(Z_VCPKG_HAS_MANIFEST_DIR ON)
else()
- set(_VCPKG_MANIFEST_DIR ${VCPKG_MANIFEST_DIR})
+ set(Z_VCPKG_HAS_MANIFEST_DIR OFF)
endif()
-if(NOT DEFINED VCPKG_MANIFEST_MODE)
- if(_VCPKG_MANIFEST_DIR)
- set(VCPKG_MANIFEST_MODE ON)
- else()
- set(VCPKG_MANIFEST_MODE OFF)
- endif()
-elseif(VCPKG_MANIFEST_MODE AND NOT _VCPKG_MANIFEST_DIR)
- _vcpkg_add_fatal_error(
- "vcpkg manifest mode was enabled, but we couldn't find a manifest file (vcpkg.json) "
- "in any directories above ${CMAKE_CURRENT_SOURCE_DIR}. Please add a manifest, or "
- "disable manifests by turning off VCPKG_MANIFEST_MODE.")
+
+option(VCPKG_MANIFEST_MODE "Use manifest mode, as opposed to classic mode." "${Z_VCPKG_HAS_MANIFEST_DIR}")
+
+if(VCPKG_MANIFEST_MODE AND NOT Z_VCPKG_HAS_MANIFEST_DIR)
+ z_vcpkg_add_fatal_error(
+"vcpkg manifest mode was enabled, but we couldn't find a manifest file (vcpkg.json)
+in the current source directory (${CMAKE_CURRENT_SOURCE_DIR}).
+Please add a manifest, or disable manifests by turning off VCPKG_MANIFEST_MODE."
+ )
endif()
-if(NOT DEFINED _INTERNAL_CHECK_VCPKG_MANIFEST_MODE)
- set(_INTERNAL_CHECK_VCPKG_MANIFEST_MODE "${VCPKG_MANIFEST_MODE}"
+if(NOT DEFINED CACHE{Z_VCPKG_CHECK_MANIFEST_MODE})
+ set(Z_VCPKG_CHECK_MANIFEST_MODE "${VCPKG_MANIFEST_MODE}"
CACHE INTERNAL "Making sure VCPKG_MANIFEST_MODE doesn't change")
endif()
-if(NOT VCPKG_MANIFEST_MODE STREQUAL _INTERNAL_CHECK_VCPKG_MANIFEST_MODE)
- _vcpkg_add_fatal_error([[
+if(NOT VCPKG_MANIFEST_MODE AND Z_VCPKG_CHECK_MANIFEST_MODE)
+ z_vcpkg_add_fatal_error([[
+vcpkg manifest mode was disabled for a build directory where it was initially enabled.
+This is not supported. Please delete the build directory and reconfigure.
+]])
+elseif(VCPKG_MANIFEST_MODE AND NOT Z_VCPKG_CHECK_MANIFEST_MODE)
+ z_vcpkg_add_fatal_error([[
vcpkg manifest mode was enabled for a build directory where it was initially disabled.
This is not supported. Please delete the build directory and reconfigure.
]])
@@ -84,16 +99,215 @@ Install the dependencies listed in your manifest:
"VCPKG_MANIFEST_MODE"
OFF)
+if(VCPKG_MANIFEST_INSTALL)
+ set(VCPKG_BOOTSTRAP_OPTIONS "${VCPKG_BOOTSTRAP_OPTIONS}" CACHE STRING "Additional options to bootstrap vcpkg" FORCE)
+ set(VCPKG_OVERLAY_PORTS "${VCPKG_OVERLAY_PORTS}" CACHE STRING "Overlay ports to use for vcpkg install in manifest mode" FORCE)
+ set(VCPKG_OVERLAY_TRIPLETS "${VCPKG_OVERLAY_TRIPLETS}" CACHE STRING "Overlay triplets to use for vcpkg install in manifest mode" FORCE)
+ set(VCPKG_INSTALL_OPTIONS "${VCPKG_INSTALL_OPTIONS}" CACHE STRING "Additional install options to pass to vcpkg" FORCE)
+ set(Z_VCPKG_UNUSED VCPKG_BOOTSTRAP_OPTIONS)
+ set(Z_VCPKG_UNUSED VCPKG_OVERLAY_PORTS)
+ set(Z_VCPKG_UNUSED VCPKG_OVERLAY_TRIPLETS)
+ set(Z_VCPKG_UNUSED VCPKG_INSTALL_OPTIONS)
+endif()
+
+# CMake helper utilities
+
+#[===[.md:
+# z_vcpkg_function_arguments
+
+Get a list of the arguments which were passed in.
+Unlike `ARGV`, which is simply the arguments joined with `;`,
+so that `(A B)` is not distinguishable from `("A;B")`,
+this macro gives `"A;B"` for the first argument list,
+and `"A\;B"` for the second.
+
+```cmake
+z_vcpkg_function_arguments(<out-var> [<N>])
+```
+
+`z_vcpkg_function_arguments` gets the arguments between `ARGV<N>` and the last argument.
+`<N>` defaults to `0`, so that all arguments are taken.
+
+## Example:
+```cmake
+function(foo_replacement)
+ z_vcpkg_function_arguments(ARGS)
+ foo(${ARGS})
+ ...
+endfunction()
+```
+#]===]
+
+# NOTE: this function definition is copied directly from scripts/cmake/z_vcpkg_function_arguments.cmake
+# do not make changes here without making the same change there.
+macro(z_vcpkg_function_arguments OUT_VAR)
+ if("${ARGC}" EQUAL 1)
+ set(z_vcpkg_function_arguments_FIRST_ARG 0)
+ elseif("${ARGC}" EQUAL 2)
+ set(z_vcpkg_function_arguments_FIRST_ARG "${ARGV1}")
+ else()
+ # vcpkg bug
+ message(FATAL_ERROR "z_vcpkg_function_arguments: invalid arguments (${ARGV})")
+ endif()
+
+ set("${OUT_VAR}")
+
+ # this allows us to get the value of the enclosing function's ARGC
+ set(z_vcpkg_function_arguments_ARGC_NAME "ARGC")
+ set(z_vcpkg_function_arguments_ARGC "${${z_vcpkg_function_arguments_ARGC_NAME}}")
+
+ math(EXPR z_vcpkg_function_arguments_LAST_ARG "${z_vcpkg_function_arguments_ARGC} - 1")
+ # GREATER_EQUAL added in CMake 3.7
+ if(NOT z_vcpkg_function_arguments_LAST_ARG LESS z_vcpkg_function_arguments_FIRST_ARG)
+ foreach(z_vcpkg_function_arguments_N RANGE "${z_vcpkg_function_arguments_FIRST_ARG}" "${z_vcpkg_function_arguments_LAST_ARG}")
+ string(REPLACE ";" "\\;" z_vcpkg_function_arguments_ESCAPED_ARG "${ARGV${z_vcpkg_function_arguments_N}}")
+ list(APPEND "${OUT_VAR}" "${z_vcpkg_function_arguments_ESCAPED_ARG}")
+ endforeach()
+ endif()
+endmacro()
+
+#[===[.md:
+# z_vcpkg_*_parent_scope_export
+If you need to re-export variables to a parent scope from a call,
+you can put these around the call to re-export those variables that have changed locally
+to parent scope.
+
+## Usage:
+```cmake
+z_vcpkg_start_parent_scope_export(
+ [PREFIX <PREFIX>]
+)
+z_vcpkg_complete_parent_scope_export(
+ [PREFIX <PREFIX>]
+ [IGNORE_REGEX <REGEX>]
+)
+```
+
+## Parameters
+### PREFIX
+The prefix to use to store the old variable values; defaults to `Z_VCPKG_PARENT_SCOPE_EXPORT`.
+The value of each variable `<VAR>` will be stored in `${PREFIX}_<VAR>` by `start`,
+and then every variable which is different from `${PREFIX}_VAR` will be re-exported by `complete`.
+
+### IGNORE_REGEX
+Variables with names matching this regex will not be exported even if their value has changed.
+
+## Example:
+```cmake
+z_vcpkg_start_parent_scope_export()
+_find_package(blah)
+z_vcpkg_complete_parent_scope_export()
+```
+#]===]
+# Notes: these do not use `cmake_parse_arguments` in order to support older versions of cmake,
+# pre-3.7 and PARSE_ARGV
+macro(z_vcpkg_start_parent_scope_export)
+ if("${ARGC}" EQUAL "0")
+ set(z_vcpkg_parent_scope_export_PREFIX "Z_VCPKG_PARENT_SCOPE_EXPORT")
+ elseif("${ARGC}" EQUAL "2" AND "${ARGV0}" STREQUAL "PREFIX")
+ set(z_vcpkg_parent_scope_export_PREFIX "${ARGV1}")
+ else()
+ message(FATAL_ERROR "Invalid parameters to z_vcpkg_start_parent_scope_export: (${ARGV})")
+ endif()
+ get_property(z_vcpkg_parent_scope_export_VARIABLE_LIST
+ DIRECTORY PROPERTY "VARIABLES")
+ foreach(z_vcpkg_parent_scope_export_VARIABLE IN LISTS z_vcpkg_parent_scope_export_VARIABLE_LIST)
+ set("${z_vcpkg_parent_scope_export_PREFIX}_${z_vcpkg_parent_scope_export_VARIABLE}" "${${z_vcpkg_parent_scope_export_VARIABLE}}")
+ endforeach()
+endmacro()
+
+macro(z_vcpkg_complete_parent_scope_export)
+ set(z_vcpkg_parent_scope_export_PREFIX_FILLED OFF)
+ if("${ARGC}" EQUAL "0")
+ # do nothing, replace with default values
+ elseif("${ARGC}" EQUAL "2")
+ if("${ARGV0}" STREQUAL "PREFIX")
+ set(z_vcpkg_parent_scope_export_PREFIX_FILLED ON)
+ set(z_vcpkg_parent_scope_export_PREFIX "${ARGV1}")
+ elseif("${ARGV0}" STREQUAL "IGNORE_REGEX")
+ set(z_vcpkg_parent_scope_export_IGNORE_REGEX "${ARGV1}")
+ else()
+ message(FATAL_ERROR "Invalid arguments to z_vcpkg_complete_parent_scope_export: (${ARGV})")
+ endif()
+ elseif("${ARGC}" EQUAL "4")
+ if("${ARGV0}" STREQUAL "PREFIX" AND "${ARGV2}" STREQUAL "IGNORE_REGEX")
+ set(z_vcpkg_parent_scope_export_PREFIX_FILLED ON)
+ set(z_vcpkg_parent_scope_export_PREFIX "${ARGV1}")
+ set(z_vcpkg_parent_scope_export_IGNORE_REGEX "${ARGV3}")
+ elseif("${ARGV0}" STREQUAL "IGNORE_REGEX" AND "${ARGV2}" STREQUAL "PREFIX")
+ set(z_vcpkg_parent_scope_export_IGNORE_REGEX "${ARGV1}")
+ set(z_vcpkg_parent_scope_export_PREFIX_FILLED ON)
+ set(z_vcpkg_parent_scope_export_PREFIX "${ARGV3}")
+ else()
+ message(FATAL_ERROR "Invalid arguments to z_vcpkg_start_parent_scope_export: (${ARGV})")
+ endif()
+ else()
+ message(FATAL_ERROR "Invalid arguments to z_vcpkg_complete_parent_scope_export: (${ARGV})")
+ endif()
+
+ if(NOT z_vcpkg_parent_scope_export_PREFIX)
+ set(z_vcpkg_parent_scope_export_PREFIX "Z_VCPKG_PARENT_SCOPE_EXPORT")
+ endif()
+
+ get_property(z_vcpkg_parent_scope_export_VARIABLE_LIST
+ DIRECTORY PROPERTY "VARIABLES")
+ foreach(z_vcpkg_parent_scope_export_VARIABLE IN LISTS z_vcpkg_parent_scope_export_VARIABLE_LIST)
+ if("${z_vcpkg_parent_scope_export_VARIABLE}" MATCHES "^${z_vcpkg_parent_scope_export_PREFIX}_")
+ # skip the backup variables
+ continue()
+ endif()
+ if("${z_vcpkg_parent_scope_export_VARIABLE}" MATCHES "^${z_vcpkg_parent_scope_export_PREFIX}_")
+ # skip the backup variables
+ continue()
+ endif()
+
+ if(DEFINED "${z_vcpkg_parent_scope_export_IGNORE_REGEX}" AND "${z_vcpkg_parent_scope_export_VARIABLE}" MATCHES "${z_vcpkg_parent_scope_export_IGNORE_REGEX}")
+ # skip those variables which should be ignored
+ continue()
+ endif()
+
+ if(NOT "${${z_vcpkg_parent_scope_export_PREFIX}_${z_vcpkg_parent_scope_export_VARIABLE}}" STREQUAL "${${z_vcpkg_parent_scope_export_VARIABLE}}")
+ set("${z_vcpkg_parent_scope_export_VARIABLE}" "${${z_vcpkg_parent_scope_export_VARIABLE}}" PARENT_SCOPE)
+ endif()
+ endforeach()
+endmacro()
+
+#[===[.md:
+# z_vcpkg_set_powershell_path
+
+Gets either the path to powershell or powershell core,
+and places it in the variable Z_VCPKG_POWERSHELL_PATH.
+#]===]
+function(z_vcpkg_set_powershell_path)
+ # Attempt to use pwsh if it is present; otherwise use powershell
+ if(NOT DEFINED Z_VCPKG_POWERSHELL_PATH)
+ find_program(Z_VCPKG_PWSH_PATH pwsh)
+ if(Z_VCPKG_PWSH_PATH)
+ set(Z_VCPKG_POWERSHELL_PATH "${Z_VCPKG_PWSH_PATH}" CACHE INTERNAL "The path to the PowerShell implementation to use.")
+ else()
+ message(DEBUG "vcpkg: Could not find PowerShell Core; falling back to PowerShell")
+ find_program(Z_VCPKG_BUILTIN_POWERSHELL_PATH powershell REQUIRED)
+ if(Z_VCPKG_BUILTIN_POWERSHELL_PATH)
+ set(Z_VCPKG_POWERSHELL_PATH "${Z_VCPKG_BUILTIN_POWERSHELL_PATH}" CACHE INTERNAL "The path to the PowerShell implementation to use.")
+ else()
+ message(WARNING "vcpkg: Could not find PowerShell; using static string 'powershell.exe'")
+ set(Z_VCPKG_POWERSHELL_PATH "powershell.exe" CACHE INTERNAL "The path to the PowerShell implementation to use.")
+ endif()
+ endif()
+ endif() # Z_VCPKG_POWERSHELL_PATH
+endfunction()
+
+
# Determine whether the toolchain is loaded during a try-compile configuration
-get_property(_CMAKE_IN_TRY_COMPILE GLOBAL PROPERTY IN_TRY_COMPILE)
+get_property(Z_VCPKG_CMAKE_IN_TRY_COMPILE GLOBAL PROPERTY IN_TRY_COMPILE)
-if (${CMAKE_VERSION} VERSION_LESS "3.6.0")
- set(_CMAKE_EMULATE_TRY_COMPILE_PLATFORM_VARIABLES ON)
+if(CMAKE_VERSION VERSION_LESS "3.6.0")
+ set(Z_VCPKG_CMAKE_EMULATE_TRY_COMPILE_PLATFORM_VARIABLES ON)
else()
- set(_CMAKE_EMULATE_TRY_COMPILE_PLATFORM_VARIABLES OFF)
+ set(Z_VCPKG_CMAKE_EMULATE_TRY_COMPILE_PLATFORM_VARIABLES OFF)
endif()
-if(_CMAKE_IN_TRY_COMPILE AND _CMAKE_EMULATE_TRY_COMPILE_PLATFORM_VARIABLES)
+if(Z_VCPKG_CMAKE_IN_TRY_COMPILE AND Z_VCPKG_CMAKE_EMULATE_TRY_COMPILE_PLATFORM_VARIABLES)
include("${CMAKE_CURRENT_SOURCE_DIR}/../vcpkg.config.cmake" OPTIONAL)
endif()
@@ -102,6 +316,7 @@ if(VCPKG_CHAINLOAD_TOOLCHAIN_FILE)
endif()
if(VCPKG_TOOLCHAIN)
+ cmake_policy(POP)
return()
endif()
@@ -129,159 +344,169 @@ if(VCPKG_TARGET_TRIPLET)
# recently created value in directory scope. This 'strange' behaviour only happens on the very first configure call since subsequent
# configure call will see the user value as the more recent value. The same logic must be applied to all cache values within this file!
# The FORCE keyword is required to ALWAYS lift the user provided/previously set value into a CACHE value.
- set(VCPKG_TARGET_TRIPLET ${VCPKG_TARGET_TRIPLET} CACHE STRING "Vcpkg target triplet (ex. x86-windows)" FORCE)
+ set(VCPKG_TARGET_TRIPLET "${VCPKG_TARGET_TRIPLET}" CACHE STRING "Vcpkg target triplet (ex. x86-windows)" FORCE)
elseif(CMAKE_GENERATOR_PLATFORM MATCHES "^[Ww][Ii][Nn]32$")
- set(_VCPKG_TARGET_TRIPLET_ARCH x86)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH x86)
elseif(CMAKE_GENERATOR_PLATFORM MATCHES "^[Xx]64$")
- set(_VCPKG_TARGET_TRIPLET_ARCH x64)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH x64)
elseif(CMAKE_GENERATOR_PLATFORM MATCHES "^[Aa][Rr][Mm]$")
- set(_VCPKG_TARGET_TRIPLET_ARCH arm)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH arm)
elseif(CMAKE_GENERATOR_PLATFORM MATCHES "^[Aa][Rr][Mm]64$")
- set(_VCPKG_TARGET_TRIPLET_ARCH arm64)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH arm64)
else()
if(CMAKE_GENERATOR MATCHES "^Visual Studio 14 2015 Win64$")
- set(_VCPKG_TARGET_TRIPLET_ARCH x64)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH x64)
elseif(CMAKE_GENERATOR MATCHES "^Visual Studio 14 2015 ARM$")
- set(_VCPKG_TARGET_TRIPLET_ARCH arm)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH arm)
elseif(CMAKE_GENERATOR MATCHES "^Visual Studio 14 2015$")
- set(_VCPKG_TARGET_TRIPLET_ARCH x86)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH x86)
elseif(CMAKE_GENERATOR MATCHES "^Visual Studio 15 2017 Win64$")
- set(_VCPKG_TARGET_TRIPLET_ARCH x64)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH x64)
elseif(CMAKE_GENERATOR MATCHES "^Visual Studio 15 2017 ARM$")
- set(_VCPKG_TARGET_TRIPLET_ARCH arm)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH arm)
elseif(CMAKE_GENERATOR MATCHES "^Visual Studio 15 2017$")
- set(_VCPKG_TARGET_TRIPLET_ARCH x86)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH x86)
elseif(CMAKE_GENERATOR MATCHES "^Visual Studio 16 2019$")
- set(_VCPKG_TARGET_TRIPLET_ARCH x64)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH x64)
else()
- find_program(_VCPKG_CL cl)
- if(_VCPKG_CL MATCHES "amd64/cl.exe$" OR _VCPKG_CL MATCHES "x64/cl.exe$")
- set(_VCPKG_TARGET_TRIPLET_ARCH x64)
- elseif(_VCPKG_CL MATCHES "arm/cl.exe$")
- set(_VCPKG_TARGET_TRIPLET_ARCH arm)
- elseif(_VCPKG_CL MATCHES "arm64/cl.exe$")
- set(_VCPKG_TARGET_TRIPLET_ARCH arm64)
- elseif(_VCPKG_CL MATCHES "bin/cl.exe$" OR _VCPKG_CL MATCHES "x86/cl.exe$")
- set(_VCPKG_TARGET_TRIPLET_ARCH x86)
+ find_program(Z_VCPKG_CL cl)
+ if(Z_VCPKG_CL MATCHES "amd64/cl.exe$" OR Z_VCPKG_CL MATCHES "x64/cl.exe$")
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH x64)
+ elseif(Z_VCPKG_CL MATCHES "arm/cl.exe$")
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH arm)
+ elseif(Z_VCPKG_CL MATCHES "arm64/cl.exe$")
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH arm64)
+ elseif(Z_VCPKG_CL MATCHES "bin/cl.exe$" OR Z_VCPKG_CL MATCHES "x86/cl.exe$")
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH x86)
elseif(CMAKE_HOST_SYSTEM_NAME STREQUAL "Darwin" AND DEFINED CMAKE_SYSTEM_NAME AND NOT CMAKE_SYSTEM_NAME STREQUAL "Darwin")
- list(LENGTH CMAKE_OSX_ARCHITECTURES arch_count)
- if(arch_count EQUAL 0)
+ list(LENGTH CMAKE_OSX_ARCHITECTURES Z_VCPKG_OSX_ARCH_COUNT)
+ if(Z_VCPKG_OSX_ARCH_COUNT EQUAL 0)
message(WARNING "Unable to determine target architecture. "
"Consider providing a value for the CMAKE_OSX_ARCHITECTURES cache variable. "
"Continuing without vcpkg.")
set(VCPKG_TOOLCHAIN ON)
+ cmake_policy(POP)
return()
+ endif()
+
+ if(Z_VCPKG_OSX_ARCH_COUNT GREATER 1)
+ message(WARNING "Detected more than one target architecture. Using the first one.")
+ endif()
+ list(GET CMAKE_OSX_ARCHITECTURES 0 Z_VCPKG_OSX_TARGET_ARCH)
+ if(Z_VCPKG_OSX_TARGET_ARCH STREQUAL "arm64")
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH arm64)
+ elseif(Z_VCPKG_OSX_TARGET_ARCH STREQUAL "arm64s")
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH arm64s)
+ elseif(Z_VCPKG_OSX_TARGET_ARCH STREQUAL "armv7s")
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH armv7s)
+ elseif(Z_VCPKG_OSX_TARGET_ARCH STREQUAL "armv7")
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH arm)
+ elseif(Z_VCPKG_OSX_TARGET_ARCH STREQUAL "x86_64")
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH x64)
+ elseif(Z_VCPKG_OSX_TARGET_ARCH STREQUAL "i386")
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH x86)
else()
- if(arch_count GREATER 1)
- message(WARNING "Detected more than one target architecture. Using the first one.")
- endif()
- list(GET CMAKE_OSX_ARCHITECTURES 0 target_arch)
- if(target_arch STREQUAL arm64)
- set(_VCPKG_TARGET_TRIPLET_ARCH arm64)
- elseif(target_arch STREQUAL arm64s)
- set(_VCPKG_TARGET_TRIPLET_ARCH arm64s)
- elseif(target_arch STREQUAL armv7s)
- set(_VCPKG_TARGET_TRIPLET_ARCH armv7s)
- elseif(target_arch STREQUAL armv7)
- set(_VCPKG_TARGET_TRIPLET_ARCH arm)
- elseif(target_arch STREQUAL x86_64)
- set(_VCPKG_TARGET_TRIPLET_ARCH x64)
- elseif(target_arch STREQUAL i386)
- set(_VCPKG_TARGET_TRIPLET_ARCH x86)
- else()
- message(WARNING "Unable to determine target architecture, continuing without vcpkg.")
- set(VCPKG_TOOLCHAIN ON)
- return()
- endif()
+ message(WARNING "Unable to determine target architecture, continuing without vcpkg.")
+ set(VCPKG_TOOLCHAIN ON)
+ cmake_policy(POP)
+ return()
endif()
elseif(CMAKE_HOST_SYSTEM_PROCESSOR STREQUAL "x86_64" OR CMAKE_HOST_SYSTEM_PROCESSOR STREQUAL "AMD64")
- set(_VCPKG_TARGET_TRIPLET_ARCH x64)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH x64)
elseif(CMAKE_HOST_SYSTEM_PROCESSOR STREQUAL "s390x")
- set(_VCPKG_TARGET_TRIPLET_ARCH s390x)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH s390x)
elseif(CMAKE_HOST_SYSTEM_PROCESSOR STREQUAL "ppc64le")
- set(_VCPKG_TARGET_TRIPLET_ARCH ppc64le)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH ppc64le)
elseif(CMAKE_HOST_SYSTEM_PROCESSOR STREQUAL "armv7l")
- set(_VCPKG_TARGET_TRIPLET_ARCH arm)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH arm)
elseif(CMAKE_HOST_SYSTEM_PROCESSOR STREQUAL "aarch64")
- set(_VCPKG_TARGET_TRIPLET_ARCH arm64)
+ set(Z_VCPKG_TARGET_TRIPLET_ARCH arm64)
else()
- if( _CMAKE_IN_TRY_COMPILE )
+ if(Z_VCPKG_CMAKE_IN_TRY_COMPILE)
message(STATUS "Unable to determine target architecture, continuing without vcpkg.")
else()
message(WARNING "Unable to determine target architecture, continuing without vcpkg.")
endif()
set(VCPKG_TOOLCHAIN ON)
+ cmake_policy(POP)
return()
endif()
endif()
endif()
if(CMAKE_SYSTEM_NAME STREQUAL "WindowsStore" OR CMAKE_SYSTEM_NAME STREQUAL "WindowsPhone")
- set(_VCPKG_TARGET_TRIPLET_PLAT uwp)
+ set(Z_VCPKG_TARGET_TRIPLET_PLAT uwp)
elseif(CMAKE_SYSTEM_NAME STREQUAL "Linux" OR (NOT CMAKE_SYSTEM_NAME AND CMAKE_HOST_SYSTEM_NAME STREQUAL "Linux"))
- set(_VCPKG_TARGET_TRIPLET_PLAT linux)
+ set(Z_VCPKG_TARGET_TRIPLET_PLAT linux)
elseif(CMAKE_SYSTEM_NAME STREQUAL "Darwin" OR (NOT CMAKE_SYSTEM_NAME AND CMAKE_HOST_SYSTEM_NAME STREQUAL "Darwin"))
- set(_VCPKG_TARGET_TRIPLET_PLAT osx)
+ set(Z_VCPKG_TARGET_TRIPLET_PLAT osx)
elseif(CMAKE_SYSTEM_NAME STREQUAL "iOS")
- set(_VCPKG_TARGET_TRIPLET_PLAT ios)
+ set(Z_VCPKG_TARGET_TRIPLET_PLAT ios)
elseif(CMAKE_SYSTEM_NAME STREQUAL "Windows" OR (NOT CMAKE_SYSTEM_NAME AND CMAKE_HOST_SYSTEM_NAME STREQUAL "Windows"))
- set(_VCPKG_TARGET_TRIPLET_PLAT windows)
+ set(Z_VCPKG_TARGET_TRIPLET_PLAT windows)
elseif(CMAKE_SYSTEM_NAME STREQUAL "FreeBSD" OR (NOT CMAKE_SYSTEM_NAME AND CMAKE_HOST_SYSTEM_NAME STREQUAL "FreeBSD"))
- set(_VCPKG_TARGET_TRIPLET_PLAT freebsd)
+ set(Z_VCPKG_TARGET_TRIPLET_PLAT freebsd)
endif()
-set(VCPKG_TARGET_TRIPLET ${_VCPKG_TARGET_TRIPLET_ARCH}-${_VCPKG_TARGET_TRIPLET_PLAT} CACHE STRING "Vcpkg target triplet (ex. x86-windows)")
-set(_VCPKG_TOOLCHAIN_DIR ${CMAKE_CURRENT_LIST_DIR})
+set(VCPKG_TARGET_TRIPLET "${Z_VCPKG_TARGET_TRIPLET_ARCH}-${Z_VCPKG_TARGET_TRIPLET_PLAT}" CACHE STRING "Vcpkg target triplet (ex. x86-windows)")
+set(Z_VCPKG_TOOLCHAIN_DIR "${CMAKE_CURRENT_LIST_DIR}")
-if(NOT DEFINED _VCPKG_ROOT_DIR)
+if(NOT DEFINED Z_VCPKG_ROOT_DIR)
# Detect .vcpkg-root to figure VCPKG_ROOT_DIR
- set(_VCPKG_ROOT_DIR_CANDIDATE ${CMAKE_CURRENT_LIST_DIR})
- while(IS_DIRECTORY ${_VCPKG_ROOT_DIR_CANDIDATE} AND NOT EXISTS "${_VCPKG_ROOT_DIR_CANDIDATE}/.vcpkg-root")
- get_filename_component(_VCPKG_ROOT_DIR_TEMP ${_VCPKG_ROOT_DIR_CANDIDATE} DIRECTORY)
- if (_VCPKG_ROOT_DIR_TEMP STREQUAL _VCPKG_ROOT_DIR_CANDIDATE) # If unchanged, we have reached the root of the drive
+ set(Z_VCPKG_ROOT_DIR_CANDIDATE "${CMAKE_CURRENT_LIST_DIR}")
+ while(IS_DIRECTORY "${Z_VCPKG_ROOT_DIR_CANDIDATE}" AND NOT EXISTS "${Z_VCPKG_ROOT_DIR_CANDIDATE}/.vcpkg-root")
+ get_filename_component(Z_VCPKG_ROOT_DIR_TEMP "${Z_VCPKG_ROOT_DIR_CANDIDATE}" DIRECTORY)
+ if(Z_VCPKG_ROOT_DIR_TEMP STREQUAL Z_VCPKG_ROOT_DIR_CANDIDATE) # If unchanged, we have reached the root of the drive
else()
- SET(_VCPKG_ROOT_DIR_CANDIDATE ${_VCPKG_ROOT_DIR_TEMP})
+ SET(Z_VCPKG_ROOT_DIR_CANDIDATE "${Z_VCPKG_ROOT_DIR_TEMP}")
endif()
endwhile()
- set(_VCPKG_ROOT_DIR ${_VCPKG_ROOT_DIR_CANDIDATE} CACHE INTERNAL "Vcpkg root directory")
+ set(Z_VCPKG_ROOT_DIR "${Z_VCPKG_ROOT_DIR_CANDIDATE}" CACHE INTERNAL "Vcpkg root directory")
endif()
-_vcpkg_get_directory_name_of_file_above(_VCPKG_ROOT_DIR ${CMAKE_CURRENT_LIST_DIR} ".vcpkg-root")
-if(NOT _VCPKG_ROOT_DIR)
- _vcpkg_add_fatal_error("Could not find .vcpkg-root")
+if(NOT Z_VCPKG_ROOT_DIR)
+ z_vcpkg_add_fatal_error("Could not find .vcpkg-root")
endif()
-if (NOT DEFINED _VCPKG_INSTALLED_DIR)
- if(_VCPKG_MANIFEST_DIR)
- set(_VCPKG_INSTALLED_DIR ${CMAKE_BINARY_DIR}/vcpkg_installed)
+# NOTE: _VCPKG_INSTALLED_DIR cannot be removed without tool changes.
+if(NOT DEFINED VCPKG_INSTALLED_DIR)
+ if(DEFINED _VCPKG_INSTALLED_DIR)
+ set(VCPKG_INSTALLED_DIR "${_VCPKG_INSTALLED_DIR}")
+ elseif(VCPKG_MANIFEST_MODE)
+ set(VCPKG_INSTALLED_DIR "${CMAKE_BINARY_DIR}/vcpkg_installed")
else()
- set(_VCPKG_INSTALLED_DIR ${_VCPKG_ROOT_DIR}/installed)
+ set(VCPKG_INSTALLED_DIR "${Z_VCPKG_ROOT_DIR}/installed")
endif()
-
- set(_VCPKG_INSTALLED_DIR ${_VCPKG_INSTALLED_DIR}
- CACHE PATH
- "The directory which contains the installed libraries for each triplet")
endif()
+set(VCPKG_INSTALLED_DIR "${VCPKG_INSTALLED_DIR}"
+ CACHE PATH
+ "The directory which contains the installed libraries for each triplet" FORCE)
if(CMAKE_BUILD_TYPE MATCHES "^[Dd][Ee][Bb][Uu][Gg]$" OR NOT DEFINED CMAKE_BUILD_TYPE) #Debug build: Put Debug paths before Release paths.
list(APPEND CMAKE_PREFIX_PATH
- ${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/debug ${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}
+ "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/debug"
+ "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}"
)
list(APPEND CMAKE_LIBRARY_PATH
- ${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/debug/lib/manual-link ${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/lib/manual-link
+ "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/debug/lib/manual-link"
+ "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/lib/manual-link"
)
list(APPEND CMAKE_FIND_ROOT_PATH
- ${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/debug ${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}
+ "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/debug"
+ "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}"
)
else() #Release build: Put Release paths before Debug paths. Debug Paths are required so that CMake generates correct info in autogenerated target files.
list(APPEND CMAKE_PREFIX_PATH
- ${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET} ${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/debug
+ "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}"
+ "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/debug"
)
list(APPEND CMAKE_LIBRARY_PATH
- ${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/lib/manual-link ${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/debug/lib/manual-link
+ "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/lib/manual-link"
+ "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/debug/lib/manual-link"
)
list(APPEND CMAKE_FIND_ROOT_PATH
- ${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET} ${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/debug
+ "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}"
+ "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/debug"
)
endif()
@@ -295,26 +520,26 @@ if(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE STREQUAL "ONLY" OR
list(APPEND CMAKE_PREFIX_PATH "/")
endif()
-set(VCPKG_CMAKE_FIND_ROOT_PATH ${CMAKE_FIND_ROOT_PATH})
+set(VCPKG_CMAKE_FIND_ROOT_PATH "${CMAKE_FIND_ROOT_PATH}")
-file(TO_CMAKE_PATH "$ENV{PROGRAMFILES}" _programfiles)
-set(_PROGRAMFILESX86 "PROGRAMFILES(x86)")
-file(TO_CMAKE_PATH "$ENV{${_PROGRAMFILESX86}}" _programfiles_x86)
+file(TO_CMAKE_PATH "$ENV{PROGRAMFILES}" Z_VCPKG_PROGRAMFILES)
+set(Z_VCPKG_PROGRAMFILESX86_NAME "PROGRAMFILES(x86)")
+file(TO_CMAKE_PATH "$ENV{${Z_VCPKG_PROGRAMFILESX86_NAME}}" Z_VCPKG_PROGRAMFILESX86)
set(CMAKE_SYSTEM_IGNORE_PATH
- "${_programfiles}/OpenSSL"
- "${_programfiles}/OpenSSL-Win32"
- "${_programfiles}/OpenSSL-Win64"
- "${_programfiles}/OpenSSL-Win32/lib/VC"
- "${_programfiles}/OpenSSL-Win64/lib/VC"
- "${_programfiles}/OpenSSL-Win32/lib/VC/static"
- "${_programfiles}/OpenSSL-Win64/lib/VC/static"
- "${_programfiles_x86}/OpenSSL"
- "${_programfiles_x86}/OpenSSL-Win32"
- "${_programfiles_x86}/OpenSSL-Win64"
- "${_programfiles_x86}/OpenSSL-Win32/lib/VC"
- "${_programfiles_x86}/OpenSSL-Win64/lib/VC"
- "${_programfiles_x86}/OpenSSL-Win32/lib/VC/static"
- "${_programfiles_x86}/OpenSSL-Win64/lib/VC/static"
+ "${Z_VCPKG_PROGRAMFILES}/OpenSSL"
+ "${Z_VCPKG_PROGRAMFILES}/OpenSSL-Win32"
+ "${Z_VCPKG_PROGRAMFILES}/OpenSSL-Win64"
+ "${Z_VCPKG_PROGRAMFILES}/OpenSSL-Win32/lib/VC"
+ "${Z_VCPKG_PROGRAMFILES}/OpenSSL-Win64/lib/VC"
+ "${Z_VCPKG_PROGRAMFILES}/OpenSSL-Win32/lib/VC/static"
+ "${Z_VCPKG_PROGRAMFILES}/OpenSSL-Win64/lib/VC/static"
+ "${Z_VCPKG_PROGRAMFILESX86}/OpenSSL"
+ "${Z_VCPKG_PROGRAMFILESX86}/OpenSSL-Win32"
+ "${Z_VCPKG_PROGRAMFILESX86}/OpenSSL-Win64"
+ "${Z_VCPKG_PROGRAMFILESX86}/OpenSSL-Win32/lib/VC"
+ "${Z_VCPKG_PROGRAMFILESX86}/OpenSSL-Win64/lib/VC"
+ "${Z_VCPKG_PROGRAMFILESX86}/OpenSSL-Win32/lib/VC/static"
+ "${Z_VCPKG_PROGRAMFILESX86}/OpenSSL-Win64/lib/VC/static"
"C:/OpenSSL/"
"C:/OpenSSL-Win32/"
"C:/OpenSSL-Win64/"
@@ -324,197 +549,174 @@ set(CMAKE_SYSTEM_IGNORE_PATH
"C:/OpenSSL-Win64/lib/VC/static"
)
-list(APPEND CMAKE_PROGRAM_PATH ${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/tools)
-file(GLOB _VCPKG_TOOLS_DIRS ${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/tools/*)
-foreach(_VCPKG_TOOLS_DIR IN LISTS _VCPKG_TOOLS_DIRS)
- if(IS_DIRECTORY "${_VCPKG_TOOLS_DIR}")
- list(APPEND CMAKE_PROGRAM_PATH "${_VCPKG_TOOLS_DIR}")
+list(APPEND CMAKE_PROGRAM_PATH "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/tools")
+file(GLOB Z_VCPKG_TOOLS_DIRS "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/tools/*")
+foreach(Z_VCPKG_TOOLS_DIR IN LISTS Z_VCPKG_TOOLS_DIRS)
+ if(IS_DIRECTORY "${Z_VCPKG_TOOLS_DIR}")
+ list(APPEND CMAKE_PROGRAM_PATH "${Z_VCPKG_TOOLS_DIR}")
endif()
endforeach()
# CMAKE_EXECUTABLE_SUFFIX is not yet defined
-if (CMAKE_HOST_SYSTEM_NAME STREQUAL "Windows")
- set(_VCPKG_EXECUTABLE "${_VCPKG_ROOT_DIR}/vcpkg.exe")
- set(_VCPKG_BOOTSTRAP_SCRIPT "${_VCPKG_ROOT_DIR}/bootstrap-vcpkg.bat")
+if(CMAKE_HOST_SYSTEM_NAME STREQUAL "Windows")
+ set(Z_VCPKG_EXECUTABLE "${Z_VCPKG_ROOT_DIR}/vcpkg.exe")
+ set(Z_VCPKG_BOOTSTRAP_SCRIPT "${Z_VCPKG_ROOT_DIR}/bootstrap-vcpkg.bat")
else()
- set(_VCPKG_EXECUTABLE "${_VCPKG_ROOT_DIR}/vcpkg")
- set(_VCPKG_BOOTSTRAP_SCRIPT "${_VCPKG_ROOT_DIR}/bootstrap-vcpkg.sh")
+ set(Z_VCPKG_EXECUTABLE "${Z_VCPKG_ROOT_DIR}/vcpkg")
+ set(Z_VCPKG_BOOTSTRAP_SCRIPT "${Z_VCPKG_ROOT_DIR}/bootstrap-vcpkg.sh")
endif()
-if(VCPKG_MANIFEST_MODE AND VCPKG_MANIFEST_INSTALL AND NOT _CMAKE_IN_TRY_COMPILE AND NOT _VCPKG_HAS_FATAL_ERROR)
- set(VCPKG_BOOTSTRAP_OPTIONS "${VCPKG_BOOTSTRAP_OPTIONS}" CACHE STRING "Additional options to bootstrap vcpkg" FORCE)
- mark_as_advanced(VCPKG_BOOTSTRAP_OPTIONS)
-
- if(NOT EXISTS "${_VCPKG_EXECUTABLE}")
+if(VCPKG_MANIFEST_MODE AND VCPKG_MANIFEST_INSTALL AND NOT Z_VCPKG_CMAKE_IN_TRY_COMPILE AND NOT Z_VCPKG_HAS_FATAL_ERROR)
+ if(NOT EXISTS "${Z_VCPKG_EXECUTABLE}" AND NOT Z_VCPKG_HAS_FATAL_ERROR)
message(STATUS "Bootstrapping vcpkg before install")
- file(TO_NATIVE_PATH "${CMAKE_BINARY_DIR}/vcpkg-bootstrap.log" _VCPKG_BOOTSTRAP_LOG)
+ file(TO_NATIVE_PATH "${CMAKE_BINARY_DIR}/vcpkg-bootstrap.log" Z_VCPKG_BOOTSTRAP_LOG)
execute_process(
- COMMAND "${_VCPKG_BOOTSTRAP_SCRIPT}" ${VCPKG_BOOTSTRAP_OPTIONS}
- OUTPUT_FILE "${_VCPKG_BOOTSTRAP_LOG}"
- ERROR_FILE "${_VCPKG_BOOTSTRAP_LOG}"
- RESULT_VARIABLE _VCPKG_BOOTSTRAP_RESULT)
+ COMMAND "${Z_VCPKG_BOOTSTRAP_SCRIPT}" ${VCPKG_BOOTSTRAP_OPTIONS}
+ OUTPUT_FILE "${Z_VCPKG_BOOTSTRAP_LOG}"
+ ERROR_FILE "${Z_VCPKG_BOOTSTRAP_LOG}"
+ RESULT_VARIABLE Z_VCPKG_BOOTSTRAP_RESULT)
- if (_VCPKG_BOOTSTRAP_RESULT EQUAL 0)
+ if(Z_VCPKG_BOOTSTRAP_RESULT EQUAL 0)
message(STATUS "Bootstrapping vcpkg before install - done")
else()
message(STATUS "Bootstrapping vcpkg before install - failed")
- _vcpkg_add_fatal_error("vcpkg install failed. See logs for more information: ${_VCPKG_BOOTSTRAP_LOG}")
+ z_vcpkg_add_fatal_error("vcpkg install failed. See logs for more information: ${Z_VCPKG_BOOTSTRAP_LOG}")
endif()
endif()
- if (NOT _VCPKG_HAS_FATAL_ERROR)
- set(VCPKG_OVERLAY_PORTS "${VCPKG_OVERLAY_PORTS}" CACHE STRING "Overlay ports to use for vcpkg install in manifest mode" FORCE)
- mark_as_advanced(VCPKG_OVERLAY_PORTS)
- set(VCPKG_OVERLAY_TRIPLETS "${VCPKG_OVERLAY_TRIPLETS}" CACHE STRING "Overlay triplets to use for vcpkg install in manifest mode" FORCE)
- mark_as_advanced(VCPKG_OVERLAY_TRIPLETS)
- set(VCPKG_INSTALL_OPTIONS "${VCPKG_INSTALL_OPTIONS}" CACHE STRING "Additional install options to pass to vcpkg" FORCE)
- mark_as_advanced(VCPKG_INSTALL_OPTIONS)
-
+ if(NOT Z_VCPKG_HAS_FATAL_ERROR)
message(STATUS "Running vcpkg install")
- set(_VCPKG_ADDITIONAL_MANIFEST_PARAMS)
+ set(Z_VCPKG_ADDITIONAL_MANIFEST_PARAMS)
if(VCPKG_OVERLAY_PORTS)
- foreach(_overlay_port IN LISTS VCPKG_OVERLAY_PORTS)
- list(APPEND _VCPKG_ADDITIONAL_MANIFEST_PARAMS "--overlay-ports=${_overlay_port}")
+ foreach(Z_VCPKG_OVERLAY_PORT IN LISTS VCPKG_OVERLAY_PORTS)
+ list(APPEND Z_VCPKG_ADDITIONAL_MANIFEST_PARAMS "--overlay-ports=${Z_VCPKG_OVERLAY_PORT}")
endforeach()
endif()
if(VCPKG_OVERLAY_TRIPLETS)
- foreach(_overlay_triplet IN LISTS VCPKG_OVERLAY_TRIPLETS)
- list(APPEND _VCPKG_ADDITIONAL_MANIFEST_PARAMS "--overlay-triplets=${_overlay_triplet}")
+ foreach(Z_VCPKG_OVERLAY_TRIPLET IN LISTS VCPKG_OVERLAY_TRIPLETS)
+ list(APPEND Z_VCPKG_ADDITIONAL_MANIFEST_PARAMS "--overlay-triplets=${Z_VCPKG_OVERLAY_TRIPLET}")
endforeach()
endif()
if(DEFINED VCPKG_FEATURE_FLAGS OR DEFINED CACHE{VCPKG_FEATURE_FLAGS})
- list(JOIN VCPKG_FEATURE_FLAGS "," _VCPKG_FEATURE_FLAGS)
- set(_VCPKG_FEATURE_FLAGS "--feature-flags=${_VCPKG_FEATURE_FLAGS}")
+ list(JOIN VCPKG_FEATURE_FLAGS "," Z_VCPKG_FEATURE_FLAGS)
+ set(Z_VCPKG_FEATURE_FLAGS "--feature-flags=${Z_VCPKG_FEATURE_FLAGS}")
endif()
- foreach(feature IN LISTS VCPKG_MANIFEST_FEATURES)
- list(APPEND _VCPKG_ADDITIONAL_MANIFEST_PARAMS "--x-feature=${feature}")
+ foreach(Z_VCPKG_FEATURE IN LISTS VCPKG_MANIFEST_FEATURES)
+ list(APPEND Z_VCPKG_ADDITIONAL_MANIFEST_PARAMS "--x-feature=${Z_VCPKG_FEATURE}")
endforeach()
if(VCPKG_MANIFEST_NO_DEFAULT_FEATURES)
- list(APPEND _VCPKG_ADDITIONAL_MANIFEST_PARAMS "--x-no-default-features")
+ list(APPEND Z_VCPKG_ADDITIONAL_MANIFEST_PARAMS "--x-no-default-features")
endif()
- if (CMAKE_VERSION VERSION_GREATER_EQUAL "3.18")
- set(_VCPKG_MANIFEST_INSTALL_ECHO_PARAMS ECHO_OUTPUT_VARIABLE ECHO_ERROR_VARIABLE)
+ if(NOT CMAKE_VERSION VERSION_LESS "3.18") # == GREATER_EQUAL, but that was added in CMake 3.7
+ set(Z_VCPKG_MANIFEST_INSTALL_ECHO_PARAMS ECHO_OUTPUT_VARIABLE ECHO_ERROR_VARIABLE)
else()
- set(_VCPKG_MANIFEST_INSTALL_ECHO_PARAMS)
+ set(Z_VCPKG_MANIFEST_INSTALL_ECHO_PARAMS)
endif()
execute_process(
- COMMAND "${_VCPKG_EXECUTABLE}" install
+ COMMAND "${Z_VCPKG_EXECUTABLE}" install
--triplet "${VCPKG_TARGET_TRIPLET}"
- --vcpkg-root "${_VCPKG_ROOT_DIR}"
+ --vcpkg-root "${Z_VCPKG_ROOT_DIR}"
"--x-wait-for-lock"
- "--x-manifest-root=${_VCPKG_MANIFEST_DIR}"
+ "--x-manifest-root=${VCPKG_MANIFEST_DIR}"
"--x-install-root=${_VCPKG_INSTALLED_DIR}"
- "${_VCPKG_FEATURE_FLAGS}"
- ${_VCPKG_ADDITIONAL_MANIFEST_PARAMS}
+ "${Z_VCPKG_FEATURE_FLAGS}"
+ ${Z_VCPKG_ADDITIONAL_MANIFEST_PARAMS}
${VCPKG_INSTALL_OPTIONS}
- OUTPUT_VARIABLE _VCPKG_MANIFEST_INSTALL_LOGTEXT
- ERROR_VARIABLE _VCPKG_MANIFEST_INSTALL_LOGTEXT
- RESULT_VARIABLE _VCPKG_INSTALL_RESULT
- ${_VCPKG_MANIFEST_INSTALL_ECHO_PARAMS}
+ OUTPUT_VARIABLE Z_VCPKG_MANIFEST_INSTALL_LOGTEXT
+ ERROR_VARIABLE Z_VCPKG_MANIFEST_INSTALL_LOGTEXT
+ RESULT_VARIABLE Z_VCPKG_MANIFEST_INSTALL_RESULT
+ ${Z_VCPKG_MANIFEST_INSTALL_ECHO_PARAMS}
)
- file(TO_NATIVE_PATH "${CMAKE_BINARY_DIR}/vcpkg-manifest-install.log" _VCPKG_MANIFEST_INSTALL_LOGFILE)
- file(WRITE "${_VCPKG_MANIFEST_INSTALL_LOGFILE}" "${_VCPKG_MANIFEST_INSTALL_LOGTEXT}")
+ file(TO_NATIVE_PATH "${CMAKE_BINARY_DIR}/vcpkg-manifest-install.log" Z_VCPKG_MANIFEST_INSTALL_LOGFILE)
+ file(WRITE "${Z_VCPKG_MANIFEST_INSTALL_LOGFILE}" "${Z_VCPKG_MANIFEST_INSTALL_LOGTEXT}")
- if (_VCPKG_INSTALL_RESULT EQUAL 0)
+ if(Z_VCPKG_MANIFEST_INSTALL_RESULT EQUAL 0)
message(STATUS "Running vcpkg install - done")
+ # file(TOUCH) added in CMake 3.12
+ file(WRITE "${_VCPKG_INSTALLED_DIR}/.cmakestamp" "")
set_property(DIRECTORY APPEND PROPERTY CMAKE_CONFIGURE_DEPENDS
- "${_VCPKG_MANIFEST_DIR}/vcpkg.json"
- "${_VCPKG_INSTALLED_DIR}/vcpkg/status")
- if(EXISTS "${_VCPKG_MANIFEST_DIR}/vcpkg-configuration.json")
+ "${VCPKG_MANIFEST_DIR}/vcpkg.json"
+ "${_VCPKG_INSTALLED_DIR}/.cmakestamp")
+ if(EXISTS "${VCPKG_MANIFEST_DIR}/vcpkg-configuration.json")
set_property(DIRECTORY APPEND PROPERTY CMAKE_CONFIGURE_DEPENDS
- "${_VCPKG_MANIFEST_DIR}/vcpkg-configuration.json")
+ "${VCPKG_MANIFEST_DIR}/vcpkg-configuration.json")
endif()
else()
message(STATUS "Running vcpkg install - failed")
- _vcpkg_add_fatal_error("vcpkg install failed. See logs for more information: ${_VCPKG_MANIFEST_INSTALL_LOGFILE}")
+ z_vcpkg_add_fatal_error("vcpkg install failed. See logs for more information: ${Z_VCPKG_MANIFEST_INSTALL_LOGFILE}")
endif()
endif()
endif()
-option(VCPKG_APPLOCAL_DEPS "Automatically copy dependencies into the output directory for executables." ON)
-option(X_VCPKG_APPLOCAL_DEPS_SERIALIZED "(experimental) Add USES_TERMINAL to VCPKG_APPLOCAL_DEPS to force serialization." OFF)
-function(_vcpkg_set_powershell_path)
- # Attempt to use pwsh if it is present; otherwise use powershell
- if (NOT DEFINED _VCPKG_POWERSHELL_PATH)
- find_program(_VCPKG_PWSH_PATH pwsh)
- if (_VCPKG_PWSH_PATH)
- set(_VCPKG_POWERSHELL_PATH "${_VCPKG_PWSH_PATH}" CACHE INTERNAL "The path to the PowerShell implementation to use.")
- else()
- message(DEBUG "vcpkg: Could not find PowerShell Core; falling back to PowerShell")
- find_program(_VCPKG_BUILTIN_POWERSHELL_PATH powershell REQUIRED)
- if (_VCPKG_BUILTIN_POWERSHELL_PATH)
- set(_VCPKG_POWERSHELL_PATH "${_VCPKG_BUILTIN_POWERSHELL_PATH}" CACHE INTERNAL "The path to the PowerShell implementation to use.")
- else()
- message(WARNING "vcpkg: Could not find PowerShell; using static string 'powershell.exe'")
- set(_VCPKG_POWERSHELL_PATH "powershell.exe" CACHE INTERNAL "The path to the PowerShell implementation to use.")
- endif()
- endif()
- endif() # _VCPKG_POWERSHELL_PATH
-endfunction()
+function(add_executable)
+ z_vcpkg_function_arguments(ARGS)
+ _add_executable(${ARGS})
+ set(target_name "${ARGV0}")
-function(add_executable name)
- _add_executable(${ARGV})
list(FIND ARGV "IMPORTED" IMPORTED_IDX)
list(FIND ARGV "ALIAS" ALIAS_IDX)
list(FIND ARGV "MACOSX_BUNDLE" MACOSX_BUNDLE_IDX)
if(IMPORTED_IDX EQUAL -1 AND ALIAS_IDX EQUAL -1)
if(VCPKG_APPLOCAL_DEPS)
- if(_VCPKG_TARGET_TRIPLET_PLAT MATCHES "windows|uwp")
- _vcpkg_set_powershell_path()
+ if(Z_VCPKG_TARGET_TRIPLET_PLAT MATCHES "windows|uwp")
+ z_vcpkg_set_powershell_path()
set(EXTRA_OPTIONS "")
if(X_VCPKG_APPLOCAL_DEPS_SERIALIZED)
set(EXTRA_OPTIONS USES_TERMINAL)
endif()
- add_custom_command(TARGET ${name} POST_BUILD
- COMMAND "${_VCPKG_POWERSHELL_PATH}" -noprofile -executionpolicy Bypass -file "${_VCPKG_TOOLCHAIN_DIR}/msbuild/applocal.ps1"
- -targetBinary $<TARGET_FILE:${name}>
+ add_custom_command(TARGET "${target_name}" POST_BUILD
+ COMMAND "${Z_VCPKG_POWERSHELL_PATH}" -noprofile -executionpolicy Bypass -file "${Z_VCPKG_TOOLCHAIN_DIR}/msbuild/applocal.ps1"
+ -targetBinary "$<TARGET_FILE:${target_name}>"
-installedDir "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}$<$<CONFIG:Debug>:/debug>/bin"
-OutVariable out
${EXTRA_OPTIONS}
)
- elseif(_VCPKG_TARGET_TRIPLET_PLAT MATCHES "osx")
- if (NOT MACOSX_BUNDLE_IDX EQUAL -1)
- add_custom_command(TARGET ${name} POST_BUILD
- COMMAND python ${_VCPKG_TOOLCHAIN_DIR}/osx/applocal.py
- $<TARGET_FILE:${name}>
+ elseif(Z_VCPKG_TARGET_TRIPLET_PLAT MATCHES "osx")
+ if(NOT MACOSX_BUNDLE_IDX EQUAL -1)
+ add_custom_command(TARGET "${target_name}" POST_BUILD
+ COMMAND python "${Z_VCPKG_TOOLCHAIN_DIR}/osx/applocal.py"
+ "$<TARGET_FILE:${target_name}>"
"${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}$<$<CONFIG:Debug>:/debug>"
)
endif()
endif()
endif()
- set_target_properties(${name} PROPERTIES VS_USER_PROPS do_not_import_user.props)
- set_target_properties(${name} PROPERTIES VS_GLOBAL_VcpkgEnabled false)
+ set_target_properties("${target_name}" PROPERTIES VS_USER_PROPS do_not_import_user.props)
+ set_target_properties("${target_name}" PROPERTIES VS_GLOBAL_VcpkgEnabled false)
endif()
endfunction()
-function(add_library name)
- _add_library(${ARGV})
- list(FIND ARGV "IMPORTED" IMPORTED_IDX)
- list(FIND ARGV "INTERFACE" INTERFACE_IDX)
- list(FIND ARGV "ALIAS" ALIAS_IDX)
+function(add_library)
+ z_vcpkg_function_arguments(ARGS)
+ _add_library(${ARGS})
+ set(target_name "${ARGV0}")
+
+ list(FIND ARGS "IMPORTED" IMPORTED_IDX)
+ list(FIND ARGS "INTERFACE" INTERFACE_IDX)
+ list(FIND ARGS "ALIAS" ALIAS_IDX)
if(IMPORTED_IDX EQUAL -1 AND INTERFACE_IDX EQUAL -1 AND ALIAS_IDX EQUAL -1)
- get_target_property(IS_LIBRARY_SHARED ${name} TYPE)
- if(VCPKG_APPLOCAL_DEPS AND _VCPKG_TARGET_TRIPLET_PLAT MATCHES "windows|uwp" AND (IS_LIBRARY_SHARED STREQUAL "SHARED_LIBRARY" OR IS_LIBRARY_SHARED STREQUAL "MODULE_LIBRARY"))
- _vcpkg_set_powershell_path()
- add_custom_command(TARGET ${name} POST_BUILD
- COMMAND "${_VCPKG_POWERSHELL_PATH}" -noprofile -executionpolicy Bypass -file "${_VCPKG_TOOLCHAIN_DIR}/msbuild/applocal.ps1"
- -targetBinary $<TARGET_FILE:${name}>
+ get_target_property(IS_LIBRARY_SHARED "${target_name}" TYPE)
+ if(VCPKG_APPLOCAL_DEPS AND Z_VCPKG_TARGET_TRIPLET_PLAT MATCHES "windows|uwp" AND (IS_LIBRARY_SHARED STREQUAL "SHARED_LIBRARY" OR IS_LIBRARY_SHARED STREQUAL "MODULE_LIBRARY"))
+ z_vcpkg_set_powershell_path()
+ add_custom_command(TARGET "${target_name}" POST_BUILD
+ COMMAND "${Z_VCPKG_POWERSHELL_PATH}" -noprofile -executionpolicy Bypass -file "${Z_VCPKG_TOOLCHAIN_DIR}/msbuild/applocal.ps1"
+ -targetBinary "$<TARGET_FILE:${target_name}>"
-installedDir "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}$<$<CONFIG:Debug>:/debug>/bin"
-OutVariable out
)
endif()
- set_target_properties(${name} PROPERTIES VS_USER_PROPS do_not_import_user.props)
- set_target_properties(${name} PROPERTIES VS_GLOBAL_VcpkgEnabled false)
+ set_target_properties("${target_name}" PROPERTIES VS_USER_PROPS do_not_import_user.props)
+ set_target_properties("${target_name}" PROPERTIES VS_GLOBAL_VcpkgEnabled false)
endif()
endfunction()
@@ -522,22 +724,24 @@ endfunction()
# Arguments:
# TARGETS - a list of installed targets to have dependencies copied for
# DESTINATION - the runtime directory for those targets (usually `bin`)
+#
+# Note that this function requires CMake 3.14 for policy CMP0087
function(x_vcpkg_install_local_dependencies)
- if(_VCPKG_TARGET_TRIPLET_PLAT MATCHES "windows|uwp")
+ if(Z_VCPKG_TARGET_TRIPLET_PLAT MATCHES "windows|uwp")
cmake_parse_arguments(PARSE_ARGV 0 __VCPKG_APPINSTALL "" "DESTINATION" "TARGETS")
- _vcpkg_set_powershell_path()
- if(NOT IS_ABSOLUTE ${__VCPKG_APPINSTALL_DESTINATION})
+ z_vcpkg_set_powershell_path()
+ if(NOT IS_ABSOLUTE "${__VCPKG_APPINSTALL_DESTINATION}")
set(__VCPKG_APPINSTALL_DESTINATION "\${CMAKE_INSTALL_PREFIX}/${__VCPKG_APPINSTALL_DESTINATION}")
endif()
foreach(TARGET IN LISTS __VCPKG_APPINSTALL_TARGETS)
- get_target_property(TARGETTYPE ${TARGET} TYPE)
+ get_target_property(TARGETTYPE "${TARGET}" TYPE)
if(NOT TARGETTYPE STREQUAL "INTERFACE_LIBRARY")
# Install CODE|SCRIPT allow the use of generator expressions
if(POLICY CMP0087)
cmake_policy(SET CMP0087 NEW)
endif()
install(CODE "message(\"-- Installing app dependencies for ${TARGET}...\")
- execute_process(COMMAND \"${_VCPKG_POWERSHELL_PATH}\" -noprofile -executionpolicy Bypass -file \"${_VCPKG_TOOLCHAIN_DIR}/msbuild/applocal.ps1\"
+ execute_process(COMMAND \"${Z_VCPKG_POWERSHELL_PATH}\" -noprofile -executionpolicy Bypass -file \"${Z_VCPKG_TOOLCHAIN_DIR}/msbuild/applocal.ps1\"
-targetBinary \"${__VCPKG_APPINSTALL_DESTINATION}/$<TARGET_FILE_NAME:${TARGET}>\"
-installedDir \"${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}$<$<CONFIG:Debug>:/debug>/bin\"
-OutVariable out)")
@@ -546,10 +750,10 @@ function(x_vcpkg_install_local_dependencies)
endif()
endfunction()
-set(X_VCPKG_APPLOCAL_DEPS_INSTALL ${X_VCPKG_APPLOCAL_DEPS_INSTALL} CACHE BOOL "(experimental) Automatically copy dependencies into the install target directory for executables.")
if(X_VCPKG_APPLOCAL_DEPS_INSTALL)
function(install)
- _install(${ARGV})
+ z_vcpkg_function_arguments(ARGS)
+ _install(${ARGS})
if(ARGV0 STREQUAL "TARGETS")
# Will contain the list of targets
@@ -561,14 +765,13 @@ if(X_VCPKG_APPLOCAL_DEPS_INSTALL)
# Parse arguments given to the install function to find targets and (runtime) destination
set(MODIFIER "") # Modifier for the command in the argument
set(LAST_COMMAND "") # Last command we found to process
- foreach(ARG ${ARGN})
+ foreach(ARG IN LISTS ARGS)
if(ARG MATCHES "ARCHIVE|LIBRARY|RUNTIME|OBJECTS|FRAMEWORK|BUNDLE|PRIVATE_HEADER|PUBLIC_HEADER|RESOURCE|INCLUDES")
- set(MODIFIER ${ARG})
+ set(MODIFIER "${ARG}")
continue()
endif()
-
if(ARG MATCHES "TARGETS|DESTINATION|PERMISSIONS|CONFIGURATIONS|COMPONENT|NAMELINK_COMPONENT|OPTIONAL|EXCLUDE_FROM_ALL|NAMELINK_ONLY|NAMELINK_SKIP|EXPORT")
- set(LAST_COMMAND ${ARG})
+ set(LAST_COMMAND "${ARG}")
continue()
endif()
@@ -581,7 +784,7 @@ if(X_VCPKG_APPLOCAL_DEPS_INSTALL)
endif()
endforeach()
- x_vcpkg_install_local_dependencies(TARGETS ${PARSED_TARGETS} DESTINATION ${DESTINATION})
+ x_vcpkg_install_local_dependencies(TARGETS "${PARSED_TARGETS}" DESTINATION "${DESTINATION}")
endif()
endfunction()
endif()
@@ -589,20 +792,27 @@ endif()
if(NOT DEFINED VCPKG_OVERRIDE_FIND_PACKAGE_NAME)
set(VCPKG_OVERRIDE_FIND_PACKAGE_NAME find_package)
endif()
-macro(${VCPKG_OVERRIDE_FIND_PACKAGE_NAME} name)
+function("${VCPKG_OVERRIDE_FIND_PACKAGE_NAME}")
# Workaround to set the ROOT_PATH until upstream CMake stops overriding
# the ROOT_PATH at apple OS initialization phase.
# See https://gitlab.kitware.com/cmake/cmake/merge_requests/3273
if(CMAKE_SYSTEM_NAME STREQUAL iOS)
- set(BACKUP_CMAKE_FIND_ROOT_PATH ${CMAKE_FIND_ROOT_PATH})
- list(APPEND CMAKE_FIND_ROOT_PATH ${VCPKG_CMAKE_FIND_ROOT_PATH})
+ # this is not a mutating operation,
+ # this just creates a new variable named CMAKE_FIND_ROOT_PATH with value
+ # "${CMAKE_FIND_ROOT_PATH};${VCPKG_CMAKE_FIND_ROOT_PATH}"
+ # therefore, we don't have to worry about restoring its old value
+ list(APPEND CMAKE_FIND_ROOT_PATH "${VCPKG_CMAKE_FIND_ROOT_PATH}")
endif()
- string(TOLOWER "${name}" _vcpkg_lowercase_name)
+ z_vcpkg_function_arguments(ARGS)
+ set(PACKAGE_NAME "${ARGV0}")
+ string(TOLOWER "${PACKAGE_NAME}" LOWERCASE_PACKAGE_NAME)
- if(EXISTS "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/share/${_vcpkg_lowercase_name}/vcpkg-cmake-wrapper.cmake")
- set(ARGS "${ARGV}")
- include(${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/share/${_vcpkg_lowercase_name}/vcpkg-cmake-wrapper.cmake)
- elseif("${name}" STREQUAL "Boost" AND EXISTS "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/include/boost")
+ set(VCPKG_CMAKE_WRAPPER_PATH "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/share/${LOWERCASE_PACKAGE_NAME}/vcpkg-cmake-wrapper.cmake")
+
+ z_vcpkg_start_parent_scope_export()
+ if(EXISTS "${VCPKG_CMAKE_WRAPPER_PATH}")
+ include("${VCPKG_CMAKE_WRAPPER_PATH}")
+ elseif("${PACKAGE_NAME}" STREQUAL "Boost" AND EXISTS "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/include/boost")
# Checking for the boost headers disables this wrapper unless the user has installed at least one boost library
set(Boost_USE_STATIC_LIBS OFF)
set(Boost_USE_MULTITHREADED ON)
@@ -614,32 +824,28 @@ macro(${VCPKG_OVERRIDE_FIND_PACKAGE_NAME} name)
else()
set(Boost_COMPILER "-vc140")
endif()
- _find_package(${ARGV})
- elseif("${name}" STREQUAL "ICU" AND EXISTS "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/include/unicode/utf.h")
- function(_vcpkg_find_in_list)
- list(FIND ARGV "COMPONENTS" COMPONENTS_IDX)
- set(COMPONENTS_IDX ${COMPONENTS_IDX} PARENT_SCOPE)
- endfunction()
- _vcpkg_find_in_list(${ARGV})
+ _find_package(${ARGS})
+ elseif("${PACKAGE_NAME}" STREQUAL "ICU" AND EXISTS "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/include/unicode/utf.h")
+ list(FIND ARGS "COMPONENTS" COMPONENTS_IDX)
if(NOT COMPONENTS_IDX EQUAL -1)
- _find_package(${ARGV} COMPONENTS data)
+ _find_package(${ARGS} COMPONENTS data)
else()
- _find_package(${ARGV})
+ _find_package(${ARGS})
endif()
- elseif("${name}" STREQUAL "GSL" AND EXISTS "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/include/gsl")
- _find_package(${ARGV})
+ elseif("${PACKAGE_NAME}" STREQUAL "GSL" AND EXISTS "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/include/gsl")
+ _find_package(${ARGS})
if(GSL_FOUND AND TARGET GSL::gsl)
set_property( TARGET GSL::gslcblas APPEND PROPERTY IMPORTED_CONFIGURATIONS Release )
set_property( TARGET GSL::gsl APPEND PROPERTY IMPORTED_CONFIGURATIONS Release )
if( EXISTS "${GSL_LIBRARY_DEBUG}" AND EXISTS "${GSL_CBLAS_LIBRARY_DEBUG}")
- set_property( TARGET GSL::gsl APPEND PROPERTY IMPORTED_CONFIGURATIONS Debug )
- set_target_properties( GSL::gsl PROPERTIES IMPORTED_LOCATION_DEBUG "${GSL_LIBRARY_DEBUG}" )
+ set_property( TARGET GSL::gsl APPEND PROPERTY IMPORTED_CONFIGURATIONS Debug )
+ set_target_properties( GSL::gsl PROPERTIES IMPORTED_LOCATION_DEBUG "${GSL_LIBRARY_DEBUG}" )
set_property( TARGET GSL::gslcblas APPEND PROPERTY IMPORTED_CONFIGURATIONS Debug )
set_target_properties( GSL::gslcblas PROPERTIES IMPORTED_LOCATION_DEBUG "${GSL_CBLAS_LIBRARY_DEBUG}" )
endif()
endif()
- elseif("${name}" STREQUAL "CURL" AND EXISTS "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/include/curl")
- _find_package(${ARGV})
+ elseif("${PACKAGE_NAME}" STREQUAL "CURL" AND EXISTS "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/include/curl")
+ _find_package(${ARGS})
if(CURL_FOUND)
if(EXISTS "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/lib/nghttp2.lib")
list(APPEND CURL_LIBRARIES
@@ -647,34 +853,34 @@ macro(${VCPKG_OVERRIDE_FIND_PACKAGE_NAME} name)
"optimized" "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/lib/nghttp2.lib")
endif()
endif()
- elseif("${_vcpkg_lowercase_name}" STREQUAL "grpc" AND EXISTS "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/share/grpc")
- _find_package(gRPC ${ARGN})
+ elseif("${LOWERCASE_PACKAGE_NAME}" STREQUAL "grpc" AND EXISTS "${_VCPKG_INSTALLED_DIR}/${VCPKG_TARGET_TRIPLET}/share/grpc")
+ list(REMOVE_AT ARGS 0)
+ _find_package(gRPC ${ARGS})
else()
- _find_package(${ARGV})
- endif()
- if(CMAKE_SYSTEM_NAME STREQUAL iOS)
- set(CMAKE_FIND_ROOT_PATH "${BACKUP_CMAKE_FIND_ROOT_PATH}")
+ _find_package(${ARGS})
endif()
-endmacro()
+
+ z_vcpkg_complete_parent_scope_export(IGNORE_REGEX "(^Z_VCPKG_)|(^ARGS$)|(^COMPONENTS_IDX$)")
+endfunction()
set(VCPKG_TOOLCHAIN ON)
-set(_UNUSED ${CMAKE_ERROR_ON_ABSOLUTE_INSTALL_DESTINATION})
-set(_UNUSED ${CMAKE_EXPORT_NO_PACKAGE_REGISTRY})
-set(_UNUSED ${CMAKE_FIND_PACKAGE_NO_PACKAGE_REGISTRY})
-set(_UNUSED ${CMAKE_FIND_PACKAGE_NO_SYSTEM_PACKAGE_REGISTRY})
-set(_UNUSED ${CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_SKIP})
+set(Z_VCPKG_UNUSED "${CMAKE_ERROR_ON_ABSOLUTE_INSTALL_DESTINATION}")
+set(Z_VCPKG_UNUSED "${CMAKE_EXPORT_NO_PACKAGE_REGISTRY}")
+set(Z_VCPKG_UNUSED "${CMAKE_FIND_PACKAGE_NO_PACKAGE_REGISTRY}")
+set(Z_VCPKG_UNUSED "${CMAKE_FIND_PACKAGE_NO_SYSTEM_PACKAGE_REGISTRY}")
+set(Z_VCPKG_UNUSED "${CMAKE_INSTALL_SYSTEM_RUNTIME_LIBS_SKIP}")
# Propogate these values to try-compile configurations so the triplet and toolchain load
-if(NOT _CMAKE_IN_TRY_COMPILE)
- if(_CMAKE_EMULATE_TRY_COMPILE_PLATFORM_VARIABLES)
- file(TO_CMAKE_PATH "${VCPKG_CHAINLOAD_TOOLCHAIN_FILE}" _chainload_file)
- file(TO_CMAKE_PATH "${_VCPKG_ROOT_DIR}" _root_dir)
+if(NOT Z_VCPKG_CMAKE_IN_TRY_COMPILE)
+ if(Z_VCPKG_CMAKE_EMULATE_TRY_COMPILE_PLATFORM_VARIABLES)
+ file(TO_CMAKE_PATH "${VCPKG_CHAINLOAD_TOOLCHAIN_FILE}" Z_VCPKG_CHAINLOAD_FILE_CMAKE)
+ file(TO_CMAKE_PATH "${Z_VCPKG_ROOT_DIR}" Z_VCPKG_ROOT_DIR_CMAKE)
file(WRITE "${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/vcpkg.config.cmake"
"set(VCPKG_TARGET_TRIPLET \"${VCPKG_TARGET_TRIPLET}\" CACHE STRING \"\")\n"
"set(VCPKG_TARGET_ARCHITECTURE \"${VCPKG_TARGET_ARCHITECTURE}\" CACHE STRING \"\")\n"
"set(VCPKG_APPLOCAL_DEPS \"${VCPKG_APPLOCAL_DEPS}\" CACHE STRING \"\")\n"
- "set(VCPKG_CHAINLOAD_TOOLCHAIN_FILE \"${_chainload_file}\" CACHE STRING \"\")\n"
- "set(_VCPKG_ROOT_DIR \"${_root_dir}\" CACHE STRING \"\")\n"
+ "set(VCPKG_CHAINLOAD_TOOLCHAIN_FILE \"${Z_VCPKG_CHAINLOAD_FILE_CMAKE}\" CACHE STRING \"\")\n"
+ "set(Z_VCPKG_ROOT_DIR \"${Z_VCPKG_ROOT_DIR_CMAKE}\" CACHE STRING \"\")\n"
)
else()
list(APPEND CMAKE_TRY_COMPILE_PLATFORM_VARIABLES
@@ -682,11 +888,13 @@ if(NOT _CMAKE_IN_TRY_COMPILE)
VCPKG_TARGET_ARCHITECTURE
VCPKG_APPLOCAL_DEPS
VCPKG_CHAINLOAD_TOOLCHAIN_FILE
- _VCPKG_ROOT_DIR
+ Z_VCPKG_ROOT_DIR
)
endif()
endif()
-if(_VCPKG_HAS_FATAL_ERROR)
- message(FATAL_ERROR "${_VCPKG_FATAL_ERROR}")
+if(Z_VCPKG_HAS_FATAL_ERROR)
+ message(FATAL_ERROR "${Z_VCPKG_FATAL_ERROR}")
endif()
+
+cmake_policy(POP)
diff --git a/scripts/cmake/z_vcpkg_function_arguments.cmake b/scripts/cmake/z_vcpkg_function_arguments.cmake
index 368ae3692..2c5b694ed 100644
--- a/scripts/cmake/z_vcpkg_function_arguments.cmake
+++ b/scripts/cmake/z_vcpkg_function_arguments.cmake
@@ -24,6 +24,9 @@ function(foo_replacement)
endfunction()
```
#]===]
+
+# NOTE: this function definition is copied directly to scripts/buildsystems/vcpkg.cmake
+# do not make changes here without making the same change there.
macro(z_vcpkg_function_arguments OUT_VAR)
if("${ARGC}" EQUAL 1)
set(z_vcpkg_function_arguments_FIRST_ARG 0)