diff options
author | Glen Chung <kuchung@microsoft.com> | 2022-05-24 19:14:59 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2022-05-26 13:06:01 (GMT) |
commit | 5fcadc481e4b60e5dbbacb026b73631b69ca3746 (patch) | |
tree | 3c121306587bd873133dfb76e190f61be937f697 /Help | |
parent | bb500723555940a29355a71898b44be196dec2a6 (diff) | |
download | CMake-5fcadc481e4b60e5dbbacb026b73631b69ca3746.zip CMake-5fcadc481e4b60e5dbbacb026b73631b69ca3746.tar.gz CMake-5fcadc481e4b60e5dbbacb026b73631b69ca3746.tar.bz2 |
MSVC: Default to -ZI instead of /Zi for x86 and x64
Add a policy for compatibility.
For more information, see [1].
[1] https://docs.microsoft.com/en-us/cpp/build/reference/z7-zi-zi-debug-information-format?view=msvc-170
Fixes: #10189
Diffstat (limited to 'Help')
-rw-r--r-- | Help/manual/cmake-policies.7.rst | 1 | ||||
-rw-r--r-- | Help/policy/CMP0138.rst | 43 | ||||
-rw-r--r-- | Help/release/dev/msvc-compilers-default-to-ZI.rst | 5 |
3 files changed, 49 insertions, 0 deletions
diff --git a/Help/manual/cmake-policies.7.rst b/Help/manual/cmake-policies.7.rst index 788d086..a7741f7 100644 --- a/Help/manual/cmake-policies.7.rst +++ b/Help/manual/cmake-policies.7.rst @@ -58,6 +58,7 @@ Policies Introduced by CMake 3.24 .. toctree:: :maxdepth: 1 + CMP0138: MSVC compilers use -ZI instead of /Zi for x86 and x64 by default. </policy/CMP0138> CMP0137: try_compile() passes platform variables in project mode. </policy/CMP0137> CMP0136: Watcom runtime library flags are selected by an abstraction. </policy/CMP0136> CMP0135: ExternalProject ignores timestamps in archives by default for the URL download method. </policy/CMP0135> diff --git a/Help/policy/CMP0138.rst b/Help/policy/CMP0138.rst new file mode 100644 index 0000000..5cf3948 --- /dev/null +++ b/Help/policy/CMP0138.rst @@ -0,0 +1,43 @@ +CMP0138 +------- + +.. versionadded:: 3.24 + +MSVC compilers use ``-ZI`` instead of ``/Zi`` for x86 and x64 by default. + +When using MSVC C/C++ compilers in CMake 3.23 and below, debug information +format flag ``/Zi`` is added to :variable:`CMAKE_<LANG>_FLAGS_DEBUG` and +:variable:`CMAKE_<LANG>_FLAGS_RELWITHDEBINFO` by default. The ``/Zi`` flag +produces a separate PDB file that contains all the symbolic debugging +information for use with the debugger, however, it does not support Edit +and Continue feature in a debugging session. + +CMake 3.24 and above adds ``-ZI`` to :variable:`CMAKE_<LANG>_FLAGS_DEBUG` +and :variable:`CMAKE_<LANG>_FLAGS_RELWITHDEBINFO` instead to enable Edit +and Continue by default. + +This policy provides compatibility with projects that have not been updated +to expect the lack of warning flags. The policy setting takes effect as of +the first :command:`project` or :command:`enable_language` command that +initializes :variable:`CMAKE_<LANG>_FLAGS_DEBUG` and +:variable:`CMAKE_<LANG>_FLAGS_RELWITHDEBINFO` for a given language +``<LANG>`` using MSVC compilers. + +.. note:: + + Once the policy has taken effect at the top of a project for a given + language, that choice must be used throughout the tree for that language. + In projects that have nested projects in subdirectories, be sure to + convert everything together. + +The ``OLD`` behavior for this policy is to place ``/Zi`` in the default +:variable:`CMAKE_<LANG>_FLAGS_DEBUG` and +:variable:`CMAKE_<LANG>_FLAGS_RELWITHDEBINFO` cache entries. The ``NEW`` +behavior for this policy is to place ``-ZI`` in the default cache entries. + +This policy was introduced in CMake version 3.24. Use the +:command:`cmake_policy` command to set it to ``OLD`` or ``NEW`` explicitly. +Unlike many policies, CMake version |release| does *not* warn +when this policy is not set and simply uses ``OLD`` behavior. + +.. include:: DEPRECATED.txt diff --git a/Help/release/dev/msvc-compilers-default-to-ZI.rst b/Help/release/dev/msvc-compilers-default-to-ZI.rst new file mode 100644 index 0000000..61ea877 --- /dev/null +++ b/Help/release/dev/msvc-compilers-default-to-ZI.rst @@ -0,0 +1,5 @@ +msvc-compilers-default-to-ZI +---------------------------- + +* With MSVC compilers, debug configurations now use ``-ZI`` by default + instead of ``/Zi``. See policy :policy:`CMP0138`. |