Ver Fonte

Merge topic 'doc-3.21-relnotes'

f119fbeec5 Help: Update Sphinx versionadded directives for 3.21 release
45acb61432 Help: Organize and revise 3.21 release notes
046aee0441 Help: Consolidate 3.21 release notes

Acked-by: Kitware Robot <[email protected]>
Merge-request: !6226
Brad King há 4 anos atrás
pai
commit
8850f6e23f
61 ficheiros alterados com 294 adições e 343 exclusões
  1. 291 0
      Help/release/3.21.rst
  2. 0 7
      Help/release/dev/ARMClang-cpu-arch-flags.rst
  3. 0 4
      Help/release/dev/FindDevIL-imported-targets.rst
  4. 0 4
      Help/release/dev/FindIconv-version.rst
  5. 0 4
      Help/release/dev/FindIntl-version.rst
  6. 0 6
      Help/release/dev/FindMsys.rst
  7. 0 5
      Help/release/dev/FindVulkan-add-Headers-glslangValidator-targets.rst
  8. 0 5
      Help/release/dev/UseJava-RESOURCES-NAMESPACE.rst
  9. 0 5
      Help/release/dev/UseSWIG-csharp.rst
  10. 0 6
      Help/release/dev/UseSWIG-dependencies.rst
  11. 0 5
      Help/release/dev/add_custom_command-DEPFILE-genex.rst
  12. 0 6
      Help/release/dev/add_custom_command-DEPFILE.rst
  13. 0 5
      Help/release/dev/add_custom_command-TARGET-genex.rst
  14. 0 6
      Help/release/dev/c-std.rst
  15. 0 6
      Help/release/dev/capabilties-generator-platforms.rst
  16. 0 8
      Help/release/dev/cmake-install-prefix-command.rst
  17. 0 4
      Help/release/dev/cmake-presets-condition.rst
  18. 0 5
      Help/release/dev/cmake-presets-host-system-name.rst
  19. 0 5
      Help/release/dev/cmake-presets-optional-generator-and-binarydir.rst
  20. 0 10
      Help/release/dev/cmake-system-name-version.rst
  21. 0 5
      Help/release/dev/cmake-toolchain-command.rst
  22. 0 7
      Help/release/dev/compile-options-order.rst
  23. 0 5
      Help/release/dev/cpack-dmg-filesystem.rst
  24. 0 6
      Help/release/dev/cpack-install-opts.rst
  25. 0 6
      Help/release/dev/cpack-nsis-executable-name.rst
  26. 0 5
      Help/release/dev/ctest-measurements-docs.rst
  27. 0 5
      Help/release/dev/ctest-output-junit.rst
  28. 0 8
      Help/release/dev/ctest-runtime-files.rst
  29. 0 4
      Help/release/dev/cxx-module-extensions.rst
  30. 0 6
      Help/release/dev/dir-IMPORTED_TARGETS.rst
  31. 0 5
      Help/release/dev/env-toolchain-file.rst
  32. 0 4
      Help/release/dev/file-COPY_FILE.rst
  33. 0 5
      Help/release/dev/file-REAL_PATH-EXPAND_TILDE.rst
  34. 0 6
      Help/release/dev/file-RENAME.rst
  35. 0 10
      Help/release/dev/fileapi-codemodel-directory.rst
  36. 0 6
      Help/release/dev/find_item-NO_CACHE.rst
  37. 0 6
      Help/release/dev/find_item-consistent-behavior.rst
  38. 0 5
      Help/release/dev/foreach-variable-scope.rst
  39. 0 11
      Help/release/dev/fujitsu-compiler-support.rst
  40. 0 6
      Help/release/dev/generate-cmake-build-command-parallel.rst
  41. 0 5
      Help/release/dev/get-runtime-dependencies-file-filter.rst
  42. 0 5
      Help/release/dev/hip.rst
  43. 0 7
      Help/release/dev/ifw-default-version-operator.rst
  44. 0 5
      Help/release/dev/install-imported-runtime-artifacts.rst
  45. 0 9
      Help/release/dev/install-runtime-dependencies.rst
  46. 0 7
      Help/release/dev/install-script-all-components.rst
  47. 0 8
      Help/release/dev/link-objects-first.rst
  48. 0 7
      Help/release/dev/linker-launcher.rst
  49. 0 7
      Help/release/dev/list-index-arg-parsing.rst
  50. 0 7
      Help/release/dev/lzma-threads.rst
  51. 0 4
      Help/release/dev/message-color.rst
  52. 0 4
      Help/release/dev/msys.rst
  53. 0 6
      Help/release/dev/ninja-absolute-paths.rst
  54. 0 5
      Help/release/dev/nmake-utf8.rst
  55. 0 4
      Help/release/dev/objc-std-17-23.rst
  56. 0 6
      Help/release/dev/project-is-top-level.rst
  57. 0 4
      Help/release/dev/runtime-dll-deps.rst
  58. 0 5
      Help/release/dev/set-cache-variable.rst
  59. 0 11
      Help/release/dev/xcode_app_extensions.rst
  60. 1 0
      Help/release/index.rst
  61. 2 0
      Help/variable/CPACK_CUSTOM_INSTALL_VARIABLES.rst

