|
|
|
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
|
|
# file Copyright.txt or https://cmake.org/licensing for details.
|
|
|
|
|
|
|
|
#[=======================================================================[.rst:
|
|
|
|
CheckOBJCXXCompilerFlag
|
|
|
|
-----------------------
|
|
|
|
|
|
|
|
.. versionadded:: 3.16
|
|
|
|
|
|
|
|
Check once whether the Objective-C++ compiler supports a given flag.
|
|
|
|
|
|
|
|
.. command:: check_objcxx_compiler_flag
|
|
|
|
|
|
|
|
.. code-block:: cmake
|
|
|
|
|
|
|
|
check_objcxx_compiler_flag(<flag> <resultVar>)
|
|
|
|
|
|
|
|
Check once that the ``<flag>`` is accepted by the compiler without a diagnostic.
|
|
|
|
The result is stored in the internal cache variable specified by
|
|
|
|
``<resultVar>``, with boolean ``true`` for success and boolean ``false`` for
|
|
|
|
failure.
|
|
|
|
|
|
|
|
``true`` indicates only that the compiler did not issue a diagnostic message
|
|
|
|
when given the flag. Whether the flag has any effect is beyond the scope of
|
|
|
|
this module.
|
|
|
|
|
|
|
|
Internally, :command:`try_compile` is used to perform the check. If
|
|
|
|
:variable:`CMAKE_TRY_COMPILE_TARGET_TYPE` is set to ``EXECUTABLE`` (default),
|
|
|
|
the check compiles and links an executable program. If set to
|
|
|
|
``STATIC_LIBRARY``, the check is compiled but not linked.
|
|
|
|
|
|
|
|
See also :command:`check_compiler_flag` for a more general command syntax.
|
|
|
|
|
|
|
|
The compile and link commands can be influenced by setting any of the
|
|
|
|
following variables prior to calling ``check_objcxx_compiler_flag()``. Unknown
|
|
|
|
flags in these variables can case a false negative result.
|
|
|
|
|
|
|
|
.. include:: /module/CMAKE_REQUIRED_FLAGS.txt
|
|
|
|
|
|
|
|
.. include:: /module/CMAKE_REQUIRED_DEFINITIONS.txt
|
|
|
|
|
|
|
|
.. include:: /module/CMAKE_REQUIRED_INCLUDES.txt
|
|
|
|
|
|
|
|
.. include:: /module/CMAKE_REQUIRED_LINK_OPTIONS.txt
|
|
|
|
|
|
|
|
.. include:: /module/CMAKE_REQUIRED_LIBRARIES.txt
|
|
|
|
|
|
|
|
.. include:: /module/CMAKE_REQUIRED_LINK_DIRECTORIES.txt
|
|
|
|
|
|
|
|
.. include:: /module/CMAKE_REQUIRED_QUIET.txt
|
|
|
|
|
|
|
|
#]=======================================================================]
|
|
|
|
|
|
|
|
include_guard(GLOBAL)
|
|
|
|
include(Internal/CheckCompilerFlag)
|
|
|
|
|
|
|
|
macro (CHECK_OBJCXX_COMPILER_FLAG _FLAG _RESULT)
|
|
|
|
cmake_check_compiler_flag(OBJCXX "${_FLAG}" ${_RESULT})
|
|
|
|
endmacro ()
|
|
|
|
|
|
|
|
# FIXME(#24994): The following module is included only for compatibility
|
|
|
|
# with projects that accidentally relied on it with CMake 3.26 and below.
|
|
|
|
include(CheckOBJCXXSourceCompiles)
|