summaryrefslogtreecommitdiff
path: root/Help/variable/CMAKE_POLICY_WARNING_CMPNNNN.rst
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2014-04-02 14:02:03 -0400
committerBrad King <brad.king@kitware.com>2014-04-02 14:43:54 -0400
commita41c0a9dcbc201b183bcc0a0c0f6bf9f2cebd079 (patch)
treec280c254b20660d77b2f8ce815d1733660201ccb /Help/variable/CMAKE_POLICY_WARNING_CMPNNNN.rst
parentd339653eaf8757b79f02a315cb5e6d63555f17d2 (diff)
downloadcmake-a41c0a9dcbc201b183bcc0a0c0f6bf9f2cebd079.tar.gz
Do not warn by default when policy CMP0025 or CMP0047 is not set
These policies are triggered by the use of a particular compiler rather than outdated CMake code in a project. Avoid warning in every project that enables a language by not displaying the policy warning by default. Add variable CMAKE_POLICY_WARNING_CMP<NNNN> to control the warning explicitly; otherwise enable the warning with --debug-output or --trace. This breaks with strict policy convention because it does not provide developers with any warning about the behavior change by default. Existing projects will continue to build without a warning or change in behavior. When a developer changes the minimum required version of CMake in a project to a sufficiently high value (3.0), the project will suddenly get the new compiler id and may break, but at least the breakage comes with a change to the project rather than the version of CMake used to build it. Breaking strict policy convention is worthwhile in this case because very few projects will be affected by the behavior change but every project would have to see the warning if it were enabled by default.
Diffstat (limited to 'Help/variable/CMAKE_POLICY_WARNING_CMPNNNN.rst')
-rw-r--r--Help/variable/CMAKE_POLICY_WARNING_CMPNNNN.rst17
1 files changed, 17 insertions, 0 deletions
diff --git a/Help/variable/CMAKE_POLICY_WARNING_CMPNNNN.rst b/Help/variable/CMAKE_POLICY_WARNING_CMPNNNN.rst
new file mode 100644
index 0000000000..b563aeaec0
--- /dev/null
+++ b/Help/variable/CMAKE_POLICY_WARNING_CMPNNNN.rst
@@ -0,0 +1,17 @@
+CMAKE_POLICY_WARNING_CMP<NNNN>
+------------------------------
+
+Explicitly enable or disable the warning when CMake Policy ``CMP<NNNN>``
+is not set. This is meaningful only for the few policies that do not
+warn by default:
+
+* ``CMAKE_POLICY_WARNING_CMP0025`` controls the warning for
+ policy :policy:`CMP0025`.
+* ``CMAKE_POLICY_WARNING_CMP0047`` controls the warning for
+ policy :policy:`CMP0047`.
+
+This variable should not be set by a project in CMake code. Project
+developers running CMake may set this variable in their cache to
+enable the warning (e.g. ``-DCMAKE_POLICY_WARNING_CMP<NNNN>=ON``).
+Alternatively, running :manual:`cmake(1)` with the ``--debug-output``
+or ``--trace`` option will also enable the warning.