mirror of
https://github.com/Kitware/CMake.git
synced 2025-12-31 02:39:48 -06:00
- Added intro code block showing how to include this module. - Added examples section. - Added missing CMAKE_REQUIRED_LINK_DIRECTORIES variable (this module can also use it as of CMake 3.31). - Added a note that this is a linker only check and it doesn't check whether the variable is also declared in headers, unlike check_symbol_exists(). - Added "See Also" section.
158 lines
4.6 KiB
CMake
158 lines
4.6 KiB
CMake
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
# file LICENSE.rst or https://cmake.org/licensing for details.
|
|
|
|
#[=======================================================================[.rst:
|
|
CheckVariableExists
|
|
-------------------
|
|
|
|
This module provides a command to check whether a C variable exists.
|
|
|
|
Load this module in a CMake project with:
|
|
|
|
.. code-block:: cmake
|
|
|
|
include(CheckVariableExists)
|
|
|
|
Commands
|
|
^^^^^^^^
|
|
|
|
This module provides the following command:
|
|
|
|
.. command:: check_variable_exists
|
|
|
|
Checks once if a C variable exists:
|
|
|
|
.. code-block:: cmake
|
|
|
|
check_variable_exists(<var> <variable>)
|
|
|
|
This command attempts to compile and link a test C program that references
|
|
the specified C variable ``<var>``. A boolean result of whether
|
|
the check was successful is stored in an internal cache variable
|
|
``<variable>``.
|
|
|
|
.. note::
|
|
|
|
Prefer using :module:`CheckSymbolExists` or :module:`CheckSourceCompiles`
|
|
instead of this command for more robust detection. This command performs
|
|
a link-only check and doesn't detect whether a variable is also declared
|
|
in system or library headers. Neither can it detect variables that might
|
|
be defined as preprocessor macros.
|
|
|
|
.. 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_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
|
|
^^^^^^^^
|
|
|
|
Example: Basic Usage
|
|
""""""""""""""""""""
|
|
|
|
In the following example, a check is performed whether the linker sees the
|
|
C variable ``tzname`` and stores the check result in the
|
|
``PROJECT_HAVE_TZNAME`` internal cache variable:
|
|
|
|
.. code-block:: cmake
|
|
|
|
include(CheckVariableExists)
|
|
|
|
check_variable_exists(tzname PROJECT_HAVE_TZNAME)
|
|
|
|
Example: Isolated Check With Linked Libraries
|
|
"""""""""""""""""""""""""""""""""""""""""""""
|
|
|
|
In the following example, this module is used in combination with the
|
|
:module:`CMakePushCheckState` module to link additional required library
|
|
using the ``CMAKE_REQUIRED_LIBRARIES`` variable. For example, in a find
|
|
module, to check whether the Net-SNMP library has the
|
|
``usmHMAC192SHA256AuthProtocol`` array:
|
|
|
|
.. code-block:: cmake
|
|
|
|
include(CheckVariableExists)
|
|
include(CMakePushCheckState)
|
|
|
|
find_library(SNMP_LIBRARY NAMES netsnmp)
|
|
|
|
if(SNMP_LIBRARY)
|
|
cmake_push_check_state(RESET)
|
|
|
|
set(CMAKE_REQUIRED_LIBRARIES ${SNMP_LIBRARY})
|
|
|
|
check_variable_exists(usmHMAC192SHA256AuthProtocol SNMP_HAVE_SHA256)
|
|
|
|
cmake_pop_check_state()
|
|
endif()
|
|
|
|
See Also
|
|
^^^^^^^^
|
|
|
|
* The :module:`CheckSymbolExists` module to check whether a C symbol exists.
|
|
#]=======================================================================]
|
|
|
|
include_guard(GLOBAL)
|
|
|
|
macro(CHECK_VARIABLE_EXISTS VAR VARIABLE)
|
|
if(NOT DEFINED "${VARIABLE}")
|
|
set(MACRO_CHECK_VARIABLE_DEFINITIONS
|
|
"-DCHECK_VARIABLE_EXISTS=${VAR} ${CMAKE_REQUIRED_FLAGS}")
|
|
if(NOT CMAKE_REQUIRED_QUIET)
|
|
message(CHECK_START "Looking for ${VAR}")
|
|
endif()
|
|
if(CMAKE_REQUIRED_LINK_OPTIONS)
|
|
set(CHECK_VARIABLE_EXISTS_ADD_LINK_OPTIONS
|
|
LINK_OPTIONS ${CMAKE_REQUIRED_LINK_OPTIONS})
|
|
else()
|
|
set(CHECK_VARIABLE_EXISTS_ADD_LINK_OPTIONS)
|
|
endif()
|
|
if(CMAKE_REQUIRED_LIBRARIES)
|
|
set(CHECK_VARIABLE_EXISTS_ADD_LIBRARIES
|
|
LINK_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES})
|
|
else()
|
|
set(CHECK_VARIABLE_EXISTS_ADD_LIBRARIES)
|
|
endif()
|
|
|
|
if(CMAKE_REQUIRED_LINK_DIRECTORIES)
|
|
set(_CVE_LINK_DIRECTORIES
|
|
"-DLINK_DIRECTORIES:STRING=${CMAKE_REQUIRED_LINK_DIRECTORIES}")
|
|
else()
|
|
set(_CVE_LINK_DIRECTORIES)
|
|
endif()
|
|
|
|
try_compile(${VARIABLE}
|
|
SOURCES ${CMAKE_ROOT}/Modules/CheckVariableExists.c
|
|
COMPILE_DEFINITIONS ${CMAKE_REQUIRED_DEFINITIONS}
|
|
${CHECK_VARIABLE_EXISTS_ADD_LINK_OPTIONS}
|
|
${CHECK_VARIABLE_EXISTS_ADD_LIBRARIES}
|
|
CMAKE_FLAGS -DCOMPILE_DEFINITIONS:STRING=${MACRO_CHECK_VARIABLE_DEFINITIONS}
|
|
"${_CVE_LINK_DIRECTORIES}"
|
|
)
|
|
unset(_CVE_LINK_DIRECTORIES)
|
|
if(${VARIABLE})
|
|
set(${VARIABLE} 1 CACHE INTERNAL "Have variable ${VAR}")
|
|
if(NOT CMAKE_REQUIRED_QUIET)
|
|
message(CHECK_PASS "found")
|
|
endif()
|
|
else()
|
|
set(${VARIABLE} "" CACHE INTERNAL "Have variable ${VAR}")
|
|
if(NOT CMAKE_REQUIRED_QUIET)
|
|
message(CHECK_FAIL "not found")
|
|
endif()
|
|
endif()
|
|
endif()
|
|
endmacro()
|