+ 291 - 0
Help/release/3.21.rst

@@ -0,0 +1,291 @@
+CMake 3.21 Release Notes
+************************
+
+.. only:: html
+
+  .. contents::
+
+Changes made since CMake 3.20 include the following.
+
+New Features
+============
+
+Presets
+-------
+
+* :manual:`cmake-presets(7)` gained support for specifying the install prefix
+  in a configure preset.
+
+* :manual:`cmake-presets(7)` gained support for conditional enabling of presets.
+
+* :manual:`cmake-presets(7)` gained support for a ``${hostSystemName}`` macro.
+
+* :manual:`cmake-presets(7)` gained support for omitting the ``generator`` and
+  ``binaryDir`` fields.
+
+Generators
+----------
+
+* The :ref:`Makefile Generators` and the :generator:`Ninja` generator
+  learned to add linker launcher tools along with the linker for ``C``,
+  ``CXX``, ``OBJC``, and ``OBJCXX`` languages.
+  See the :variable:`CMAKE_<LANG>_LINKER_LAUNCHER` variable
+  and :prop_tgt:`<LANG>_LINKER_LAUNCHER` target property for details.
+
+Languages
+---------
+
+* CMake learned to support ``HIP`` as a first-class language that can be
+  enabled via the :command:`project` and :command:`enable_language` commands.
+
+* :prop_tgt:`C_STANDARD`, :prop_tgt:`OBJC_STANDARD`, and the
+  :manual:`Compile Features <cmake-compile-features(7)>` functionality gained
+  support for C17 and C23.
+
+* Source file extensions ``.ixx`` and ``.cppm`` are now treated as C++.
+
+Command-Line
+------------
+
+* :manual:`cmake(1)` gained the ``--install-prefix <dir>``
+  command-line option to specify the location of the install prefix.
+
+* :manual:`cmake(1)` gained the ``--toolchain <path/to/file>``
+  command-line option to specify a toolchain file.
+
+* :manual:`cmake(1)` ``-E capabilities`` output now contains for each
+  generator a ``supportedPlatforms`` field listing platforms known to
+  be supported in :variable:`CMAKE_GENERATOR_PLATFORM`.
+
+* Messages printed to a terminal now may be colored by message type.
+
+Compilers
+---------
+
+* The Fujitsu compiler is now supported using compiler id ``Fujitsu``
+  in traditional (``Trad``) mode, and compiler id ``FujitsuClang``
+  in ``Clang`` mode.
+
+Platforms
+---------
+
+* CMake now supports the MSYS runtime environment, much like CYGWIN.
+
+File-Based API
+--------------
+
+* The :manual:`cmake-file-api(7)` "codemodel" version 2 ``version`` field
+  has been updated to 2.3.
+
+* The :manual:`cmake-file-api(7)` "codemodel" version 2 gained a
+  new "directory" object containing directory-level information.
+  This includes a list of installers generated by the :command:`install`
+  command.
+
+Commands
+--------
+
+* The :command:`add_custom_command` command ``DEPFILE`` option:
+
+  * may now use
+    :manual:`generator expressions <cmake-generator-expressions(7)>`,
+
+  * is now supported by :ref:`Visual Studio Generators` for VS 2012
+    and above, and
+
+  * is now supported by the :generator:`Xcode` generator.
+
+* The :command:`add_custom_command(TARGET)` command
+  (for :ref:`Build Events <add_custom_command(TARGET)>`)
+  gained support for resolving target-dependent generator expressions.
+
+* The :command:`build_command` command gained a ``PARALLEL_LEVEL`` option.
+
+* The :command:`file(COPY_FILE)` command was added to copy a single file.
+
+* The :command:`file(GET_RUNTIME_DEPENDENCIES)` command gained new
+  ``POST_INCLUDE_FILES`` and ``POST_EXCLUDE_FILES`` arguments.
+
+* The :command:`file(REAL_PATH)` command gained the option ``EXPAND_TILDE`` to
+  replace any leading tilde with the path to the user's home directory.
+
+* The :command:`file(RENAME)` command learned to optionally capture
+  failure in a result variable.  It also gained a ``NO_REPLACE``
+  option to fail if the destination exists.
+
+* The :command:`install` command gained a new ``IMPORTED_RUNTIME_ARTIFACTS``
+  mode, which can be used to install the runtime artifacts of imported targets.
+
+* The :command:`install` command gained a new ``RUNTIME_DEPENDENCY_SET`` mode,
+  which can be used to install runtime dependencies using
+  :command:`file(GET_RUNTIME_DEPENDENCIES)`.
+
+* The :command:`install(TARGETS)` command gained new ``RUNTIME_DEPENDENCIES``
+  and ``RUNTIME_DEPENDENCY_SET`` arguments, which can be used to install
+  runtime dependencies using :command:`file(GET_RUNTIME_DEPENDENCIES)`.
+
+* The :command:`install(SCRIPT|CODE)` command
+  supports a new option ``ALL_COMPONENTS`` which allows
+  the corresponding code to run for every component of
+  a per component installation.
+
+* The :command:`project` command now sets variables
+  :variable:`PROJECT_IS_TOP_LEVEL` and :variable:`<PROJECT-NAME>_IS_TOP_LEVEL`
+  to indicate whether it was called in a top-level ``CMakeLists.txt`` file.
+
+Variables
+---------
+
+* The :envvar:`CMAKE_TOOLCHAIN_FILE` environment variable was added to
+  provide a default value for the :variable:`CMAKE_TOOLCHAIN_FILE` variable.
+
+Properties
+----------
+
+* The :prop_dir:`IMPORTED_TARGETS` directory property was added to
+  get a list of :ref:`Imported Targets` created in the current
+  directory.
+
+* The :prop_tgt:`XCODE_EMBED_APP_EXTENSIONS <XCODE_EMBED_<type>>` target property
+  was added to tell the :generator:`Xcode` generator to embed app extensions
+  such as iMessage sticker packs.
+  Aspects of the embedding can be customized with the
+  :prop_tgt:`XCODE_EMBED_APP_EXTENSIONS_PATH <XCODE_EMBED_<type>>`,
+  :prop_tgt:`XCODE_EMBED_APP_EXTENSIONS_CODE_SIGN_ON_COPY <XCODE_EMBED_<type>_CODE_SIGN_ON_COPY>` and
+  :prop_tgt:`XCODE_EMBED_APP_EXTENSIONS_REMOVE_HEADERS_ON_COPY <XCODE_EMBED_<type>_REMOVE_HEADERS_ON_COPY>`
+  properties.
+
+Modules
+-------
+
+* The :module:`FindBLAS` and :module:`FindLAPACK` modules learned to support
+  the serial ``Fujitsu_SSL2`` and parallel ``Fujitsu_SSL2BLAMP`` libraries.
+
+* The :module:`FindDevIL` module now provides imported targets.
+
+* The :module:`FindIconv` module now has version support.
+
+* The :module:`FindIntl` module now has version support.
+
+* The :module:`FindMPI` module learned to support ``Fujitsu`` and
+  ``FujitsuClang`` in both host and cross compiling modes.
+
+* The :module:`FindMsys` module was added to find MSYS installations.
+  Like :module:`FindCygwin`, it is used automatically by some other
+  find modules to locate UNIX-style tools on Windows.
+
+* The :module:`FindOpenMP` module learned to support ``Fujitsu`` and
+  ``FujitsuClang``.
+
+* The :module:`FindVulkan` module gained imported targets
+  ``Vulkan::Headers`` and ``Vulkan::glslangValidator``.
+
+* The :module:`UseJava` module command ``add_jar`` gained a ``RESOURCES``
+  option to allow explicit naming of resources with non-optional namespace.
+
+* The :module:`UseSWIG` module use now standard library naming conventions
+  for the ``CSharp`` language. See policy :policy:`CMP0122`.
+
+* The :module:`UseSWIG` module now supports using the ``swig`` tool to
+  generate implicit dependencies with the :generator:`Xcode` generator.
+
+Generator Expressions
+---------------------
+
+* A new :genex:`TARGET_RUNTIME_DLLS` generator expression was added.
+
+CTest
+-----
+
+* :manual:`ctest(1)` gained documentation for its ability to capture
+  :ref:`Additional Test Measurements`.
+
+* :manual:`ctest(1)` learned to recognize files attached to a test at run time.
+  Previously it was only possible to attach files to tests at configure time
+  by using the :prop_test:`ATTACHED_FILES` or
+  :prop_test:`ATTACHED_FILES_ON_FAIL` test properties.
+  See :ref:`Additional Test Measurements` for more information.
+
+* :manual:`ctest(1)` gained a ``--output-junit`` option to write test results
+  to a JUnit XML file.
+
+* The :command:`ctest_build` command gained a ``PARALLEL_LEVEL`` option.
+
+CPack
+-----
+
+* The :cpack_gen:`CPack DragNDrop Generator` gained option
+  :variable:`CPACK_DMG_FILESYSTEM` to control the ``.dmg`` filesystem.
+
+* The :cpack_gen:`CPack IFW Generator` now supports hyphens in names
+  given to :command:`cpack_ifw_configure_component` or
+  :command:`cpack_ifw_configure_component_group` as ``DEPENDS`` or
+  ``DEPENDENCIES`` arguments.  This requires QtIFW 3.1 or later.
+
+* The :cpack_gen:`CPack NSIS Generator` gained a new
+  :variable:`CPACK_NSIS_EXECUTABLE` variable to specify the ``makensis``
+  executable to use instead of the default one.
+
+* The :variable:`CPACK_CUSTOM_INSTALL_VARIABLES` variable was added to set
+  variables in ``cmake_install.cmake`` script invocations made by CPack.
+
+Deprecated and Removed Features
+===============================
+
+* Undocumented :variable:`CMAKE_SYSTEM_NAME` version-stripping behavior has
+  been removed entirely. If it is set by a ``-D`` flag or by a
+  :manual:`toolchain file <cmake-toolchains(7)>`, it is left unaltered,
+  even if it still contains a version number.
+  Similar :variable:`CMAKE_HOST_SYSTEM_NAME` version-stripping behavior,
+  also undocumented, has been moved earlier, before :command:`project` or
+  :command:`enable_language` is called.
+
+* ``ARMClang`` cpu/arch compile and link flags are no longer added
+  automatically based on the :variable:`CMAKE_SYSTEM_PROCESSOR`
+  variable or the undocumented ``CMAKE_SYSTEM_ARCH`` variable.
+  They must be specified explicitly.  See policy :policy:`CMP0123`.
+
+Other Changes
+=============
+
+* The :command:`find_file`, :command:`find_path`, :command:`find_program`,
+  and :command:`find_library` commands handle cache variables in the same way
+  regardless how they are defined. See policy :policy:`CMP0125` for details.
+
+* The :command:`find_file`, :command:`find_path`, :command:`find_program`,
+  and :command:`find_library` commands gained the option ``NO_CACHE`` to store
+  find result in normal variable.
+
+* The :command:`foreach` command now isolates loop variables in the loop scope.
+  See policy :policy:`CMP0124` for details.
+
+* The :command:`list` command's ``GET``, ``INSERT``, ``SUBLIST``, and
+  ``REMOVE_AT`` subcommands now error with invalid (i.e., non-integer) values
+  are given as any of their index arguments based on the setting of policy
+  :policy:`CMP0121`.
+
+* The :command:`set(CACHE)` command no longer removes a normal variable
+  of the same name, if any. See policy :policy:`CMP0126`.
+
+* :command:`target_link_libraries` calls referencing object libraries
+  via the :genex:`TARGET_OBJECTS` generator expression now place the
+  object files before all libraries on the link line, regardless of
+  their specified order.  See documentation on
+  :ref:`Linking Object Libraries via \$\<TARGET_OBJECTS\>` for details.
+
+* The :ref:`Ninja Generators` now pass source files and include directories
+  to the compiler using absolute paths.  This makes diagnostic messages and
+  debug symbols more consistent, and matches the :ref:`Makefile Generators`.
+
+* The :generator:`NMake Makefiles` generator now encodes the generated
+  makefiles as UTF-8 with a BOM when using ``nmake`` from VS 9 or above.
+
+* The :ref:`Visual Studio Generators` for VS 2010 and above now place
+  per-source preprocessor definitions after target-wide preprocssor
+  definitions.  This makes VS consistent with the :ref:`Ninja Generators`
+  and the :ref:`Makefile Generators`.
+
+* The precompiled binaries provided on
+  `cmake.org <https://cmake.org/download/>`_ now support
+  ``liblzma`` multi-threading.  See the :variable:`CPACK_THREADS` and
+  :variable:`CPACK_ARCHIVE_THREADS` variables.

