|
|
|
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
|
|
# file Copyright.txt or https://cmake.org/licensing for details.
|
|
|
|
|
|
|
|
#[=======================================================================[.rst:
|
|
|
|
CheckIncludeFiles
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
Provides a macro to check if a list of one or more header files can
|
|
|
|
be included together.
|
|
|
|
|
|
|
|
.. command:: CHECK_INCLUDE_FILES
|
|
|
|
|
|
|
|
.. code-block:: cmake
|
|
|
|
|
|
|
|
CHECK_INCLUDE_FILES("<includes>" <variable> [LANGUAGE <language>])
|
|
|
|
|
|
|
|
Check if the given ``<includes>`` list may be included together
|
|
|
|
in a source file and store the result in an internal cache
|
|
|
|
entry named ``<variable>``. Specify the ``<includes>`` argument
|
|
|
|
as a :ref:`;-list <CMake Language Lists>` of header file names.
|
|
|
|
|
|
|
|
If ``LANGUAGE`` is set, the specified compiler will be used to perform the
|
|
|
|
check. Acceptable values are ``C`` and ``CXX``. If not set, the C compiler
|
|
|
|
will be used if enabled. If the C compiler is not enabled, the C++
|
|
|
|
compiler will be used if enabled.
|
|
|
|
|
|
|
|
The following variables may be set before calling this macro to modify
|
|
|
|
the way the check is run:
|
|
|
|
|
|
|
|
``CMAKE_REQUIRED_FLAGS``
|
|
|
|
string of compile command line flags.
|
|
|
|
``CMAKE_REQUIRED_DEFINITIONS``
|
|
|
|
a :ref:`;-list <CMake Language Lists>` of macros to define (-DFOO=bar).
|
|
|
|
``CMAKE_REQUIRED_INCLUDES``
|
|
|
|
a :ref:`;-list <CMake Language Lists>` of header search paths to pass to
|
|
|
|
the compiler.
|
|
|
|
``CMAKE_REQUIRED_LINK_OPTIONS``
|
|
|
|
.. versionadded:: 3.14
|
|
|
|
a :ref:`;-list <CMake Language Lists>` of options to add to the link command.
|
|
|
|
``CMAKE_REQUIRED_LIBRARIES``
|
|
|
|
a :ref:`;-list <CMake Language Lists>` of libraries to add to the link
|
|
|
|
command. See policy :policy:`CMP0075`.
|
|
|
|
``CMAKE_REQUIRED_QUIET``
|
|
|
|
.. versionadded:: 3.1
|
|
|
|
execute quietly without messages.
|
|
|
|
|
|
|
|
See modules :module:`CheckIncludeFile` and :module:`CheckIncludeFileCXX`
|
|
|
|
to check for a single header file in ``C`` or ``CXX`` languages.
|
|
|
|
#]=======================================================================]
|
|
|
|
|
|
|
|
include_guard(GLOBAL)
|
|
|
|
|
|
|
|
macro(CHECK_INCLUDE_FILES INCLUDE VARIABLE)
|
|
|
|
if(NOT DEFINED "${VARIABLE}")
|
|
|
|
set(CMAKE_CONFIGURABLE_FILE_CONTENT "/* */\n")
|
|
|
|
|
|
|
|
if("x${ARGN}" STREQUAL "x")
|
|
|
|
if(CMAKE_C_COMPILER_LOADED)
|
|
|
|
set(_lang C)
|
|
|
|
elseif(CMAKE_CXX_COMPILER_LOADED)
|
|
|
|
set(_lang CXX)
|
|
|
|
else()
|
|
|
|
message(FATAL_ERROR "CHECK_INCLUDE_FILES needs either C or CXX language enabled.\n")
|
|
|
|
endif()
|
|
|
|
elseif("x${ARGN}" MATCHES "^xLANGUAGE;([a-zA-Z]+)$")
|
|
|
|
set(_lang "${CMAKE_MATCH_1}")
|
|
|
|
elseif("x${ARGN}" MATCHES "^xLANGUAGE$")
|
|
|
|
message(FATAL_ERROR "No languages listed for LANGUAGE option.\nSupported languages: C, CXX.\n")
|
|
|
|
else()
|
|
|
|
message(FATAL_ERROR "Unknown arguments:\n ${ARGN}\n")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(_lang STREQUAL "C")
|
|
|
|
set(src ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CheckIncludeFiles/${VARIABLE}.c)
|
|
|
|
elseif(_lang STREQUAL "CXX")
|
|
|
|
set(src ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CheckIncludeFiles/${VARIABLE}.cpp)
|
|
|
|
else()
|
|
|
|
message(FATAL_ERROR "Unknown language:\n ${_lang}\nSupported languages: C, CXX.\n")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(CMAKE_REQUIRED_INCLUDES)
|
|
|
|
set(CHECK_INCLUDE_FILES_INCLUDE_DIRS "-DINCLUDE_DIRECTORIES=${CMAKE_REQUIRED_INCLUDES}")
|
|
|
|
else()
|
|
|
|
set(CHECK_INCLUDE_FILES_INCLUDE_DIRS)
|
|
|
|
endif()
|
|
|
|
set(CHECK_INCLUDE_FILES_CONTENT "/* */\n")
|
|
|
|
set(MACRO_CHECK_INCLUDE_FILES_FLAGS ${CMAKE_REQUIRED_FLAGS})
|
|
|
|
foreach(FILE ${INCLUDE})
|
|
|
|
string(APPEND CMAKE_CONFIGURABLE_FILE_CONTENT
|
|
|
|
"#include <${FILE}>\n")
|
|
|
|
endforeach()
|
|
|
|
string(APPEND CMAKE_CONFIGURABLE_FILE_CONTENT
|
|
|
|
"\n\nint main(void){return 0;}\n")
|
|
|
|
configure_file("${CMAKE_ROOT}/Modules/CMakeConfigurableFile.in"
|
|
|
|
"${src}" @ONLY)
|
|
|
|
|
|
|
|
set(_INCLUDE ${INCLUDE}) # remove empty elements
|
|
|
|
if("${_INCLUDE}" MATCHES "^([^;]+);.+;([^;]+)$")
|
|
|
|
list(LENGTH _INCLUDE _INCLUDE_LEN)
|
|
|
|
set(_description "${_INCLUDE_LEN} include files ${CMAKE_MATCH_1}, ..., ${CMAKE_MATCH_2}")
|
|
|
|
elseif("${_INCLUDE}" MATCHES "^([^;]+);([^;]+)$")
|
|
|
|
set(_description "include files ${CMAKE_MATCH_1}, ${CMAKE_MATCH_2}")
|
|
|
|
else()
|
|
|
|
set(_description "include file ${_INCLUDE}")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
set(_CIF_LINK_OPTIONS)
|
|
|
|
if(CMAKE_REQUIRED_LINK_OPTIONS)
|
|
|
|
set(_CIF_LINK_OPTIONS LINK_OPTIONS ${CMAKE_REQUIRED_LINK_OPTIONS})
|
|
|
|
endif()
|
|
|
|
|
|
|
|
set(_CIF_LINK_LIBRARIES "")
|
|
|
|
if(CMAKE_REQUIRED_LIBRARIES)
|
|
|
|
cmake_policy(GET CMP0075 _CIF_CMP0075
|
|
|
|
PARENT_SCOPE # undocumented, do not use outside of CMake
|
|
|
|
)
|
|
|
|
if("x${_CIF_CMP0075}x" STREQUAL "xNEWx")
|
|
|
|
set(_CIF_LINK_LIBRARIES LINK_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES})
|
|
|
|
elseif("x${_CIF_CMP0075}x" STREQUAL "xOLDx")
|
|
|
|
elseif(NOT _CIF_CMP0075_WARNED)
|
|
|
|
set(_CIF_CMP0075_WARNED 1)
|
|
|
|
message(AUTHOR_WARNING
|
|
|
|
"Policy CMP0075 is not set: Include file check macros honor CMAKE_REQUIRED_LIBRARIES. "
|
|
|
|
"Run \"cmake --help-policy CMP0075\" for policy details. "
|
|
|
|
"Use the cmake_policy command to set the policy and suppress this warning."
|
|
|
|
"\n"
|
|
|
|
"CMAKE_REQUIRED_LIBRARIES is set to:\n"
|
|
|
|
" ${CMAKE_REQUIRED_LIBRARIES}\n"
|
|
|
|
"For compatibility with CMake 3.11 and below this check is ignoring it."
|
|
|
|
)
|
|
|
|
endif()
|
|
|
|
unset(_CIF_CMP0075)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(NOT CMAKE_REQUIRED_QUIET)
|
|
|
|
message(CHECK_START "Looking for ${_description}")
|
|
|
|
endif()
|
|
|
|
try_compile(${VARIABLE}
|
|
|
|
${CMAKE_BINARY_DIR}
|
|
|
|
${src}
|
|
|
|
COMPILE_DEFINITIONS ${CMAKE_REQUIRED_DEFINITIONS}
|
|
|
|
${_CIF_LINK_OPTIONS}
|
|
|
|
${_CIF_LINK_LIBRARIES}
|
|
|
|
CMAKE_FLAGS
|
|
|
|
-DCOMPILE_DEFINITIONS:STRING=${MACRO_CHECK_INCLUDE_FILES_FLAGS}
|
|
|
|
"${CHECK_INCLUDE_FILES_INCLUDE_DIRS}"
|
|
|
|
OUTPUT_VARIABLE OUTPUT)
|
|
|
|
unset(_CIF_LINK_OPTIONS)
|
|
|
|
unset(_CIF_LINK_LIBRARIES)
|
|
|
|
if(${VARIABLE})
|
|
|
|
if(NOT CMAKE_REQUIRED_QUIET)
|
|
|
|
message(CHECK_PASS "found")
|
|
|
|
endif()
|
|
|
|
set(${VARIABLE} 1 CACHE INTERNAL "Have include ${INCLUDE}")
|
|
|
|
file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeOutput.log
|
|
|
|
"Determining if files ${INCLUDE} "
|
|
|
|
"exist passed with the following output:\n"
|
|
|
|
"${OUTPUT}\n\n")
|
|
|
|
else()
|
|
|
|
if(NOT CMAKE_REQUIRED_QUIET)
|
|
|
|
message(CHECK_FAIL "not found")
|
|
|
|
endif()
|
|
|
|
set(${VARIABLE} "" CACHE INTERNAL "Have includes ${INCLUDE}")
|
|
|
|
file(APPEND ${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeError.log
|
|
|
|
"Determining if files ${INCLUDE} "
|
|
|
|
"exist failed with the following output:\n"
|
|
|
|
"${OUTPUT}\nSource:\n${CMAKE_CONFIGURABLE_FILE_CONTENT}\n")
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
endmacro()
|