From 0ae60f7236e4da0c234f59f3671f742695d54905 Mon Sep 17 00:00:00 2001 From: Andrew Kelley Date: Sat, 22 Oct 2022 17:46:25 -0700 Subject: [PATCH] CMake: detect use of CMAKE_PREFIX_PATH env var CMake recognizes the CMAKE_PREFIX_PATH environment variable for some things, and also the CMAKE_PREFIX_PATH cache variable for other things. However, it does not relate these two things, i.e. if the environment variable is set, CMake does not populate the cache variable in a corresponding manner. Some package systems, such as Homebrew, set the environment variable but not the cache variable. Furthermore, the environment variable follows the system path separator, such as ':' on POSIX and ';' on Windows, but the cache variable follows CMake's array behavior, i.e. always ';' for a separator. Closes #13242 --- CMakeLists.txt | 16 ++++++++++++++++ src/stage1/config.h.in | 2 +- 2 files changed, 17 insertions(+), 1 deletion(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 4355fce270..3b540045e5 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -16,6 +16,22 @@ if(NOT CMAKE_INSTALL_PREFIX) "Directory to install zig to" FORCE) endif() +# CMake recognizes the CMAKE_PREFIX_PATH environment variable for some things, +# and also the CMAKE_PREFIX_PATH cache variable for other things. However, it +# does not relate these two things, i.e. if the environment variable is set, +# CMake does not populate the cache variable in a corresponding manner. Some +# package systems, such as Homebrew, set the environment variable but not the +# cache variable. Furthermore, the environment variable follows the system path +# separator, such as ':' on POSIX and ';' on Windows, but the cache variable +# follows CMake's array behavior, i.e. always ';' for a separator. +list(APPEND ZIG_CMAKE_PREFIX_PATH "${CMAKE_PREFIX_PATH}") +if(WIN32) + list(APPEND ZIG_CMAKE_PREFIX_PATH $ENV{CMAKE_PREFIX_PATH}) +else() + string(REGEX REPLACE ":" ";" ZIG_CMAKE_PREFIX_PATH_STRING "$ENV{CMAKE_PREFIX_PATH}") + list(APPEND ZIG_CMAKE_PREFIX_PATH "${ZIG_CMAKE_PREFIX_PATH_STRING}") +endif() + set(CMAKE_USER_MAKE_RULES_OVERRIDE ${CMAKE_CURRENT_SOURCE_DIR}/cmake/c_flag_overrides.cmake) set(CMAKE_USER_MAKE_RULES_OVERRIDE_CXX diff --git a/src/stage1/config.h.in b/src/stage1/config.h.in index 8d1e688cbe..2d4fff6df2 100644 --- a/src/stage1/config.h.in +++ b/src/stage1/config.h.in @@ -17,7 +17,7 @@ // Used by build.zig for communicating build information to self hosted build. #define ZIG_CMAKE_BINARY_DIR "@CMAKE_BINARY_DIR@" #define ZIG_LLVM_LINK_MODE "@LLVM_LINK_MODE@" -#define ZIG_CMAKE_PREFIX_PATH "@CMAKE_PREFIX_PATH@" +#define ZIG_CMAKE_PREFIX_PATH "@ZIG_CMAKE_PREFIX_PATH@" #define ZIG_CXX_COMPILER "@CMAKE_CXX_COMPILER@" #define ZIG_LLD_INCLUDE_PATH "@LLD_INCLUDE_DIRS@" #define ZIG_LLD_LIBRARIES "@LLD_LIBRARIES@"