+ 0 - 7
Help/release/dev/ARMClang-cpu-arch-flags.rst

@@ -1,7 +0,0 @@
-ARMClang-cpu-arch-flags
------------------------
-
-* ``ARMClang`` cpu/arch compile and link flags are no longer added
-  automatically based on the :variable:`CMAKE_SYSTEM_PROCESSOR`
-  variable or the undocumented ``CMAKE_SYSTEM_ARCH`` variable.
-  They must be specified explicitly.  See policy :policy:`CMP0123`.

+ 0 - 4
Help/release/dev/FindDevIL-imported-targets.rst

@@ -1,4 +0,0 @@
-FindDevIL
----------
-
-* The :module:`FindDevIL` module now provides imported targets.

+ 0 - 4
Help/release/dev/FindIconv-version.rst

@@ -1,4 +0,0 @@
-FindIconv-version
------------------
-
-* The :module:`FindIconv` module now has version support.

+ 0 - 4
Help/release/dev/FindIntl-version.rst

@@ -1,4 +0,0 @@
-FindIntl-version
-----------------
-
-* The :module:`FindIntl` module now has version support.

+ 0 - 6
Help/release/dev/FindMsys.rst

@@ -1,6 +0,0 @@
-FindMsys
---------
-
-* The :module:`FindMsys` module was added to find MSYS installations.
-  Like :module:`FindCygwin`, it is used automatically by some other
-  find modules to locate UNIX-style tools on Windows.

