summaryrefslogtreecommitdiff
path: root/Help/prop_tgt/C_STANDARD_REQUIRED.rst
blob: 8059e3a669dd676add2863f8f637a34197024ea4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
C_STANDARD_REQUIRED
-------------------

.. versionadded:: 3.1

Boolean describing whether the value of :prop_tgt:`C_STANDARD` is a requirement.

If this property is set to ``ON``, then the value of the
:prop_tgt:`C_STANDARD` target property is treated as a requirement.  If this
property is ``OFF`` or unset, the :prop_tgt:`C_STANDARD` target property is
treated as optional and may "decay" to a previous standard if the requested is
not available.  For compilers that have no notion of a C standard level, such
as Microsoft Visual C++ before VS 16.7, this property has no effect.

See the :manual:`cmake-compile-features(7)` manual for information on
compile features and a list of supported compilers.

This property is initialized by the value of
the :variable:`CMAKE_C_STANDARD_REQUIRED` variable if it is set when a
target is created.