mirror of
https://github.com/Kitware/CMake.git
synced 2025-10-14 02:08:27 +08:00

- Added intro code blocks showing how to include these modules. - Added section titles. - Used "command" instead of "macro". - Indented command-related descriptions according to the command section indentation level. - Added the "See Also" sections. - Synced descriptions between the modules.
107 lines
3.5 KiB
CMake
107 lines
3.5 KiB
CMake
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
# file LICENSE.rst or https://cmake.org/licensing for details.
|
|
|
|
#[=======================================================================[.rst:
|
|
CheckCXXSymbolExists
|
|
--------------------
|
|
|
|
This module provides a command to check whether a C++ symbol exists.
|
|
|
|
Load this module in a CMake project with:
|
|
|
|
.. code-block:: cmake
|
|
|
|
include(CheckCXXSymbolExists)
|
|
|
|
Commands
|
|
^^^^^^^^
|
|
|
|
This module provides the following command:
|
|
|
|
.. command:: check_cxx_symbol_exists
|
|
|
|
Checks once whether a symbol exists as a function, variable, or preprocessor
|
|
macro in C++:
|
|
|
|
.. code-block:: cmake
|
|
|
|
check_cxx_symbol_exists(<symbol> <headers> <variable>)
|
|
|
|
This command checks whether the ``<symbol>`` is available after including
|
|
the specified header file(s) ``<headers>``, and stores the result in the
|
|
internal cache variable ``<variable>``. Multiple header files can be
|
|
specified in one argument as a string using a
|
|
:ref:`semicolon-separated list <CMake Language Lists>`.
|
|
|
|
If the header files define the symbol as a macro, it is considered
|
|
available and assumed to work. If the symbol is declared as a function
|
|
or variable, the check also ensures that it links successfully
|
|
(i.e., the symbol must exist in a linked library or object file).
|
|
|
|
Symbols that are types, enum values, or C++ templates are not
|
|
recognized. For those, consider using the :module:`CheckTypeSize` or
|
|
:module:`CheckSourceCompiles` module instead.
|
|
|
|
This command is intended to check symbols as they appear in C++. For C
|
|
symbols, use the :module:`CheckSymbolExists` module instead.
|
|
|
|
.. note::
|
|
|
|
This command is unreliable for symbols that are (potentially) overloaded
|
|
functions. Since there is no reliable way to predict whether
|
|
a given function in the system environment may be defined as an
|
|
overloaded function or may be an overloaded function on other systems
|
|
or will become so in the future, it is generally advised to use the
|
|
:module:`CheckSourceCompiles` module for checking any function symbol
|
|
(unless it is certain the checked function is not overloaded on other
|
|
systems or will not be so in the future).
|
|
|
|
.. rubric:: Variables Affecting the Check
|
|
|
|
The following variables may be set before calling this command to modify
|
|
the way the check is run:
|
|
|
|
.. include:: /module/include/CMAKE_REQUIRED_FLAGS.rst
|
|
|
|
.. include:: /module/include/CMAKE_REQUIRED_DEFINITIONS.rst
|
|
|
|
.. include:: /module/include/CMAKE_REQUIRED_INCLUDES.rst
|
|
|
|
.. include:: /module/include/CMAKE_REQUIRED_LINK_OPTIONS.rst
|
|
|
|
.. include:: /module/include/CMAKE_REQUIRED_LIBRARIES.rst
|
|
|
|
.. include:: /module/include/CMAKE_REQUIRED_LINK_DIRECTORIES.rst
|
|
|
|
.. include:: /module/include/CMAKE_REQUIRED_QUIET.rst
|
|
|
|
Examples
|
|
^^^^^^^^
|
|
|
|
The following example demonstrates how to check for the presence of a
|
|
preprocessor macro ``SEEK_SET`` and the C++ function ``std::fopen()`` from
|
|
the ``<cstdio>`` header using this module:
|
|
|
|
.. code-block:: cmake
|
|
|
|
include(CheckCXXSymbolExists)
|
|
|
|
# Check for macro SEEK_SET
|
|
check_cxx_symbol_exists(SEEK_SET "cstdio" HAVE_SEEK_SET)
|
|
|
|
# Check for function std::fopen
|
|
check_cxx_symbol_exists(std::fopen "cstdio" HAVE_STD_FOPEN)
|
|
|
|
See Also
|
|
^^^^^^^^
|
|
|
|
* The :module:`CheckSymbolExists` module to check whether a C symbol exists.
|
|
#]=======================================================================]
|
|
|
|
include_guard(GLOBAL)
|
|
include(CheckSymbolExists)
|
|
|
|
macro(CHECK_CXX_SYMBOL_EXISTS SYMBOL FILES VARIABLE)
|
|
__CHECK_SYMBOL_EXISTS_IMPL(CheckSymbolExists.cxx "${SYMBOL}" "${FILES}" "${VARIABLE}" )
|
|
endmacro()
|