+ 0 - 5
Help/release/dev/FindVulkan-add-Headers-glslangValidator-targets.rst

@@ -1,5 +0,0 @@
-FindVulkan-add-Headers-glslangValidator-targets
------------------------------------------------
-
-* The :module:`FindVulkan` module gained imported targets
-  ``Vulkan::Headers`` and ``Vulkan::glslangValidator``.

+ 0 - 5
Help/release/dev/UseJava-RESOURCES-NAMESPACE.rst

@@ -1,5 +0,0 @@
-UseJava-RESOURCES-NAMESPACE
----------------------------
-
-* The :module:`UseJava` module command ``add_jar`` gained option RESOURCES
-  allow explicit naming of resources with non-optional namespace.

+ 0 - 5
Help/release/dev/UseSWIG-csharp.rst

@@ -1,5 +0,0 @@
-UseSWIG-csharp
---------------
-
-* The :module:`UseSWIG` module use now standard library name conventions for
-  ``CSharp`` language. See policy :policy:`CMP0122`.

+ 0 - 6
Help/release/dev/UseSWIG-dependencies.rst

@@ -1,6 +0,0 @@
-UseSWIG-dependencies
---------------------
-
-* :module:`UseSWIG` module gained the capability, for
-  :generator:`Xcode` generator, to use `swig` tool to generate implicit
-  dependencies.

