|
|
|
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
|
|
# file Copyright.txt or https://cmake.org/licensing for details.
|
|
|
|
|
|
|
|
#.rst:
|
|
|
|
# CheckCXXSymbolExists
|
|
|
|
# --------------------
|
|
|
|
#
|
|
|
|
# Check if a symbol exists as a function, variable, or macro in C++
|
|
|
|
#
|
|
|
|
# CHECK_CXX_SYMBOL_EXISTS(<symbol> <files> <variable>)
|
|
|
|
#
|
|
|
|
# Check that the <symbol> is available after including given header
|
|
|
|
# <files> and store the result in a <variable>. Specify the list of
|
|
|
|
# files in one argument as a semicolon-separated list.
|
|
|
|
# CHECK_CXX_SYMBOL_EXISTS() can be used to check in C++ files, as
|
|
|
|
# opposed to CHECK_SYMBOL_EXISTS(), which works only for C.
|
|
|
|
#
|
|
|
|
# If the header files define the symbol as a macro it is considered
|
|
|
|
# available and assumed to work. If the header files declare the symbol
|
|
|
|
# as a function or variable then the symbol must also be available for
|
|
|
|
# linking. If the symbol is a type or enum value it will not be
|
|
|
|
# recognized (consider using CheckTypeSize or CheckCSourceCompiles).
|
|
|
|
#
|
|
|
|
# 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 = list of macros to define (-DFOO=bar)
|
|
|
|
# CMAKE_REQUIRED_INCLUDES = list of include directories
|
|
|
|
# CMAKE_REQUIRED_LIBRARIES = list of libraries to link
|
|
|
|
# CMAKE_REQUIRED_QUIET = execute quietly without messages
|
|
|
|
|
|
|
|
include(CheckSymbolExists)
|
|
|
|
|
|
|
|
macro(CHECK_CXX_SYMBOL_EXISTS SYMBOL FILES VARIABLE)
|
|
|
|
_CHECK_SYMBOL_EXISTS("${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckSymbolExists.cxx" "${SYMBOL}" "${FILES}" "${VARIABLE}" )
|
|
|
|
endmacro()
|