From 9c9a6e6023013ababfcc59ca9931c78c0512df1c Mon Sep 17 00:00:00 2001 From: Brad King Date: Fri, 4 Oct 2019 11:00:00 -0400 Subject: Help: Consolidate 3.16 release notes Run the `Utilities/Release/consolidate-relnotes.bash` script to move notes from `Help/release/dev/*` into `Help/release/3.16.rst`. --- Help/release/3.16.rst | 219 +++++++++++++++++++++ Help/release/dev/CMP0095.rst | 5 - Help/release/dev/FPHSA-reason-failure-message.rst | 5 - Help/release/dev/FindGnuTLS-target.rst | 4 - Help/release/dev/FindPkgConfig-module-name.rst | 6 - Help/release/dev/FindPython-FIND_ABI.rst | 5 - Help/release/dev/FindPython-specify_artifacts.rst | 5 - .../dev/add-install-remove-environment-rpath.rst | 6 - .../dev/add_cmake_find_use_package_registry.rst | 11 -- .../add_skip_regular_expression_test_property.rst | 10 - Help/release/dev/add_test-expand_lists.rst | 6 - Help/release/dev/aix.rst | 20 -- Help/release/dev/automoc_path_prefix.rst | 13 -- Help/release/dev/build-install-rpath-genex.rst | 5 - Help/release/dev/cmake-e-true-false.rst | 5 - Help/release/dev/cmake-initial-cache-dirs.rst | 6 - .../dev/cmake-qch-no-version-in-filename.rst | 8 - .../dev/cpack-install-multiple-configurations.rst | 5 - Help/release/dev/cpack-install-scripts.rst | 5 - Help/release/dev/cpack-zstd.rst | 5 - ...build-makeprogram-propagated-configure-pass.rst | 6 - Help/release/dev/ctest-hardware-allocation.rst | 6 - .../dev/cuda-CMAKE_CUDA_RESOLVE_DEVICE_SYMBOLS.rst | 6 - Help/release/dev/deprecate-policy-old.rst | 8 - .../dev/doxygen-add-docs-USE_STAMP_FILE.rst | 7 - Help/release/dev/eclipse-resource-encoding.rst | 6 - .../external-project-support-no-git-submodules.rst | 6 - Help/release/dev/get-runtime-dependencies.rst | 9 - .../dev/global-controls-over-find-locations.rst | 21 -- Help/release/dev/gtest-1.8.1.rst | 5 - Help/release/dev/message-indent.rst | 5 - Help/release/dev/objective-c-cxx.rst | 9 - Help/release/dev/per-lang-link-library-flag.rst | 9 - Help/release/dev/precompile-headers.rst | 6 - Help/release/dev/project-version-0.rst | 5 - Help/release/dev/remove_directory-symlink.rst | 6 - Help/release/dev/solaris_clang.rst | 4 - Help/release/dev/trace-redirect.rst | 6 - Help/release/dev/unity-build.rst | 6 - Help/release/dev/vs-configuration-type-genex.rst | 5 - Help/release/dev/vs-dpi-aware.rst | 6 - .../dev/windows-auto-export-incremental-build.rst | 6 - .../dev/xcode-debug-document-versioning.rst | 7 - Help/release/index.rst | 1 + 44 files changed, 220 insertions(+), 295 deletions(-) create mode 100644 Help/release/3.16.rst delete mode 100644 Help/release/dev/CMP0095.rst delete mode 100644 Help/release/dev/FPHSA-reason-failure-message.rst delete mode 100644 Help/release/dev/FindGnuTLS-target.rst delete mode 100644 Help/release/dev/FindPkgConfig-module-name.rst delete mode 100644 Help/release/dev/FindPython-FIND_ABI.rst delete mode 100644 Help/release/dev/FindPython-specify_artifacts.rst delete mode 100644 Help/release/dev/add-install-remove-environment-rpath.rst delete mode 100644 Help/release/dev/add_cmake_find_use_package_registry.rst delete mode 100644 Help/release/dev/add_skip_regular_expression_test_property.rst delete mode 100644 Help/release/dev/add_test-expand_lists.rst delete mode 100644 Help/release/dev/aix.rst delete mode 100644 Help/release/dev/automoc_path_prefix.rst delete mode 100644 Help/release/dev/build-install-rpath-genex.rst delete mode 100644 Help/release/dev/cmake-e-true-false.rst delete mode 100644 Help/release/dev/cmake-initial-cache-dirs.rst delete mode 100644 Help/release/dev/cmake-qch-no-version-in-filename.rst delete mode 100644 Help/release/dev/cpack-install-multiple-configurations.rst delete mode 100644 Help/release/dev/cpack-install-scripts.rst delete mode 100644 Help/release/dev/cpack-zstd.rst delete mode 100644 Help/release/dev/ctest-build-makeprogram-propagated-configure-pass.rst delete mode 100644 Help/release/dev/ctest-hardware-allocation.rst delete mode 100644 Help/release/dev/cuda-CMAKE_CUDA_RESOLVE_DEVICE_SYMBOLS.rst delete mode 100644 Help/release/dev/deprecate-policy-old.rst delete mode 100644 Help/release/dev/doxygen-add-docs-USE_STAMP_FILE.rst delete mode 100644 Help/release/dev/eclipse-resource-encoding.rst delete mode 100644 Help/release/dev/external-project-support-no-git-submodules.rst delete mode 100644 Help/release/dev/get-runtime-dependencies.rst delete mode 100644 Help/release/dev/global-controls-over-find-locations.rst delete mode 100644 Help/release/dev/gtest-1.8.1.rst delete mode 100644 Help/release/dev/message-indent.rst delete mode 100644 Help/release/dev/objective-c-cxx.rst delete mode 100644 Help/release/dev/per-lang-link-library-flag.rst delete mode 100644 Help/release/dev/precompile-headers.rst delete mode 100644 Help/release/dev/project-version-0.rst delete mode 100644 Help/release/dev/remove_directory-symlink.rst delete mode 100644 Help/release/dev/solaris_clang.rst delete mode 100644 Help/release/dev/trace-redirect.rst delete mode 100644 Help/release/dev/unity-build.rst delete mode 100644 Help/release/dev/vs-configuration-type-genex.rst delete mode 100644 Help/release/dev/vs-dpi-aware.rst delete mode 100644 Help/release/dev/windows-auto-export-incremental-build.rst delete mode 100644 Help/release/dev/xcode-debug-document-versioning.rst diff --git a/Help/release/3.16.rst b/Help/release/3.16.rst new file mode 100644 index 0000000..760335d --- /dev/null +++ b/Help/release/3.16.rst @@ -0,0 +1,219 @@ +CMake 3.16 Release Notes +************************ + +.. only:: html + + .. contents:: + +Changes made since CMake 3.15 include the following. + +* The :command:`find_package` command has learned to check the following + variables to control searching + + * :variable:`CMAKE_FIND_USE_PACKAGE_REGISTRY` - Controls the searching the + cmake user registry. + +* The :variable:`CMAKE_FIND_PACKAGE_NO_PACKAGE_REGISTRY` has been deprecated. + Instead use :variable:`CMAKE_FIND_USE_PACKAGE_REGISTRY` + +* A new target property, :prop_tgt:`INSTALL_REMOVE_ENVIRONMENT_RPATH`, was + added which removes compiler-defined rpaths from a target. This property is + initialized by :variable:`CMAKE_INSTALL_REMOVE_ENVIRONMENT_RPATH`. + +* A new test property, :prop_test:`SKIP_REGULAR_EXPRESSION`, has been added. + This property is similar to :prop_test:`FAIL_REGULAR_EXPRESSION` and + :prop_test:`PASS_REGULAR_EXPRESSION`, but with the same meaning as + :prop_test:`SKIP_RETURN_CODE`. This is useful, for example, in cases where + the user has no control over the return code of the test. For example, in + Catch2, the return value is the number of assertion failed, therefore it is + impossible to use it for :prop_test:`SKIP_RETURN_CODE`. + +* The command :command:`add_test` learned the option ``COMMAND_EXPAND_LISTS`` + which causes lists in the ``COMMAND`` argument to be expanded, including + lists created by generator expressions. + +* On AIX, executables using the :prop_tgt:`ENABLE_EXPORTS` target property + now produce a linker import file with a ``.imp`` extension in addition + to the executable file. Plugins (created via :command:`add_library` with + the ``MODULE`` option) that use :command:`target_link_libraries` to link + to the executable for its symbols are now linked using the import file. + The :command:`install(TARGETS)` command now installs the import file as + an ``ARCHIVE`` artifact. + +* On AIX, runtime linking is no longer enabled by default. CMake provides + the linker enough information to resolve all symbols up front. + One may manually enable runtime linking for shared libraries and/or + loadable modules by adding ``-Wl,-G`` to their link flags + (e.g. in the :variable:`CMAKE_SHARED_LINKER_FLAGS` or + :variable:`CMAKE_MODULE_LINKER_FLAGS` variable). + One may manually enable runtime linking for executables by adding + ``-Wl,-brtl`` to their link flags (e.g. in the + :variable:`CMAKE_EXE_LINKER_FLAGS` variable). + +* When using :prop_tgt:`AUTOMOC`, CMake now generates the ``-p`` path prefix + option for ``moc``. This ensures that ``moc`` output files are identical + on different build setups (given, that the headers compiled by ``moc`` are + in an :command:`include directory `). + Also it ensures that ``moc`` output files will compile correctly when the + source and/or build directory is a symbolic link. + + The ``moc`` path prefix generation behavior can be configured by setting + the new :variable:`CMAKE_AUTOMOC_PATH_PREFIX` variable and/or + :prop_tgt:`AUTOMOC_PATH_PREFIX` target property. + +* :prop_tgt:`BUILD_RPATH` and :prop_tgt:`INSTALL_RPATH` now support + :manual:`generator expressions `. + +* :manual:`cmake(1)` ``-E`` now supports ``true`` and ``false`` commands, which + do nothing while returning exit codes of 0 and 1, respectively. + +* The :manual:`cmake(1)` ``-C `` option now evaluates the + initial cache script with :variable:`CMAKE_SOURCE_DIR` and + :variable:`CMAKE_BINARY_DIR` set to the top-level source and build trees. + +* The Qt Compressed Help file is now named ``CMake.qch``, which no longer + contains the release version in the file name. When CMake is upgraded + in-place, the name and location of this file will remain constant. + Tools such as IDEs, help viewers, etc. should now be able to refer to this + file at a fixed location that remains valid across CMake upgrades. + +* ``RPATH`` entries are properly escaped in the intermediary CMake install script. + See policy :policy:`CMP0095`. + +* CPack learned :variable:`CPACK_INSTALL_CMAKE_CONFIGURATIONS` to control + what configurations going to be packaged for multi-configuration generators. + +* The ``CPACK_INSTALL_SCRIPT`` variable has been deprecated in favor of the + new, more accurately named :variable:`CPACK_INSTALL_SCRIPTS` variable. + +* The :cpack_gen:`CPack Archive Generator` learned to generate `.tar.zst` + packages with Zstandard compression. + +* :manual:`ctest(1)` ``--build-makeprogram`` now specifies the make program + used when configuring a project with the Ninja and Makefiles generators + in addition to building it. + +* :manual:`ctest(1)` now has the ability to serialize tests based on hardware + requirements for each test. See :ref:`ctest-hardware-allocation` for + details. + +* Variable :variable:`CMAKE_CUDA_RESOLVE_DEVICE_SYMBOLS` has been + introduced to optionally initialize the + :prop_tgt:`CUDA_RESOLVE_DEVICE_SYMBOLS` target property. + +* An explicit deprecation diagnostic was added for policy ``CMP0067`` + (``CMP0066`` and below were already deprecated). + The :manual:`cmake-policies(7)` manual explains that the OLD behaviors + of all policies are deprecated and that projects should port to the + NEW behaviors. + +* The :command:`doxygen_add_docs` command from the :module:`FindDoxygen` + module gained a new ``USE_STAMP_FILE`` option. When this option present, + the custom target created by the command will only re-run Doxygen if any + of the source files have changed since the last successful run. + +* The :generator:`Eclipse CDT4` extra generator gained a new + :variable:`CMAKE_ECLIPSE_RESOURCE_ENCODING` option to specify + the resource encoding. + +* The :module:`ExternalProject` module's ``ExternalProject_Add`` command + has been updated so that ``GIT_SUBMODULES ""`` initializes no submodules. See + policy :policy:`CMP0097`. + +* The :module:`FindGnuTLS` module now provides an imported target. + +* The :module:`FindPkgConfig` module :command:`pkg_search_module` macro + now defines a ``_MODULE_NAME`` result variable containing the + first matching module name. + +* Modules :module:`FindPython3` and :module:`FindPython` gain the capability + to control which ``ABIs`` will be searched. + +* Modules :module:`FindPython3`, :module:`FindPython2` and :module:`FindPython` + gain the capability to specify directly artifacts. + +* Modules :module:`FindPackageHandleStandardArgs` gains the capability to + specify a message giving the reason for the failure. + +* The :command:`file` command learned a new sub-command, + ``GET_RUNTIME_DEPENDENCIES``, which allows you to recursively get the list of + libraries linked by an executable or library. This sub-command is intended as + a replacement for :module:`GetPrerequisites`. +* The :module:`GetPrerequisites` module has been deprecated, as it has been + superceded by :command:`file(GET_RUNTIME_DEPENDENCIES)`. + +* The :command:`find_file`, :command:`find_library`, :command:`find_path`, + :command:`find_package`, and :command:`find_program` commands have learned to + check the following variables to control searching + + * :variable:`CMAKE_FIND_USE_CMAKE_ENVIRONMENT_PATH` - Controls the searching + the cmake-specific environment variables. + + * :variable:`CMAKE_FIND_USE_CMAKE_PATH` - Controls the searching the + cmake-specific cache variables. + + * :variable:`CMAKE_FIND_USE_CMAKE_SYSTEM_PATH` - Controls the searching + cmake platform specific variables. + + * :variable:`CMAKE_FIND_USE_PACKAGE_ROOT_PATH` - Controls the searching of + :variable:`_ROOT` variables. + + * :variable:`CMAKE_FIND_USE_SYSTEM_ENVIRONMENT_PATH` - Controls the searching + the standard system environment variables. + +* The :module:`FindGTest` module has been updated to recognize + MSVC build trees generated by GTest 1.8.1. + +* The :command:`message` command learned indentation control with the new + :variable:`CMAKE_MESSAGE_INDENT` variable. + +* CMake learned to support the Objective C (``OBJC``) and Objective C++ + (``OBJCXX``) languages. They may be enabled via the :command:`project` + and :command:`enable_language` commands. When ``OBJC`` or ``OBJCXX`` + is enabled, source files with the ``.m`` or ``.mm``, respectively, + will be compiled as Objective C or C++. Otherwise they will be treated + as plain C++ sources as they were before. + +* New variables :variable:`CMAKE__LINK_LIBRARY_FLAG`, + :variable:`CMAKE__LINK_LIBRARY_FILE_FLAG`, and + :variable:`CMAKE__LINK_LIBRARY_SUFFIX` allow control of the + flag used to specify linking to a library on a per-language basis. + This is useful for mixed-language projects where the different + drivers may use different flags. + +* The :prop_tgt:`PRECOMPILE_HEADERS` target property was added to tell + generators to use a list of precompile headers for faster compilation + times. + +* The :command:`project` no longer strips leading zeros in version components. + See policy :policy:`CMP0096`. + +* The :manual:`cmake(1)` ``-E remove_directory`` command-line tool, + when given the path to a symlink to a directory, now removes just + the symlink. It no longer removes content of the linked directory. + +* The ``Clang`` compiler is now supported on ``Solaris``. + +* :manual:`cmake(1)` gained a ``--trace-redirect=`` command line option + that can be used to redirect ``--trace`` output to a file instead + of ``stderr``. + +* The :prop_tgt:`UNITY_BUILD` target property was added to tell + generators to batch include source files for faster compilation + times. + +* :prop_tgt:`VS_CONFIGURATION_TYPE` now supports + :manual:`generator expressions `. + +* The :prop_tgt:`VS_DPI_AWARE` target property was added to tell + :ref:`Visual Studio Generators` to set the ``EnableDpiAwareness`` + property in ``.vcxproj`` files. + +* On Windows, existing auto generated exports are now only updated if the + modified time stamp of the exports is not newer than any modified time stamp + of the input files. + +* The Xcode generator learnt to set the value of the + ``Allow debugging when using document Versions Browser`` schema + option with the :prop_tgt:`XCODE_SCHEME_DEBUG_DOCUMENT_VERSIONING` + target property. diff --git a/Help/release/dev/CMP0095.rst b/Help/release/dev/CMP0095.rst deleted file mode 100644 index 21d0550..0000000 --- a/Help/release/dev/CMP0095.rst +++ /dev/null @@ -1,5 +0,0 @@ -CMP0095 -------- - -* ``RPATH`` entries are properly escaped in the intermediary CMake install script. - See policy :policy:`CMP0095`. diff --git a/Help/release/dev/FPHSA-reason-failure-message.rst b/Help/release/dev/FPHSA-reason-failure-message.rst deleted file mode 100644 index 419c3ba..0000000 --- a/Help/release/dev/FPHSA-reason-failure-message.rst +++ /dev/null @@ -1,5 +0,0 @@ -FPHSA-reason-failure-message ----------------------------- - -* Modules :module:`FindPackageHandleStandardArgs` gains the capability to - specify a message giving the reason for the failure. diff --git a/Help/release/dev/FindGnuTLS-target.rst b/Help/release/dev/FindGnuTLS-target.rst deleted file mode 100644 index 671a7b7..0000000 --- a/Help/release/dev/FindGnuTLS-target.rst +++ /dev/null @@ -1,4 +0,0 @@ -FindGnuTLS-target ------------------ - -* The :module:`FindGnuTLS` module now provides an imported target. diff --git a/Help/release/dev/FindPkgConfig-module-name.rst b/Help/release/dev/FindPkgConfig-module-name.rst deleted file mode 100644 index 9f1cd36..0000000 --- a/Help/release/dev/FindPkgConfig-module-name.rst +++ /dev/null @@ -1,6 +0,0 @@ -FindPkgConfig-module-name -------------------------- - -* The :module:`FindPkgConfig` module :command:`pkg_search_module` macro - now defines a ``_MODULE_NAME`` result variable containing the - first matching module name. diff --git a/Help/release/dev/FindPython-FIND_ABI.rst b/Help/release/dev/FindPython-FIND_ABI.rst deleted file mode 100644 index 19e3f71..0000000 --- a/Help/release/dev/FindPython-FIND_ABI.rst +++ /dev/null @@ -1,5 +0,0 @@ -FindPython-FIND_ABI -------------------- - -* Modules :module:`FindPython3` and :module:`FindPython` gain the capability - to control which ``ABIs`` will be searched. diff --git a/Help/release/dev/FindPython-specify_artifacts.rst b/Help/release/dev/FindPython-specify_artifacts.rst deleted file mode 100644 index 7032f8b..0000000 --- a/Help/release/dev/FindPython-specify_artifacts.rst +++ /dev/null @@ -1,5 +0,0 @@ -FindPython-specify_artifacts ----------------------------- - -* Modules :module:`FindPython3`, :module:`FindPython2` and :module:`FindPython` - gain the capability to specify directly artifacts. diff --git a/Help/release/dev/add-install-remove-environment-rpath.rst b/Help/release/dev/add-install-remove-environment-rpath.rst deleted file mode 100644 index 156106c..0000000 --- a/Help/release/dev/add-install-remove-environment-rpath.rst +++ /dev/null @@ -1,6 +0,0 @@ -add-install-remove-environment-rpath ------------------------------------- - -* A new target property, :prop_tgt:`INSTALL_REMOVE_ENVIRONMENT_RPATH`, was - added which removes compiler-defined rpaths from a target. This property is - initialized by :variable:`CMAKE_INSTALL_REMOVE_ENVIRONMENT_RPATH`. diff --git a/Help/release/dev/add_cmake_find_use_package_registry.rst b/Help/release/dev/add_cmake_find_use_package_registry.rst deleted file mode 100644 index 1b02bad..0000000 --- a/Help/release/dev/add_cmake_find_use_package_registry.rst +++ /dev/null @@ -1,11 +0,0 @@ -add_cmake_find_use_package_registry ------------------------------------ - -* The :command:`find_package` command has learned to check the following - variables to control searching - - * :variable:`CMAKE_FIND_USE_PACKAGE_REGISTRY` - Controls the searching the - cmake user registry. - -* The :variable:`CMAKE_FIND_PACKAGE_NO_PACKAGE_REGISTRY` has been deprecated. - Instead use :variable:`CMAKE_FIND_USE_PACKAGE_REGISTRY` diff --git a/Help/release/dev/add_skip_regular_expression_test_property.rst b/Help/release/dev/add_skip_regular_expression_test_property.rst deleted file mode 100644 index 20ef214..0000000 --- a/Help/release/dev/add_skip_regular_expression_test_property.rst +++ /dev/null @@ -1,10 +0,0 @@ -add_skip_regular_expression_test_property ------------------------------------------ - -* A new test property, :prop_test:`SKIP_REGULAR_EXPRESSION`, has been added. - This property is similar to :prop_test:`FAIL_REGULAR_EXPRESSION` and - :prop_test:`PASS_REGULAR_EXPRESSION`, but with the same meaning as - :prop_test:`SKIP_RETURN_CODE`. This is useful, for example, in cases where - the user has no control over the return code of the test. For example, in - Catch2, the return value is the number of assertion failed, therefore it is - impossible to use it for :prop_test:`SKIP_RETURN_CODE`. diff --git a/Help/release/dev/add_test-expand_lists.rst b/Help/release/dev/add_test-expand_lists.rst deleted file mode 100644 index 88d26b7..0000000 --- a/Help/release/dev/add_test-expand_lists.rst +++ /dev/null @@ -1,6 +0,0 @@ -add_test-expand_lists ---------------------- - -* The command :command:`add_test` learned the option ``COMMAND_EXPAND_LISTS`` - which causes lists in the ``COMMAND`` argument to be expanded, including - lists created by generator expressions. diff --git a/Help/release/dev/aix.rst b/Help/release/dev/aix.rst deleted file mode 100644 index 6919358..0000000 --- a/Help/release/dev/aix.rst +++ /dev/null @@ -1,20 +0,0 @@ -aix ---- - -* On AIX, executables using the :prop_tgt:`ENABLE_EXPORTS` target property - now produce a linker import file with a ``.imp`` extension in addition - to the executable file. Plugins (created via :command:`add_library` with - the ``MODULE`` option) that use :command:`target_link_libraries` to link - to the executable for its symbols are now linked using the import file. - The :command:`install(TARGETS)` command now installs the import file as - an ``ARCHIVE`` artifact. - -* On AIX, runtime linking is no longer enabled by default. CMake provides - the linker enough information to resolve all symbols up front. - One may manually enable runtime linking for shared libraries and/or - loadable modules by adding ``-Wl,-G`` to their link flags - (e.g. in the :variable:`CMAKE_SHARED_LINKER_FLAGS` or - :variable:`CMAKE_MODULE_LINKER_FLAGS` variable). - One may manually enable runtime linking for executables by adding - ``-Wl,-brtl`` to their link flags (e.g. in the - :variable:`CMAKE_EXE_LINKER_FLAGS` variable). diff --git a/Help/release/dev/automoc_path_prefix.rst b/Help/release/dev/automoc_path_prefix.rst deleted file mode 100644 index bee1b32..0000000 --- a/Help/release/dev/automoc_path_prefix.rst +++ /dev/null @@ -1,13 +0,0 @@ -automoc_path_prefix -------------------- - -* When using :prop_tgt:`AUTOMOC`, CMake now generates the ``-p`` path prefix - option for ``moc``. This ensures that ``moc`` output files are identical - on different build setups (given, that the headers compiled by ``moc`` are - in an :command:`include directory `). - Also it ensures that ``moc`` output files will compile correctly when the - source and/or build directory is a symbolic link. - - The ``moc`` path prefix generation behavior can be configured by setting - the new :variable:`CMAKE_AUTOMOC_PATH_PREFIX` variable and/or - :prop_tgt:`AUTOMOC_PATH_PREFIX` target property. diff --git a/Help/release/dev/build-install-rpath-genex.rst b/Help/release/dev/build-install-rpath-genex.rst deleted file mode 100644 index 644b1b2..0000000 --- a/Help/release/dev/build-install-rpath-genex.rst +++ /dev/null @@ -1,5 +0,0 @@ -build-install-rpath-genex -------------------------- - -* :prop_tgt:`BUILD_RPATH` and :prop_tgt:`INSTALL_RPATH` now support - :manual:`generator expressions `. diff --git a/Help/release/dev/cmake-e-true-false.rst b/Help/release/dev/cmake-e-true-false.rst deleted file mode 100644 index 173fabd..0000000 --- a/Help/release/dev/cmake-e-true-false.rst +++ /dev/null @@ -1,5 +0,0 @@ -cmake-e-true-false ------------------- - -* :manual:`cmake(1)` ``-E`` now supports ``true`` and ``false`` commands, which - do nothing while returning exit codes of 0 and 1, respectively. diff --git a/Help/release/dev/cmake-initial-cache-dirs.rst b/Help/release/dev/cmake-initial-cache-dirs.rst deleted file mode 100644 index be91902..0000000 --- a/Help/release/dev/cmake-initial-cache-dirs.rst +++ /dev/null @@ -1,6 +0,0 @@ -cmake-initial-cache-dirs ------------------------- - -* The :manual:`cmake(1)` ``-C `` option now evaluates the - initial cache script with :variable:`CMAKE_SOURCE_DIR` and - :variable:`CMAKE_BINARY_DIR` set to the top-level source and build trees. diff --git a/Help/release/dev/cmake-qch-no-version-in-filename.rst b/Help/release/dev/cmake-qch-no-version-in-filename.rst deleted file mode 100644 index 3c5cb04..0000000 --- a/Help/release/dev/cmake-qch-no-version-in-filename.rst +++ /dev/null @@ -1,8 +0,0 @@ -cmake-qch-no-version-in-filename --------------------------------- - -* The Qt Compressed Help file is now named ``CMake.qch``, which no longer - contains the release version in the file name. When CMake is upgraded - in-place, the name and location of this file will remain constant. - Tools such as IDEs, help viewers, etc. should now be able to refer to this - file at a fixed location that remains valid across CMake upgrades. diff --git a/Help/release/dev/cpack-install-multiple-configurations.rst b/Help/release/dev/cpack-install-multiple-configurations.rst deleted file mode 100644 index d1692dc..0000000 --- a/Help/release/dev/cpack-install-multiple-configurations.rst +++ /dev/null @@ -1,5 +0,0 @@ -cpack-install-multiple-configurations -------------------------------------- - -* CPack learned :variable:`CPACK_INSTALL_CMAKE_CONFIGURATIONS` to control - what configurations going to be packaged for multi-configuration generators. diff --git a/Help/release/dev/cpack-install-scripts.rst b/Help/release/dev/cpack-install-scripts.rst deleted file mode 100644 index 7b80d33..0000000 --- a/Help/release/dev/cpack-install-scripts.rst +++ /dev/null @@ -1,5 +0,0 @@ -cpack-install-scripts ---------------------- - -* The ``CPACK_INSTALL_SCRIPT`` variable has been deprecated in favor of the - new, more accurately named :variable:`CPACK_INSTALL_SCRIPTS` variable. diff --git a/Help/release/dev/cpack-zstd.rst b/Help/release/dev/cpack-zstd.rst deleted file mode 100644 index e1e64a2..0000000 --- a/Help/release/dev/cpack-zstd.rst +++ /dev/null @@ -1,5 +0,0 @@ -cpack-zstd ----------- - -* The :cpack_gen:`CPack Archive Generator` learned to generate `.tar.zst` - packages with Zstandard compression. diff --git a/Help/release/dev/ctest-build-makeprogram-propagated-configure-pass.rst b/Help/release/dev/ctest-build-makeprogram-propagated-configure-pass.rst deleted file mode 100644 index 4465de8..0000000 --- a/Help/release/dev/ctest-build-makeprogram-propagated-configure-pass.rst +++ /dev/null @@ -1,6 +0,0 @@ -ctest-build-makeprogram-propagated-configure-pass -------------------------------------------------- - -* :manual:`ctest(1)` ``--build-makeprogram`` now specifies the make program - used when configuring a project with the Ninja and Makefiles generators - in addition to building it. diff --git a/Help/release/dev/ctest-hardware-allocation.rst b/Help/release/dev/ctest-hardware-allocation.rst deleted file mode 100644 index 875dbdc..0000000 --- a/Help/release/dev/ctest-hardware-allocation.rst +++ /dev/null @@ -1,6 +0,0 @@ -ctest-hardware-allocation -------------------------- - -* :manual:`ctest(1)` now has the ability to serialize tests based on hardware - requirements for each test. See :ref:`ctest-hardware-allocation` for - details. diff --git a/Help/release/dev/cuda-CMAKE_CUDA_RESOLVE_DEVICE_SYMBOLS.rst b/Help/release/dev/cuda-CMAKE_CUDA_RESOLVE_DEVICE_SYMBOLS.rst deleted file mode 100644 index f21fddf..0000000 --- a/Help/release/dev/cuda-CMAKE_CUDA_RESOLVE_DEVICE_SYMBOLS.rst +++ /dev/null @@ -1,6 +0,0 @@ -cuda-CMAKE_CUDA_RESOLVE_DEVICE_SYMBOLS --------------------------------------- - -* Variable :variable:`CMAKE_CUDA_RESOLVE_DEVICE_SYMBOLS` has been - introduced to optionally initialize the - :prop_tgt:`CUDA_RESOLVE_DEVICE_SYMBOLS` target property. diff --git a/Help/release/dev/deprecate-policy-old.rst b/Help/release/dev/deprecate-policy-old.rst deleted file mode 100644 index 440efa9..0000000 --- a/Help/release/dev/deprecate-policy-old.rst +++ /dev/null @@ -1,8 +0,0 @@ -deprecate-policy-old --------------------- - -* An explicit deprecation diagnostic was added for policy ``CMP0067`` - (``CMP0066`` and below were already deprecated). - The :manual:`cmake-policies(7)` manual explains that the OLD behaviors - of all policies are deprecated and that projects should port to the - NEW behaviors. diff --git a/Help/release/dev/doxygen-add-docs-USE_STAMP_FILE.rst b/Help/release/dev/doxygen-add-docs-USE_STAMP_FILE.rst deleted file mode 100644 index 700ee6c..0000000 --- a/Help/release/dev/doxygen-add-docs-USE_STAMP_FILE.rst +++ /dev/null @@ -1,7 +0,0 @@ -doxygen-add-docs-USE_STAMP_FILE -------------------------------- - -* The :command:`doxygen_add_docs` command from the :module:`FindDoxygen` - module gained a new ``USE_STAMP_FILE`` option. When this option present, - the custom target created by the command will only re-run Doxygen if any - of the source files have changed since the last successful run. diff --git a/Help/release/dev/eclipse-resource-encoding.rst b/Help/release/dev/eclipse-resource-encoding.rst deleted file mode 100644 index 6ceca0c..0000000 --- a/Help/release/dev/eclipse-resource-encoding.rst +++ /dev/null @@ -1,6 +0,0 @@ -eclipse-resource-encoding -------------------------- - -* The :generator:`Eclipse CDT4` extra generator gained a new - :variable:`CMAKE_ECLIPSE_RESOURCE_ENCODING` option to specify - the resource encoding. diff --git a/Help/release/dev/external-project-support-no-git-submodules.rst b/Help/release/dev/external-project-support-no-git-submodules.rst deleted file mode 100644 index 1d4be66..0000000 --- a/Help/release/dev/external-project-support-no-git-submodules.rst +++ /dev/null @@ -1,6 +0,0 @@ -external-project-support-no-git-submodules ------------------------------------------- - -* The :module:`ExternalProject` module's ``ExternalProject_Add`` command - has been updated so that ``GIT_SUBMODULES ""`` initializes no submodules. See - policy :policy:`CMP0097`. diff --git a/Help/release/dev/get-runtime-dependencies.rst b/Help/release/dev/get-runtime-dependencies.rst deleted file mode 100644 index b9dc6e6..0000000 --- a/Help/release/dev/get-runtime-dependencies.rst +++ /dev/null @@ -1,9 +0,0 @@ -get-runtime-dependencies ------------------------- - -* The :command:`file` command learned a new sub-command, - ``GET_RUNTIME_DEPENDENCIES``, which allows you to recursively get the list of - libraries linked by an executable or library. This sub-command is intended as - a replacement for :module:`GetPrerequisites`. -* The :module:`GetPrerequisites` module has been deprecated, as it has been - superceded by :command:`file(GET_RUNTIME_DEPENDENCIES)`. diff --git a/Help/release/dev/global-controls-over-find-locations.rst b/Help/release/dev/global-controls-over-find-locations.rst deleted file mode 100644 index 1c0b226..0000000 --- a/Help/release/dev/global-controls-over-find-locations.rst +++ /dev/null @@ -1,21 +0,0 @@ -global-controls-over-find-locations ------------------------------------ - -* The :command:`find_file`, :command:`find_library`, :command:`find_path`, - :command:`find_package`, and :command:`find_program` commands have learned to - check the following variables to control searching - - * :variable:`CMAKE_FIND_USE_CMAKE_ENVIRONMENT_PATH` - Controls the searching - the cmake-specific environment variables. - - * :variable:`CMAKE_FIND_USE_CMAKE_PATH` - Controls the searching the - cmake-specific cache variables. - - * :variable:`CMAKE_FIND_USE_CMAKE_SYSTEM_PATH` - Controls the searching - cmake platform specific variables. - - * :variable:`CMAKE_FIND_USE_PACKAGE_ROOT_PATH` - Controls the searching of - :variable:`_ROOT` variables. - - * :variable:`CMAKE_FIND_USE_SYSTEM_ENVIRONMENT_PATH` - Controls the searching - the standard system environment variables. diff --git a/Help/release/dev/gtest-1.8.1.rst b/Help/release/dev/gtest-1.8.1.rst deleted file mode 100644 index 2e48da4..0000000 --- a/Help/release/dev/gtest-1.8.1.rst +++ /dev/null @@ -1,5 +0,0 @@ -gtest-1.8.1 ------------ - -* The :module:`FindGTest` module has been updated to recognize - MSVC build trees generated by GTest 1.8.1. diff --git a/Help/release/dev/message-indent.rst b/Help/release/dev/message-indent.rst deleted file mode 100644 index b170708..0000000 --- a/Help/release/dev/message-indent.rst +++ /dev/null @@ -1,5 +0,0 @@ -message-indent --------------- - -* The :command:`message` command learned indentation control with the new - :variable:`CMAKE_MESSAGE_INDENT` variable. diff --git a/Help/release/dev/objective-c-cxx.rst b/Help/release/dev/objective-c-cxx.rst deleted file mode 100644 index 218af4e..0000000 --- a/Help/release/dev/objective-c-cxx.rst +++ /dev/null @@ -1,9 +0,0 @@ -Objective C/C++ ---------------- - -* CMake learned to support the Objective C (``OBJC``) and Objective C++ - (``OBJCXX``) languages. They may be enabled via the :command:`project` - and :command:`enable_language` commands. When ``OBJC`` or ``OBJCXX`` - is enabled, source files with the ``.m`` or ``.mm``, respectively, - will be compiled as Objective C or C++. Otherwise they will be treated - as plain C++ sources as they were before. diff --git a/Help/release/dev/per-lang-link-library-flag.rst b/Help/release/dev/per-lang-link-library-flag.rst deleted file mode 100644 index 4f5966d..0000000 --- a/Help/release/dev/per-lang-link-library-flag.rst +++ /dev/null @@ -1,9 +0,0 @@ -per-lang-link-library-flag --------------------------- - -* New variables :variable:`CMAKE__LINK_LIBRARY_FLAG`, - :variable:`CMAKE__LINK_LIBRARY_FILE_FLAG`, and - :variable:`CMAKE__LINK_LIBRARY_SUFFIX` allow control of the - flag used to specify linking to a library on a per-language basis. - This is useful for mixed-language projects where the different - drivers may use different flags. diff --git a/Help/release/dev/precompile-headers.rst b/Help/release/dev/precompile-headers.rst deleted file mode 100644 index 8b62da7..0000000 --- a/Help/release/dev/precompile-headers.rst +++ /dev/null @@ -1,6 +0,0 @@ -Precompile Headers ------------------- - -* The :prop_tgt:`PRECOMPILE_HEADERS` target property was added to tell - generators to use a list of precompile headers for faster compilation - times. diff --git a/Help/release/dev/project-version-0.rst b/Help/release/dev/project-version-0.rst deleted file mode 100644 index 6525522..0000000 --- a/Help/release/dev/project-version-0.rst +++ /dev/null @@ -1,5 +0,0 @@ -project-version-0 ------------------ - -* The :command:`project` no longer strips leading zeros in version components. - See policy :policy:`CMP0096`. diff --git a/Help/release/dev/remove_directory-symlink.rst b/Help/release/dev/remove_directory-symlink.rst deleted file mode 100644 index 0896388..0000000 --- a/Help/release/dev/remove_directory-symlink.rst +++ /dev/null @@ -1,6 +0,0 @@ -remove_directory-symlink ------------------------- - -* The :manual:`cmake(1)` ``-E remove_directory`` command-line tool, - when given the path to a symlink to a directory, now removes just - the symlink. It no longer removes content of the linked directory. diff --git a/Help/release/dev/solaris_clang.rst b/Help/release/dev/solaris_clang.rst deleted file mode 100644 index 0b023ee..0000000 --- a/Help/release/dev/solaris_clang.rst +++ /dev/null @@ -1,4 +0,0 @@ -solaris_clang -------------- - -* The ``Clang`` compiler is now supported on ``Solaris``. diff --git a/Help/release/dev/trace-redirect.rst b/Help/release/dev/trace-redirect.rst deleted file mode 100644 index 410021e..0000000 --- a/Help/release/dev/trace-redirect.rst +++ /dev/null @@ -1,6 +0,0 @@ -trace-redirect --------------- - -* :manual:`cmake(1)` gained a ``--trace-redirect=`` command line option - that can be used to redirect ``--trace`` output to a file instead - of ``stderr``. diff --git a/Help/release/dev/unity-build.rst b/Help/release/dev/unity-build.rst deleted file mode 100644 index 293a375..0000000 --- a/Help/release/dev/unity-build.rst +++ /dev/null @@ -1,6 +0,0 @@ -Unity build ------------ - -* The :prop_tgt:`UNITY_BUILD` target property was added to tell - generators to batch include source files for faster compilation - times. diff --git a/Help/release/dev/vs-configuration-type-genex.rst b/Help/release/dev/vs-configuration-type-genex.rst deleted file mode 100644 index d930d5b..0000000 --- a/Help/release/dev/vs-configuration-type-genex.rst +++ /dev/null @@ -1,5 +0,0 @@ -vs-configuration-type-genex ---------------------------- - -* :prop_tgt:`VS_CONFIGURATION_TYPE` now supports - :manual:`generator expressions `. diff --git a/Help/release/dev/vs-dpi-aware.rst b/Help/release/dev/vs-dpi-aware.rst deleted file mode 100644 index f76f26c..0000000 --- a/Help/release/dev/vs-dpi-aware.rst +++ /dev/null @@ -1,6 +0,0 @@ -vs-dpi-aware ------------- - -* The :prop_tgt:`VS_DPI_AWARE` target property was added to tell - :ref:`Visual Studio Generators` to set the ``EnableDpiAwareness`` - property in ``.vcxproj`` files. diff --git a/Help/release/dev/windows-auto-export-incremental-build.rst b/Help/release/dev/windows-auto-export-incremental-build.rst deleted file mode 100644 index 3126329..0000000 --- a/Help/release/dev/windows-auto-export-incremental-build.rst +++ /dev/null @@ -1,6 +0,0 @@ -windows-auto-export-incremental-build -------------------------------------- - -* On Windows, existing auto generated exports are now only updated if the - modified time stamp of the exports is not newer than any modified time stamp - of the input files. diff --git a/Help/release/dev/xcode-debug-document-versioning.rst b/Help/release/dev/xcode-debug-document-versioning.rst deleted file mode 100644 index 15aed4f..0000000 --- a/Help/release/dev/xcode-debug-document-versioning.rst +++ /dev/null @@ -1,7 +0,0 @@ -xcode-debug-document-versioning -------------------------------- - -* The Xcode generator learnt to set the value of the - ``Allow debugging when using document Versions Browser`` schema - option with the :prop_tgt:`XCODE_SCHEME_DEBUG_DOCUMENT_VERSIONING` - target property. diff --git a/Help/release/index.rst b/Help/release/index.rst index 62032e6..a4585a5 100644 --- a/Help/release/index.rst +++ b/Help/release/index.rst @@ -15,6 +15,7 @@ Releases .. toctree:: :maxdepth: 1 + 3.16 <3.16> 3.15 <3.15> 3.14 <3.14> 3.13 <3.13> -- cgit v0.12 From a933d8d84e527b04920773d296b09bdcc0872ecf Mon Sep 17 00:00:00 2001 From: Brad King Date: Fri, 4 Oct 2019 11:41:08 -0400 Subject: Help: Organize and revise 3.16 release notes Add section headers similar to the 3.15 release notes and move each individual bullet into an appropriate section. Revise a few bullets. Drop bullets covering internal interfaces. --- Help/release/3.16.rst | 313 ++++++++++++++++++++++++++++---------------------- 1 file changed, 178 insertions(+), 135 deletions(-) diff --git a/Help/release/3.16.rst b/Help/release/3.16.rst index 760335d..8d8490e 100644 --- a/Help/release/3.16.rst +++ b/Help/release/3.16.rst @@ -7,30 +7,26 @@ CMake 3.16 Release Notes Changes made since CMake 3.15 include the following. -* The :command:`find_package` command has learned to check the following - variables to control searching +New Features +============ - * :variable:`CMAKE_FIND_USE_PACKAGE_REGISTRY` - Controls the searching the - cmake user registry. +Languages +--------- -* The :variable:`CMAKE_FIND_PACKAGE_NO_PACKAGE_REGISTRY` has been deprecated. - Instead use :variable:`CMAKE_FIND_USE_PACKAGE_REGISTRY` +* CMake learned to support the Objective C (``OBJC``) and Objective C++ + (``OBJCXX``) languages. They may be enabled via the :command:`project` + and :command:`enable_language` commands. When ``OBJC`` or ``OBJCXX`` + is enabled, source files with the ``.m`` or ``.mm``, respectively, + will be compiled as Objective C or C++. Otherwise they will be treated + as plain C++ sources as they were before. -* A new target property, :prop_tgt:`INSTALL_REMOVE_ENVIRONMENT_RPATH`, was - added which removes compiler-defined rpaths from a target. This property is - initialized by :variable:`CMAKE_INSTALL_REMOVE_ENVIRONMENT_RPATH`. +Compilers +--------- -* A new test property, :prop_test:`SKIP_REGULAR_EXPRESSION`, has been added. - This property is similar to :prop_test:`FAIL_REGULAR_EXPRESSION` and - :prop_test:`PASS_REGULAR_EXPRESSION`, but with the same meaning as - :prop_test:`SKIP_RETURN_CODE`. This is useful, for example, in cases where - the user has no control over the return code of the test. For example, in - Catch2, the return value is the number of assertion failed, therefore it is - impossible to use it for :prop_test:`SKIP_RETURN_CODE`. +* The ``Clang`` compiler is now supported on ``Solaris``. -* The command :command:`add_test` learned the option ``COMMAND_EXPAND_LISTS`` - which causes lists in the ``COMMAND`` argument to be expanded, including - lists created by generator expressions. +Platforms +--------- * On AIX, executables using the :prop_tgt:`ENABLE_EXPORTS` target property now produce a linker import file with a ``.imp`` extension in addition @@ -50,97 +46,27 @@ Changes made since CMake 3.15 include the following. ``-Wl,-brtl`` to their link flags (e.g. in the :variable:`CMAKE_EXE_LINKER_FLAGS` variable). -* When using :prop_tgt:`AUTOMOC`, CMake now generates the ``-p`` path prefix - option for ``moc``. This ensures that ``moc`` output files are identical - on different build setups (given, that the headers compiled by ``moc`` are - in an :command:`include directory `). - Also it ensures that ``moc`` output files will compile correctly when the - source and/or build directory is a symbolic link. - - The ``moc`` path prefix generation behavior can be configured by setting - the new :variable:`CMAKE_AUTOMOC_PATH_PREFIX` variable and/or - :prop_tgt:`AUTOMOC_PATH_PREFIX` target property. - -* :prop_tgt:`BUILD_RPATH` and :prop_tgt:`INSTALL_RPATH` now support - :manual:`generator expressions `. - -* :manual:`cmake(1)` ``-E`` now supports ``true`` and ``false`` commands, which - do nothing while returning exit codes of 0 and 1, respectively. - -* The :manual:`cmake(1)` ``-C `` option now evaluates the - initial cache script with :variable:`CMAKE_SOURCE_DIR` and - :variable:`CMAKE_BINARY_DIR` set to the top-level source and build trees. - -* The Qt Compressed Help file is now named ``CMake.qch``, which no longer - contains the release version in the file name. When CMake is upgraded - in-place, the name and location of this file will remain constant. - Tools such as IDEs, help viewers, etc. should now be able to refer to this - file at a fixed location that remains valid across CMake upgrades. - -* ``RPATH`` entries are properly escaped in the intermediary CMake install script. - See policy :policy:`CMP0095`. +Command-Line +------------ -* CPack learned :variable:`CPACK_INSTALL_CMAKE_CONFIGURATIONS` to control - what configurations going to be packaged for multi-configuration generators. +* :manual:`cmake(1)` ``-E`` now supports ``true`` and ``false`` commands, + which do nothing while returning exit codes of 0 and 1, respectively. -* The ``CPACK_INSTALL_SCRIPT`` variable has been deprecated in favor of the - new, more accurately named :variable:`CPACK_INSTALL_SCRIPTS` variable. - -* The :cpack_gen:`CPack Archive Generator` learned to generate `.tar.zst` - packages with Zstandard compression. - -* :manual:`ctest(1)` ``--build-makeprogram`` now specifies the make program - used when configuring a project with the Ninja and Makefiles generators - in addition to building it. - -* :manual:`ctest(1)` now has the ability to serialize tests based on hardware - requirements for each test. See :ref:`ctest-hardware-allocation` for - details. - -* Variable :variable:`CMAKE_CUDA_RESOLVE_DEVICE_SYMBOLS` has been - introduced to optionally initialize the - :prop_tgt:`CUDA_RESOLVE_DEVICE_SYMBOLS` target property. - -* An explicit deprecation diagnostic was added for policy ``CMP0067`` - (``CMP0066`` and below were already deprecated). - The :manual:`cmake-policies(7)` manual explains that the OLD behaviors - of all policies are deprecated and that projects should port to the - NEW behaviors. - -* The :command:`doxygen_add_docs` command from the :module:`FindDoxygen` - module gained a new ``USE_STAMP_FILE`` option. When this option present, - the custom target created by the command will only re-run Doxygen if any - of the source files have changed since the last successful run. - -* The :generator:`Eclipse CDT4` extra generator gained a new - :variable:`CMAKE_ECLIPSE_RESOURCE_ENCODING` option to specify - the resource encoding. - -* The :module:`ExternalProject` module's ``ExternalProject_Add`` command - has been updated so that ``GIT_SUBMODULES ""`` initializes no submodules. See - policy :policy:`CMP0097`. - -* The :module:`FindGnuTLS` module now provides an imported target. - -* The :module:`FindPkgConfig` module :command:`pkg_search_module` macro - now defines a ``_MODULE_NAME`` result variable containing the - first matching module name. - -* Modules :module:`FindPython3` and :module:`FindPython` gain the capability - to control which ``ABIs`` will be searched. +* :manual:`cmake(1)` gained a ``--trace-redirect=`` command line + option that can be used to redirect ``--trace`` output to a file instead + of ``stderr``. -* Modules :module:`FindPython3`, :module:`FindPython2` and :module:`FindPython` - gain the capability to specify directly artifacts. +Commands +-------- -* Modules :module:`FindPackageHandleStandardArgs` gains the capability to - specify a message giving the reason for the failure. +* The :command:`add_test` command learned the option ``COMMAND_EXPAND_LISTS`` + which causes lists in the ``COMMAND`` argument to be expanded, including + lists created by generator expressions. * The :command:`file` command learned a new sub-command, ``GET_RUNTIME_DEPENDENCIES``, which allows you to recursively get the list of libraries linked by an executable or library. This sub-command is intended as a replacement for :module:`GetPrerequisites`. -* The :module:`GetPrerequisites` module has been deprecated, as it has been - superceded by :command:`file(GET_RUNTIME_DEPENDENCIES)`. * The :command:`find_file`, :command:`find_library`, :command:`find_path`, :command:`find_package`, and :command:`find_program` commands have learned to @@ -161,59 +87,176 @@ Changes made since CMake 3.15 include the following. * :variable:`CMAKE_FIND_USE_SYSTEM_ENVIRONMENT_PATH` - Controls the searching the standard system environment variables. -* The :module:`FindGTest` module has been updated to recognize - MSVC build trees generated by GTest 1.8.1. +* The :command:`find_package` command has learned to check the following + variables to control searching + + * :variable:`CMAKE_FIND_USE_PACKAGE_REGISTRY` - Controls the searching the + cmake user registry. * The :command:`message` command learned indentation control with the new :variable:`CMAKE_MESSAGE_INDENT` variable. -* CMake learned to support the Objective C (``OBJC``) and Objective C++ - (``OBJCXX``) languages. They may be enabled via the :command:`project` - and :command:`enable_language` commands. When ``OBJC`` or ``OBJCXX`` - is enabled, source files with the ``.m`` or ``.mm``, respectively, - will be compiled as Objective C or C++. Otherwise they will be treated - as plain C++ sources as they were before. +* The :command:`target_precompile_headers` command was added to specify + a list of headers to precompile for faster compilation times. -* New variables :variable:`CMAKE__LINK_LIBRARY_FLAG`, - :variable:`CMAKE__LINK_LIBRARY_FILE_FLAG`, and - :variable:`CMAKE__LINK_LIBRARY_SUFFIX` allow control of the - flag used to specify linking to a library on a per-language basis. - This is useful for mixed-language projects where the different - drivers may use different flags. +Variables +--------- -* The :prop_tgt:`PRECOMPILE_HEADERS` target property was added to tell - generators to use a list of precompile headers for faster compilation - times. +* The :variable:`CMAKE_CUDA_RESOLVE_DEVICE_SYMBOLS` variable has been + introduced to optionally initialize the + :prop_tgt:`CUDA_RESOLVE_DEVICE_SYMBOLS` target property. -* The :command:`project` no longer strips leading zeros in version components. - See policy :policy:`CMP0096`. +* The :variable:`CMAKE_ECLIPSE_RESOURCE_ENCODING` variable was added to + specify the resource encoding for the the :generator:`Eclipse CDT4` extra + generator. -* The :manual:`cmake(1)` ``-E remove_directory`` command-line tool, - when given the path to a symlink to a directory, now removes just - the symlink. It no longer removes content of the linked directory. +Properties +---------- -* The ``Clang`` compiler is now supported on ``Solaris``. +* The :prop_tgt:`BUILD_RPATH` and :prop_tgt:`INSTALL_RPATH` target properties + now support :manual:`generator expressions `. -* :manual:`cmake(1)` gained a ``--trace-redirect=`` command line option - that can be used to redirect ``--trace`` output to a file instead - of ``stderr``. +* The :prop_tgt:`INSTALL_REMOVE_ENVIRONMENT_RPATH` target property was + added to remove compiler-defined ``RPATH`` entries from a target. + This property is initialized by the + :variable:`CMAKE_INSTALL_REMOVE_ENVIRONMENT_RPATH` variable. + +* The :prop_tgt:`PRECOMPILE_HEADERS` target property was added to specify + a list of headers to precompile for faster compilation times. + Set it using the :command:`target_precompile_headers` command. * The :prop_tgt:`UNITY_BUILD` target property was added to tell generators to batch include source files for faster compilation times. -* :prop_tgt:`VS_CONFIGURATION_TYPE` now supports +* The :prop_tgt:`VS_CONFIGURATION_TYPE` target property now supports :manual:`generator expressions `. * The :prop_tgt:`VS_DPI_AWARE` target property was added to tell :ref:`Visual Studio Generators` to set the ``EnableDpiAwareness`` property in ``.vcxproj`` files. -* On Windows, existing auto generated exports are now only updated if the - modified time stamp of the exports is not newer than any modified time stamp - of the input files. +* The :prop_tgt:`XCODE_SCHEME_DEBUG_DOCUMENT_VERSIONING` target property was + added to tell the :generator:`Xcode` generator to set the value of the + ``Allow debugging when using document Versions Browser`` schema option. + +Modules +------- + +* The :module:`FindDoxygen` module :command:`doxygen_add_docs` command + gained a new ``USE_STAMP_FILE`` option. When this option present, + the custom target created by the command will only re-run Doxygen if + any of the source files have changed since the last successful run. + +* The :module:`FindGnuTLS` module now provides an imported target. + +* The :module:`FindPackageHandleStandardArgs` module + :command:`find_package_handle_standard_args` command gained + a new ``REASON_FAILURE_MESSAGE`` option to specify a message + giving the reason for the failure. + +* The :module:`FindPkgConfig` module :command:`pkg_search_module` macro + now defines a ``_MODULE_NAME`` result variable containing the + first matching module name. + +* The :module:`FindPython3` and :module:`FindPython` modules gained + options to control which ``ABIs`` will be searched. + +* The :module:`FindPython3`, :module:`FindPython2`, and :module:`FindPython` + modules now support direct specification of artifacts via cache entries. + +Autogen +------- + +* When using :prop_tgt:`AUTOMOC`, CMake now generates the ``-p`` path prefix + option for ``moc``. This ensures that ``moc`` output files are identical + on different build setups (given, that the headers compiled by ``moc`` are + in an :command:`include directory `). + Also it ensures that ``moc`` output files will compile correctly when the + source and/or build directory is a symbolic link. + + The ``moc`` path prefix generation behavior can be configured by setting + the new :variable:`CMAKE_AUTOMOC_PATH_PREFIX` variable and/or + :prop_tgt:`AUTOMOC_PATH_PREFIX` target property. + +CTest +----- + +* :manual:`ctest(1)` now has the ability to serialize tests based on hardware + requirements for each test. See :ref:`ctest-hardware-allocation` for + details. + +* A new test property, :prop_test:`SKIP_REGULAR_EXPRESSION`, has been added. + This property is similar to :prop_test:`FAIL_REGULAR_EXPRESSION` and + :prop_test:`PASS_REGULAR_EXPRESSION`, but with the same meaning as + :prop_test:`SKIP_RETURN_CODE`. This is useful, for example, in cases where + the user has no control over the return code of the test. For example, in + Catch2, the return value is the number of assertion failed, therefore it is + impossible to use it for :prop_test:`SKIP_RETURN_CODE`. + +CPack +----- + +* CPack variable :variable:`CPACK_INSTALL_CMAKE_CONFIGURATIONS` was added to + control what configurations are to be packaged for multi-configuration + CMake generators. + +* The :cpack_gen:`CPack Archive Generator` learned to generate ``.tar.zst`` + packages with Zstandard compression. + +Deprecated and Removed Features +=============================== + +* An explicit deprecation diagnostic was added for policy ``CMP0067`` + (``CMP0066`` and below were already deprecated). + The :manual:`cmake-policies(7)` manual explains that the OLD behaviors + of all policies are deprecated and that projects should port to the + NEW behaviors. + +* The :variable:`CMAKE_FIND_PACKAGE_NO_PACKAGE_REGISTRY` variable has been + deprecated. Use the :variable:`CMAKE_FIND_USE_PACKAGE_REGISTRY` variable + instead. + +* The :module:`GetPrerequisites` module has been deprecated, as it has been + superceded by :command:`file(GET_RUNTIME_DEPENDENCIES)`. + +* The ``CPACK_INSTALL_SCRIPT`` variable has been deprecated in favor of the + new, more accurately named :variable:`CPACK_INSTALL_SCRIPTS` variable. + +Other Changes +============= + +* The :manual:`cmake(1)` ``-C `` option now evaluates the + initial cache script with :variable:`CMAKE_SOURCE_DIR` and + :variable:`CMAKE_BINARY_DIR` set to the top-level source and build trees. + +* The :manual:`cmake(1)` ``-E remove_directory`` command-line tool, + when given the path to a symlink to a directory, now removes just + the symlink. It no longer removes content of the linked directory. + +* The :manual:`ctest(1)` ``--build-makeprogram`` command-line option now + specifies the make program used when configuring a project with the + :generator:`Ninja` generator or the :ref:`Makefile Generators`. + +* The :module:`ExternalProject` module :command:`ExternalProject_Add` command + has been updated so that ``GIT_SUBMODULES ""`` initializes no submodules. + See policy :policy:`CMP0097`. + +* The :module:`FindGTest` module has been updated to recognize + MSVC build trees generated by GTest 1.8.1. + +* The :command:`project` command no longer strips leading zeros in version + components. See policy :policy:`CMP0096`. + +* The Qt Compressed Help file is now named ``CMake.qch``, which no longer + contains the release version in the file name. When CMake is upgraded + in-place, the name and location of this file will remain constant. + Tools such as IDEs, help viewers, etc. should now be able to refer to this + file at a fixed location that remains valid across CMake upgrades. + +* ``RPATH`` entries are properly escaped in the generated CMake scripts + used for installation. See policy :policy:`CMP0095`. -* The Xcode generator learnt to set the value of the - ``Allow debugging when using document Versions Browser`` schema - option with the :prop_tgt:`XCODE_SCHEME_DEBUG_DOCUMENT_VERSIONING` - target property. +* When using :variable:`CMAKE_WINDOWS_EXPORT_ALL_SYMBOLS` on Windows the + auto-generated exports are now updated only when the object files + providing the symbols are updated. -- cgit v0.12 From ffa1c76ba364f4400973e184b30b9ca387e0b484 Mon Sep 17 00:00:00 2001 From: Brad King Date: Mon, 7 Oct 2019 10:21:40 -0400 Subject: Help: Add missing 3.16 release notes for CPack/DEB descriptions Add notes for the changes from commit 33c7ea513d (CPackDeb: Use `CPACK_PACKAGE_DESCRIPTION_FILE`, 2019-07-11). Suggested-by: Alex Turbov --- Help/release/3.16.rst | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/Help/release/3.16.rst b/Help/release/3.16.rst index 8d8490e..2b1ecf5 100644 --- a/Help/release/3.16.rst +++ b/Help/release/3.16.rst @@ -201,9 +201,17 @@ CPack control what configurations are to be packaged for multi-configuration CMake generators. +* The :cpack_gen:`CPack DEB Generator` is now able to format generic text + (usually used as the description for multiple CPack generators) according + to the `Debian Policy Manual`_. See the + :variable:`CPACK_PACKAGE_DESCRIPTION_FILE` and + :variable:`CPACK_DEBIAN__DESCRIPTION` variables. + * The :cpack_gen:`CPack Archive Generator` learned to generate ``.tar.zst`` packages with Zstandard compression. +.. _`Debian Policy Manual`: https://www.debian.org/doc/debian-policy/ch-controlfields.html#description + Deprecated and Removed Features =============================== -- cgit v0.12