+ 0 - 5
Help/release/dev/add_custom_command-DEPFILE-genex.rst

@@ -1,5 +0,0 @@
-add_custom_command-DEPFILE-genex
---------------------------------
-
-* The :command:`add_custom_command` command ``DEPFILE`` option learned to
-  support :manual:`generator expressions <cmake-generator-expressions(7)>`.

+ 0 - 6
Help/release/dev/add_custom_command-DEPFILE.rst

@@ -1,6 +0,0 @@
-add_custom_command-DEPFILE
---------------------------
-
-* The :command:`add_custom_command` command gained ``DEPFILE`` support on
-  the :generator:`Xcode` generator, and on :ref:`Visual Studio Generators`
-  for VS 2012 and above.

+ 0 - 5
Help/release/dev/add_custom_command-TARGET-genex.rst

@@ -1,5 +0,0 @@
-add_custom_command-TARGET-genex
--------------------------------
-
-* The :ref:`add_custom_command(TARGET) <add_custom_command(TARGET)>` command
-  gained support for resolving target-dependent generator expressions.

+ 0 - 6
Help/release/dev/c-std.rst

@@ -1,6 +0,0 @@
-c-std
------
-
-* :prop_tgt:`C_STANDARD` and the
-  :manual:`Compile Features <cmake-compile-features(7)>` functionality gained
-  support for C17 and C23.

+ 0 - 6
Help/release/dev/capabilties-generator-platforms.rst

@@ -1,6 +0,0 @@
-capabilties-generator-platforms
--------------------------------
-
-* The :manual:`cmake(1)` ``-E capabilities`` output now contains for each
-  generator a ``supportedPlatforms`` field listing platform known to
-  be supported in :variable:`CMAKE_GENERATOR_PLATFORM`.

+ 0 - 8
Help/release/dev/cmake-install-prefix-command.rst

@@ -1,8 +0,0 @@
-cmake-install-prefix-command
-----------------------------
-
-* The :manual:`cmake(1)` command gained the ``--install-prefix <dir>``
-  command line option to specify the location of the install prefix.
-
-* :manual:`cmake-presets(7)` configure preset gained support for specifying
-  the install prefix.

+ 0 - 4
Help/release/dev/cmake-presets-condition.rst

@@ -1,4 +0,0 @@
-cmake-presets-condition
------------------------
-
-* :manual:`cmake-presets(7)` now support conditional enabling of presets.

+ 0 - 5
Help/release/dev/cmake-presets-host-system-name.rst

@@ -1,5 +0,0 @@
-cmake-presets-host-system-name
-------------------------------
-
-* :manual:`cmake-presets(7)` gained support for a new ``${hostSystemName}``
-  macro.

+ 0 - 5
Help/release/dev/cmake-presets-optional-generator-and-binarydir.rst

@@ -1,5 +0,0 @@
-cmake-presets-optional-generator-and-binarydir
-----------------------------------------------
-
-* :manual:`cmake-presets(7)` now support omitting the ``generator`` and
-  ``binaryDir`` fields.

+ 0 - 10
Help/release/dev/cmake-system-name-version.rst

@@ -1,10 +0,0 @@
-cmake-system-name-version
--------------------------
-
-* :variable:`CMAKE_HOST_SYSTEM_NAME`'s undocumented version-stripping behavior
-  has been moved earlier, before :command:`project` or
-  :command:`enable_language` is called.
-* :variable:`CMAKE_SYSTEM_NAME`'s undocumented version-stripping behavior has
-  been removed entirely. If it is set by a ``-D`` flag or by a
-  :manual:`toolchain file <cmake-toolchains(7)>`, it is left unaltered, even if
-  it still contains a version number.

+ 0 - 5
Help/release/dev/cmake-toolchain-command.rst

@@ -1,5 +0,0 @@
-cmake-toolchain-command
-----------------------------
-
-* The :manual:`cmake(1)` command gained the ``--toolchain <path/to/file>``
-  command line option to specify a toolchain file.

+ 0 - 7
Help/release/dev/compile-options-order.rst

@@ -1,7 +0,0 @@
-compile-options-order
----------------------
-
-* The :ref:`Visual Studio Generators` for VS 2010 and above now place
-  per-source preprocessor definitions after target-wide preprocssor
-  definitions.  This makes VS consistent with the :ref:`Ninja Generators`
-  and the :ref:`Makefile Generators`.

