diff options
author | Brad King <brad.king@kitware.com> | 2014-12-12 16:13:21 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2014-12-12 16:13:21 (GMT) |
commit | 0dd9e7173d43251fa4aca0846d85911cc7e84d2a (patch) | |
tree | 30b99d060d74fc217aaf355c658ef60fece2bb8b /Help | |
parent | ce53ef0be135f15a95987db502cd29bebe03c0cc (diff) | |
parent | f2f1c95dd9a1e1b3dc6652ef2afb7ca74c0c986f (diff) | |
download | CMake-0dd9e7173d43251fa4aca0846d85911cc7e84d2a.zip CMake-0dd9e7173d43251fa4aca0846d85911cc7e84d2a.tar.gz CMake-0dd9e7173d43251fa4aca0846d85911cc7e84d2a.tar.bz2 |
Merge branch 'doc-CMP0054-example' into release
Diffstat (limited to 'Help')
-rw-r--r-- | Help/policy/CMP0054.rst | 34 |
1 files changed, 31 insertions, 3 deletions
diff --git a/Help/policy/CMP0054.rst b/Help/policy/CMP0054.rst index dffee5e..39f0c40 100644 --- a/Help/policy/CMP0054.rst +++ b/Help/policy/CMP0054.rst @@ -3,15 +3,43 @@ CMP0054 Only interpret :command:`if` arguments as variables or keywords when unquoted. -CMake 3.1 and above no longer dereference variables or interpret keywords -in an :command:`if` command argument when it is a :ref:`Quoted Argument` -or a :ref:`Bracket Argument`. +CMake 3.1 and above no longer implicitly dereference variables or +interpret keywords in an :command:`if` command argument when +it is a :ref:`Quoted Argument` or a :ref:`Bracket Argument`. The ``OLD`` behavior for this policy is to dereference variables and interpret keywords even if they are quoted or bracketed. The ``NEW`` behavior is to not dereference variables or interpret keywords that have been quoted or bracketed. +Given the following partial example: + +:: + + set(MONKEY 1) + set(ANIMAL MONKEY) + + if("${ANIMAL}" STREQUAL "MONKEY") + +After explicit expansion of variables this gives: + +:: + + if("MONKEY" STREQUAL "MONKEY") + +With the policy set to ``OLD`` implicit expansion reduces this semantically to: + +:: + + if("1" STREQUAL "1") + +With the policy set to ``NEW`` the quoted arguments will not be +further dereferenced: + +:: + + if("MONKEY" STREQUAL "MONKEY") + This policy was introduced in CMake version 3.1. CMake version |release| warns when the policy is not set and uses ``OLD`` behavior. Use the :command:`cmake_policy` command to set |