1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
|
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
# file LICENSE.rst or https://cmake.org/licensing for details.
#[=======================================================================[.rst:
CheckCSourceRuns
----------------
This module provides a command to check whether a C source can be built and
run.
Load this module in a CMake project with:
.. code-block:: cmake
include(CheckCSourceRuns)
Commands
^^^^^^^^
This module provides the following command:
.. command:: check_c_source_runs
Checks once whether the given C source code compiles and links into an
executable that can subsequently be run:
.. code-block:: cmake
check_c_source_runs(<code> <variable>)
The C source supplied in ``<code>`` must contain at least a ``main()``
function. The result of the check is stored in the internal cache variable
specified by ``<variable>``. If the code builds and runs with exit code
``0``, success is indicated by a boolean true value. Failure to build or
run is indicated by a boolean false value, such as an empty string or an
error message.
.. 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 use this module to check whether
the C source code is supported and operational at runtime. The result of
the check is stored in the internal cache variable ``HAVE_NORETURN``.
.. code-block:: cmake
include(CheckCSourceRuns)
check_c_source_runs("
#include <stdlib.h>
#include <stdnoreturn.h>
noreturn void f(){ exit(0); }
int main(void) { f(); return 1; }
" HAVE_NORETURN)
See Also
^^^^^^^^
* The :module:`CheckSourceRuns` module for a more general command syntax.
* The :module:`CheckSourceCompiles` module to check whether a source code
can be built.
#]=======================================================================]
include_guard(GLOBAL)
include(Internal/CheckSourceRuns)
macro(CHECK_C_SOURCE_RUNS SOURCE VAR)
set(_CheckSourceRuns_old_signature 1)
cmake_check_source_runs(C "${SOURCE}" ${VAR} ${ARGN})
unset(_CheckSourceRuns_old_signature)
endmacro()
|