+ 0 - 5
Help/release/dev/cpack-dmg-filesystem.rst

@@ -1,5 +0,0 @@
-cpack-dmg-filesystem
---------------------
-
-* The :cpack_gen:`CPack DragNDrop Generator` gained option
-  :variable:`CPACK_DMG_FILESYSTEM` to control the ``.dmg`` filesystem.

+ 0 - 6
Help/release/dev/cpack-install-opts.rst

@@ -1,6 +0,0 @@
-cpack-install-opts
-------------------
-
-* The new :variable:`CPACK_CUSTOM_INSTALL_VARIABLES`
-  can be used to set variables in CPack ``cmake_install.cmake``
-  invocations.

+ 0 - 6
Help/release/dev/cpack-nsis-executable-name.rst

@@ -1,6 +0,0 @@
-cpack-nsis-executable-name
---------------------------
-
-* The :cpack_gen:`CPack NSIS Generator` gained a new variable
-  :variable:`CPACK_NSIS_EXECUTABLE` to specify the makensis
-  executable to use instead of the default one.

+ 0 - 5
Help/release/dev/ctest-measurements-docs.rst

@@ -1,5 +0,0 @@
-ctest-measurements-docs
------------------------
-
-* :manual:`ctest(1)` gained documentation for its ability to capture
-  :ref:`Additional Test Measurements`.

+ 0 - 5
Help/release/dev/ctest-output-junit.rst

@@ -1,5 +0,0 @@
-ctest-output-junit
-------------------
-
-* :manual:`ctest(1)` gained a ``--output-junit`` option to write test results
-  to a JUnit XML file.

+ 0 - 8
Help/release/dev/ctest-runtime-files.rst

@@ -1,8 +0,0 @@
-ctest-runtime-files
--------------------
-
-* :manual:`ctest(1)` learned to recognize files attached to a test at run time.
-  Previously it was only possible to attach files to tests at configure time
-  by using the :prop_test:`ATTACHED_FILES` or
-  :prop_test:`ATTACHED_FILES_ON_FAIL` test properties.
-  See :ref:`Additional Test Measurements` for more information.

+ 0 - 4
Help/release/dev/cxx-module-extensions.rst

@@ -1,4 +0,0 @@
-cxx-module-extensions
----------------------
-
-* Source file extensions ``.ixx`` and ``.cppm`` are now treated as C++.

+ 0 - 6
Help/release/dev/dir-IMPORTED_TARGETS.rst

@@ -1,6 +0,0 @@
-dir-IMPORTED_TARGETS
---------------------
-
-* The :prop_dir:`IMPORTED_TARGETS` directory property was added to
-  get a list of :ref:`Imported Targets` created in the current
-  directory.

+ 0 - 5
Help/release/dev/env-toolchain-file.rst

@@ -1,5 +0,0 @@
-env-toolchain-file
-------------------
-
-* The :envvar:`CMAKE_TOOLCHAIN_FILE` environment variable was added to
-  provide a default value for the :variable:`CMAKE_TOOLCHAIN_FILE` variable.

+ 0 - 4
Help/release/dev/file-COPY_FILE.rst

@@ -1,4 +0,0 @@
-file-COPY_ONLY
---------------
-
-* The :command:`file(COPY_FILE)` command was added to copy a file to another.

+ 0 - 5
Help/release/dev/file-REAL_PATH-EXPAND_TILDE.rst

@@ -1,5 +0,0 @@
-file-REAL_PATH-EXPAND_TILDE
----------------------------
-
-* The :command:`file(REAL_PATH)` command gained the option ``EXPAND_TILDE`` to
-  replace any leading tilde with the path to the user's home directory.

+ 0 - 6
Help/release/dev/file-RENAME.rst

@@ -1,6 +0,0 @@
-file-RENAME
------------
-
-* The :command:`file(RENAME)` command learned to optionally capture
-  failure in a result variable.  It also gained a ``NO_REPLACE``
-  option to fail if the destination exists.

+ 0 - 10
Help/release/dev/fileapi-codemodel-directory.rst

@@ -1,10 +0,0 @@
-fileapi-codemodel-directory
----------------------------
-
-* The :manual:`cmake-file-api(7)` "codemodel" version 2 ``version`` field has
-  component been updated to 2.3.
-
-* The :manual:`cmake-file-api(7)` "codemodel" version 2 gained a
-  new "directory" object containing directory-level information.
-  This includes a list of installers generated by the :command:`install`
-  command.

+ 0 - 6
Help/release/dev/find_item-NO_CACHE.rst

@@ -1,6 +0,0 @@
-find_item-NO_CACHE
-------------------
-
-* The :command:`find_file`, :command:`find_path`, :command:`find_program`,
-  and :command:`find_library` commands gained the option ``NO_CACHE`` to store
-  find result in normal variable.

+ 0 - 6
Help/release/dev/find_item-consistent-behavior.rst

