blob: 47559f3d3d2a90d05be04c22dd52c0a5ed695d73 (
plain)
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
91
92
93
94
95
96
97
98
99
|
# Distributed under the OSI-approved BSD 3-Clause License. See accompanying
# file LICENSE.rst or https://cmake.org/licensing for details.
#[=======================================================================[.rst:
CheckCXXSourceRuns
------------------
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(CheckCXXSourceRuns)
Commands
^^^^^^^^
This module provides the following command:
.. command:: check_cxx_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_cxx_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 check whether the C++ standard
library is functional and ``std::vector`` works at runtime. If the source
compiles, links, and runs successfully, internal cache variable
``HAVE_WORKING_STD_VECTOR`` will be set to boolean true value. Code is
supplied using :ref:`Bracket Argument` for easier embedded quotes handling:
.. code-block:: cmake
:force:
include(CheckCXXSourceRuns)
check_cxx_source_runs([[
#include <iostream>
#include <vector>
int main()
{
std::vector<int> v = {1, 2, 3};
if (v.size() != 3) return 1;
std::cout << "Vector works correctly." << std::endl;
return 0;
}
]] HAVE_WORKING_STD_VECTOR)
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_CXX_SOURCE_RUNS SOURCE VAR)
set(_CheckSourceRuns_old_signature 1)
cmake_check_source_runs(CXX "${SOURCE}" ${VAR} ${ARGN})
unset(_CheckSourceRuns_old_signature)
endmacro()
|