CMAKE_SYSTEM_PREFIX_PATH
Semicolon-separated list of directories specifying installation prefixes to be searched by the find_package()
, find_program()
, find_library()
, find_file()
, and find_path()
commands. Each command will add appropriate subdirectories (like bin
, lib
, or include
) as specified in its own documentation.
By default this contains the system directories for the current system, the CMAKE_INSTALL_PREFIX
, and the CMAKE_STAGING_PREFIX
. The installation and staging prefixes may be excluded by setting the CMAKE_FIND_NO_INSTALL_PREFIX
variable.
The system directories that are contained in CMAKE_SYSTEM_PREFIX_PATH
are locations that typically include installed software. An example being /usr/local
for UNIX based platforms. In addition to standard platform locations, CMake will also add values to CMAKE_SYSTEM_PREFIX_PATH
based on environment variables. The environment variables and search locations that CMake uses may evolve over time, as platforms and their conventions also evolve. The following provides an indicative list of environment variables and locations that CMake searches, but they are subject to change:
- CrayLinuxEnvironment:
-
ENV{SYSROOT_DIR}/
ENV{SYSROOT_DIR}/usr
ENV{SYSROOT_DIR}/usr/local
- Darwin:
-
-
ENV{SDKROOT}/usr
WhenCMAKE_OSX_SYSROOT
is not explicitly specified.
-
- OpenBSD:
-
ENV{LOCALBASE}
- Unix:
-
-
ENV{CONDA_PREFIX}
when using a conda compiler
-
- Windows:
-
ENV{ProgramW6432}
ENV{ProgramFiles}
ENV{ProgramFiles(x86)}
ENV{SystemDrive}/Program Files
ENV{SystemDrive}/Program Files (x86)
CMAKE_SYSTEM_PREFIX_PATH
is not intended to be modified by the project; use CMAKE_PREFIX_PATH
for this.
See also CMAKE_SYSTEM_INCLUDE_PATH
, CMAKE_SYSTEM_LIBRARY_PATH
, CMAKE_SYSTEM_PROGRAM_PATH
, and CMAKE_SYSTEM_IGNORE_PATH
.
© 2000–2020 Kitware, Inc. and Contributors
Licensed under the BSD 3-clause License.
https://cmake.org/cmake/help/v3.18/variable/CMAKE_SYSTEM_PREFIX_PATH.html