@@ -1,6 +0,0 @@
-find_item-consistent-behavior
------------------------------
-
-* The :command:`find_file`, :command:`find_path`, :command:`find_program`,
-  and :command:`find_library` commands handle cache variables in the same way
-  regardless how they are defined. See policy :policy:`CMP0125` for details.

+ 0 - 5
Help/release/dev/foreach-variable-scope.rst

@@ -1,5 +0,0 @@
-foreach-variable-scope
-----------------------
-
-* The :command:`foreach` command restrict loop variables to the loop scope.
-  See policy :policy:`CMP0124` for details.

+ 0 - 11
Help/release/dev/fujitsu-compiler-support.rst

@@ -1,11 +0,0 @@
-fujitsu-compiler-support
-------------------------
-
-* Addition of the ``Fujitsu`` compiler ID operating in traditional ``Trad``
-  mode and ``FujitsuClang`` operating in ``Clang`` mode.
-* The :module:`FindOpenMP` module learned to support ``Fujitsu`` and
-  ``FujitsuClang``.
-* The :module:`FindMPI` module learned to support ``Fujitsu`` and
-  ``FujitsuClang`` in both host and cross compiling modes.
-* The :module:`FindBLAS` and :module:`FindLAPACK` modules learned to support
-  the serial ``Fujitsu SSL2`` and parallel ``Fujitsu SSL2BLAMP`` libraries.

+ 0 - 6
Help/release/dev/generate-cmake-build-command-parallel.rst

@@ -1,6 +0,0 @@
-generate-cmake-build-command-parallel
--------------------------------------
-
-* The :command:`build_command` command gained a ``PARALLEL_LEVEL`` option.
-
-* The :command:`ctest_build` command gained a ``PARALLEL_LEVEL`` option.

+ 0 - 5
Help/release/dev/get-runtime-dependencies-file-filter.rst

@@ -1,5 +0,0 @@
-get-runtime-dependencies-file-filter
-------------------------------------
-
-* The :command:`file(GET_RUNTIME_DEPENDENCIES)` command gained new
-  ``POST_INCLUDE_FILES`` and ``POST_EXCLUDE_FILES`` arguments.

+ 0 - 5
Help/release/dev/hip.rst

@@ -1,5 +0,0 @@
-hip
----
-
-* CMake learned to support ``HIP`` as a first-class language that can be
-  enabled via the :command:`project` and :command:`enable_language` commands.

+ 0 - 7
Help/release/dev/ifw-default-version-operator.rst

@@ -1,7 +0,0 @@
-ifw-default-version-operator
-----------------------------
-
-* Names given as ``DEPENDS`` or ``DEPENDENCIES`` arguments to
-  :command:`cpack_ifw_configure_component` or
-  :command:`cpack_ifw_configure_component_group` may now contain hyphens.
-  This requires QtIFW 3.1 or later.

+ 0 - 5
Help/release/dev/install-imported-runtime-artifacts.rst

@@ -1,5 +0,0 @@
-install-imported-runtime-artifacts
-----------------------------------
-
-* The :command:`install` command gained a new ``IMPORTED_RUNTIME_ARTIFACTS``
-  mode, which can be used to install the runtime artifacts of imported targets.

+ 0 - 9
Help/release/dev/install-runtime-dependencies.rst

@@ -1,9 +0,0 @@
-install-runtime-dependencies
-----------------------------
-
-* The :command:`install(TARGETS)` command gained new ``RUNTIME_DEPENDENCIES``
-  and ``RUNTIME_DEPENDENCY_SET`` arguments, which can be used to install
-  runtime dependencies using :command:`file(GET_RUNTIME_DEPENDENCIES)`.
-* The :command:`install` command gained a new ``RUNTIME_DEPENDENCY_SET`` mode,
-  which can be used to install runtime dependencies using
-  :command:`file(GET_RUNTIME_DEPENDENCIES)`.

+ 0 - 7
Help/release/dev/install-script-all-components.rst

@@ -1,7 +0,0 @@
-install-script-all-components
------------------------------
-
-* The :command:`install(SCRIPT|CODE)` command
-  supports a new option ``ALL_COMPONENTS`` which allows
-  the corresponding code to run for every component of
-  a per component installation.

+ 0 - 8
Help/release/dev/link-objects-first.rst

@@ -1,8 +0,0 @@
-link-objects-first
-------------------
-
-* :command:`target_link_libraries` calls referencing object libraries
-  via the :genex:`TARGET_OBJECTS` generator expression now place the
-  object files before all libraries on the link line, regardless of
-  their specified order.  See documentation on
-  :ref:`Linking Object Libraries via \$\<TARGET_OBJECTS\>` for details.

+ 0 - 7
Help/release/dev/linker-launcher.rst

@@ -1,7 +0,0 @@
-linker-launcher
----------------
-
-* The :ref:`Makefile Generators` and the :generator:`Ninja` generator learned to
-  add linker launcher tools along with the linker for ``C``, ``CXX``, ``OBJC``, and
-  ``OBJCXX`` languages. See the :variable:`CMAKE_<LANG>_LINKER_LAUNCHER` variable
-  and :prop_tgt:`<LANG>_LINKER_LAUNCHER` target property for details.

+ 0 - 7
Help/release/dev/list-index-arg-parsing.rst

@@ -1,7 +0,0 @@
-list-index-arg-parsing
-----------------------
-
-* The :command:`list` command's ``GET``, ``INSERT``, ``SUBLIST``, and
-  ``REMOVE_AT`` subcommands now error with invalid (i.e., non-integer) values
-  are given as any of their index arguments based on the setting of policy
-  :policy:`CMP0121`.

+ 0 - 7
Help/release/dev/lzma-threads.rst

@@ -1,7 +0,0 @@
-lzma-threads
-------------
-
-* The precompiled binaries provided on
-  `cmake.org <https://cmake.org/download/>`_ now support
-  ``liblzma`` multi-threading.  See the :variable:`CPACK_THREADS` and
-  :variable:`CPACK_ARCHIVE_THREADS` variables.

+ 0 - 4
Help/release/dev/message-color.rst

@@ -1,4 +0,0 @@
-message-color
--------------
-
-* Messages printed to a terminal now may be colored by message type.

+ 0 - 4
Help/release/dev/msys.rst

@@ -1,4 +0,0 @@
-msys
-----
-
-* CMake now supports the MSYS runtime environment, much like CYGWIN.

+ 0 - 6
Help/release/dev/ninja-absolute-paths.rst

@@ -1,6 +0,0 @@
-ninja-absolute-paths
---------------------
-
-* The :ref:`Ninja Generators` now pass source files and include directories
-  to the compiler using absolute paths.  This makes diagnostic messages and
-  debug symbols more consistent, and matches the :ref:`Makefile Generators`.

+ 0 - 5
Help/release/dev/nmake-utf8.rst

@@ -1,5 +0,0 @@
-nmake-utf8
-----------
-
-* The :generator:`NMake Makefiles` generator now encodes the generated
-  makefiles as UTF-8 with a BOM when using ``nmake`` from VS 9 or above.

+ 0 - 4
Help/release/dev/objc-std-17-23.rst

@@ -1,4 +0,0 @@
-objc-std-17-23
---------------
-
-* :prop_tgt:`OBJC_STANDARD` gained support for C17 and C23.

+ 0 - 6
Help/release/dev/project-is-top-level.rst

@@ -1,6 +0,0 @@
-project-is-top-level
---------------------
-
-* :command:`project` now sets variables :variable:`PROJECT_IS_TOP_LEVEL` and
-  :variable:`<PROJECT-NAME>_IS_TOP_LEVEL` to indicate whether it was called
-  in a top level ``CMakeLists.txt`` file.

+ 0 - 4
Help/release/dev/runtime-dll-deps.rst

@@ -1,4 +0,0 @@
-runtime-dll-deps
-----------------
-
-* A new :genex:`TARGET_RUNTIME_DLLS` generator expression was added.

+ 0 - 5
Help/release/dev/set-cache-variable.rst

@@ -1,5 +0,0 @@
-set-cache-variable
-------------------
-
-* The :command:`set(CACHE)` command no longer removes a normal variable of the
-  same name, if any. See policy :policy:`CMP0126`.

+ 0 - 11
Help/release/dev/xcode_app_extensions.rst

@@ -1,11 +0,0 @@
-xcode_app_extensions
---------------------
-
-* The :prop_tgt:`XCODE_EMBED_APP_EXTENSIONS <XCODE_EMBED_<type>>` target property
-  was added to tell the :generator:`Xcode` generator to embed app extensions
-  such as iMessage sticker packs.
-  Aspects of the embedding can be customized with the
-  :prop_tgt:`XCODE_EMBED_APP_EXTENSIONS_PATH <XCODE_EMBED_<type>>`,
-  :prop_tgt:`XCODE_EMBED_APP_EXTENSIONS_CODE_SIGN_ON_COPY <XCODE_EMBED_<type>_CODE_SIGN_ON_COPY>` and
-  :prop_tgt:`XCODE_EMBED_APP_EXTENSIONS_REMOVE_HEADERS_ON_COPY <XCODE_EMBED_<type>_REMOVE_HEADERS_ON_COPY>`
-  properties.

+ 1 - 0
Help/release/index.rst

@@ -15,6 +15,7 @@ Releases
 .. toctree::
    :maxdepth: 1
 
+   3.21 <3.21>
    3.20 <3.20>
    3.19 <3.19>
    3.18 <3.18>

+ 2 - 0
Help/variable/CPACK_CUSTOM_INSTALL_VARIABLES.rst

@@ -1,6 +1,8 @@
 CPACK_CUSTOM_INSTALL_VARIABLES
 ------------------------------
 
+.. versionadded:: 3.21
+
 CPack variables (set via e.g. ``cpack -D``, ``CPackConfig.cmake`` or
 :variable:`CPACK_PROJECT_CONFIG_FILE` scripts) are not directly visible in
 installation scripts.  Instead, one can pass a list of ``varName=value``