From 550d0a8e15212c6bc3b2156e8f73ac71a09489f6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Timo=20R=C3=B6hling?= Date: Wed, 13 Apr 2022 00:32:21 +0200 Subject: [PATCH] New upstream version 3.23.1 --- Help/command/install.rst | 2 +- Help/command/string.rst | 2 +- Help/command/target_sources.rst | 2 +- Help/dev/maint.rst | 18 +--- Help/policy/CMP0112.rst | 4 +- Help/prop_tgt/HEADER_SETS.rst | 13 ++- Help/prop_tgt/INTERFACE_HEADER_SETS.rst | 8 +- Help/release/3.22.rst | 18 +++- Help/release/3.23.rst | 22 ++++- Help/variable/CMAKE_CACHEFILE_DIR.rst | 7 +- Modules/CMakeDependentOption.cmake | 19 ++-- Modules/CheckPIESupported.cmake | 11 ++- Modules/FindPostgreSQL.cmake | 4 +- Modules/GNUInstallDirs.cmake | 6 +- Modules/Internal/CheckFlagCommonConfig.cmake | 4 +- Modules/Internal/HeaderpadWorkaround.cmake | 69 +++++++++++++ Source/CMakeVersion.cmake | 4 +- Source/cmCoreTryCompile.cxx | 6 ++ Source/cmFileSet.cxx | 62 +++++++++++- Source/cmFileSet.h | 21 +++- Source/cmLocalGenerator.cxx | 10 +- Source/cmNinjaTargetGenerator.cxx | 34 ++++--- Source/cmTarget.cxx | 97 ++++++++----------- Source/cmTarget.h | 5 +- Source/cmTargetSourcesCommand.cxx | 56 +++-------- Source/cmakemain.cxx | 5 +- Tests/CudaOnly/WithDefs/CMakeLists.txt | 2 + .../ListConfigurePresetsWorkingDir-stdout.txt | 7 ++ .../RunCMake/CMakePresets/RunCMakeTest.cmake | 10 +- .../CheckCCompilerFlag.cmake | 9 ++ .../CheckCXXCompilerFlag.cmake | 9 ++ .../HeaderpadWorkaround.cmake | 18 ++++ .../CheckCompilerFlag/RunCMakeTest.cmake | 4 + .../GNUInstallDirs/Root-Debian-stderr.txt | 4 +- .../GNUInstallDirs/UsrLocal-Debian-stderr.txt | 4 +- .../PchIncludedOneLanguage.cmake | 17 ++++ .../PrecompileHeaders/RunCMakeTest.cmake | 1 + Tests/RunCMake/RunCMake.cmake | 2 +- ...result.txt => FileSetFramework-result.txt} | 0 .../FileSetFramework-stderr.txt | 4 + .../target_sources/FileSetFramework.cmake | 7 ++ .../target_sources/FileSetImport.cmake | 4 +- .../FileSetNoExistInterface-stderr.txt | 4 - .../FileSetNoExistPrivate-stderr.txt | 4 - .../FileSetNoExistPrivate.cmake | 7 -- .../target_sources/FileSetNoScope-stderr.txt | 4 - .../target_sources/FileSetNoScope.cmake | 6 -- .../target_sources/FileSetProperties.cmake | 4 +- ...xt => FileSetReadOnlyInterface-result.txt} | 0 .../FileSetReadOnlyInterface-stderr.txt | 5 + ...e.cmake => FileSetReadOnlyInterface.cmake} | 3 - ....txt => FileSetReadOnlyPrivate-result.txt} | 0 .../FileSetReadOnlyPrivate-stderr.txt | 5 + .../FileSetReadOnlyPrivate.cmake | 4 + .../target_sources/RunCMakeTest.cmake | 8 +- Utilities/Release/linux/aarch64/cache.txt | 2 +- Utilities/Release/linux/x86_64/cache.txt | 2 +- Utilities/Release/win/x86/cache-i386.txt | 2 +- Utilities/Release/win/x86/cache-x86_64.txt | 2 +- Utilities/Sphinx/CMakeLists.txt | 56 +++++++++-- Utilities/Sphinx/conf.py.in | 1 + Utilities/Sphinx/static/cmake.css | 12 +++ Utilities/Sphinx/templates/layout.html | 40 +++++++- 63 files changed, 541 insertions(+), 241 deletions(-) create mode 100644 Modules/Internal/HeaderpadWorkaround.cmake create mode 100644 Tests/RunCMake/CMakePresets/ListConfigurePresetsWorkingDir-stdout.txt create mode 100644 Tests/RunCMake/CheckCompilerFlag/HeaderpadWorkaround.cmake create mode 100644 Tests/RunCMake/PrecompileHeaders/PchIncludedOneLanguage.cmake rename Tests/RunCMake/target_sources/{FileSetNoExistInterface-result.txt => FileSetFramework-result.txt} (100%) create mode 100644 Tests/RunCMake/target_sources/FileSetFramework-stderr.txt create mode 100644 Tests/RunCMake/target_sources/FileSetFramework.cmake delete mode 100644 Tests/RunCMake/target_sources/FileSetNoExistInterface-stderr.txt delete mode 100644 Tests/RunCMake/target_sources/FileSetNoExistPrivate-stderr.txt delete mode 100644 Tests/RunCMake/target_sources/FileSetNoExistPrivate.cmake delete mode 100644 Tests/RunCMake/target_sources/FileSetNoScope-stderr.txt delete mode 100644 Tests/RunCMake/target_sources/FileSetNoScope.cmake rename Tests/RunCMake/target_sources/{FileSetNoExistPrivate-result.txt => FileSetReadOnlyInterface-result.txt} (100%) create mode 100644 Tests/RunCMake/target_sources/FileSetReadOnlyInterface-stderr.txt rename Tests/RunCMake/target_sources/{FileSetNoExistInterface.cmake => FileSetReadOnlyInterface.cmake} (50%) rename Tests/RunCMake/target_sources/{FileSetNoScope-result.txt => FileSetReadOnlyPrivate-result.txt} (100%) create mode 100644 Tests/RunCMake/target_sources/FileSetReadOnlyPrivate-stderr.txt create mode 100644 Tests/RunCMake/target_sources/FileSetReadOnlyPrivate.cmake diff --git a/Help/command/install.rst b/Help/command/install.rst index 14f7ff791..1a9dfd70c 100644 --- a/Help/command/install.rst +++ b/Help/command/install.rst @@ -828,7 +828,7 @@ of the ``Development`` component in the package metadata, ensuring that the library is always installed if the headers and CMake export file are present. .. versionadded:: 3.7 - In addition to cmake language files, the ``EXPORT_ANDROID_MK`` mode maybe + In addition to cmake language files, the ``EXPORT_ANDROID_MK`` mode may be used to specify an export to the android ndk build system. This mode accepts the same options as the normal export mode. The Android NDK supports the use of prebuilt libraries, both static and shared. This diff --git a/Help/command/string.rst b/Help/command/string.rst index 9b707eb83..b1ca2cb80 100644 --- a/Help/command/string.rst +++ b/Help/command/string.rst @@ -612,7 +612,7 @@ Requires an element of object type. .. code-block:: cmake string(JSON [ERROR_VARIABLE ] - LENGTH [ ...]) + LENGTH [ ...]) Get the length of an element in ```` at the location given by the list of ```` arguments. diff --git a/Help/command/target_sources.rst b/Help/command/target_sources.rst index 6ad86e3f8..1ad6c373e 100644 --- a/Help/command/target_sources.rst +++ b/Help/command/target_sources.rst @@ -77,7 +77,7 @@ have zero or more named file sets. Each file set has a name, a type, a scope of ``INTERFACE``, ``PUBLIC``, or ``PRIVATE``, one or more base directories, and files within those directories. The only acceptable type is ``HEADERS``. The optional default file sets are named after their type. The target may not be a -custom target. +custom target or :prop_tgt:`FRAMEWORK` target. Files in a ``PRIVATE`` or ``PUBLIC`` file set are marked as source files for the purposes of IDE integration. Additionally, files in ``HEADERS`` file sets diff --git a/Help/dev/maint.rst b/Help/dev/maint.rst index 151ea5a1b..53be91f00 100644 --- a/Help/dev/maint.rst +++ b/Help/dev/maint.rst @@ -245,20 +245,6 @@ Commit with a message such as:: Release versions do not have the development topic section of the CMake Release Notes index page. -Update ``.gitlab-ci.yml`` to drop the upload jobs from the -packaging pipeline by renaming them to start in ``.``: - -.. code-block:: shell - - sed -i 's/^u:/.u:/' .gitlab-ci.yml - -Commit with a message such as:: - - gitlab-ci: Drop package pipeline upload jobs for release branch - - The package pipeline for release versions should not upload packages - automatically to our archive of nightly development versions. - Update ``Source/CMakeVersion.cmake`` to set the version to ``$major.$minor.0-rc0``: @@ -290,15 +276,13 @@ Merge the ``release-$ver`` branch to ``master``: git merge --no-ff release-$ver Begin post-release development by restoring the development branch release -note infrastructure, the nightly package pipeline upload jobs, and -the version date from ``origin/master``: +note infrastructure, and the version date from ``origin/master``: .. code-block:: shell git checkout origin/master -- \ Source/CMakeVersion.cmake Help/release/dev/0-sample-topic.rst sed -i $'/^Releases/ i\\\n.. include:: dev.txt\\\n' Help/release/index.rst - sed -i 's/^\.u:/u:/' .gitlab-ci.yml Update ``Source/CMakeVersion.cmake`` to set the version to ``$major.$minor.$date``: diff --git a/Help/policy/CMP0112.rst b/Help/policy/CMP0112.rst index 313a51e82..5b00d0710 100644 --- a/Help/policy/CMP0112.rst +++ b/Help/policy/CMP0112.rst @@ -24,7 +24,9 @@ file name components no longer add a dependency on the evaluated target. In CMake 3.18 and lower a dependency on the evaluated target of the above generator expressions would always be added. CMake 3.19 and above prefer to not add this dependency. This policy provides compatibility for projects -that have not been updated to expect the new behavior. +that have not been updated to expect the new behavior. The policy setting +is recorded on each target when it is created, and decides whether generator +expressions referencing that target imply a dependency on it. The ``OLD`` behavior for this policy is to add a dependency on the evaluated target for the above generator expressions. The ``NEW`` behavior of diff --git a/Help/prop_tgt/HEADER_SETS.rst b/Help/prop_tgt/HEADER_SETS.rst index fcf723e41..ceb1df506 100644 --- a/Help/prop_tgt/HEADER_SETS.rst +++ b/Help/prop_tgt/HEADER_SETS.rst @@ -3,14 +3,13 @@ HEADER_SETS .. versionadded:: 3.23 -List of the target's ``PRIVATE`` and ``PUBLIC`` header sets (i.e. all -file sets with the type ``HEADERS``). Files listed in these file sets -are treated as source files for the purpose of IDE integration. -The files also have their :prop_sf:`HEADER_FILE_ONLY` property set to -``TRUE``. +Read-only list of the target's ``PRIVATE`` and ``PUBLIC`` header sets (i.e. +all file sets with the type ``HEADERS``). Files listed in these file sets are +treated as source files for the purpose of IDE integration. The files also +have their :prop_sf:`HEADER_FILE_ONLY` property set to ``TRUE``. -This property is normally only set by :command:`target_sources(FILE_SET)` -rather than being manipulated directly. +Header sets may be defined using the :command:`target_sources` command +``FILE_SET`` option with type ``HEADERS``. See also :prop_tgt:`HEADER_SET_`, :prop_tgt:`HEADER_SET` and :prop_tgt:`INTERFACE_HEADER_SETS`. diff --git a/Help/prop_tgt/INTERFACE_HEADER_SETS.rst b/Help/prop_tgt/INTERFACE_HEADER_SETS.rst index 62db5b304..2d3bdacfc 100644 --- a/Help/prop_tgt/INTERFACE_HEADER_SETS.rst +++ b/Help/prop_tgt/INTERFACE_HEADER_SETS.rst @@ -3,12 +3,12 @@ INTERFACE_HEADER_SETS .. versionadded:: 3.23 -List of the target's ``INTERFACE`` and ``PUBLIC`` header sets (i.e. all -file sets with the type ``HEADERS``). Files listed in these header sets +Read-only list of the target's ``INTERFACE`` and ``PUBLIC`` header sets (i.e. +all file sets with the type ``HEADERS``). Files listed in these header sets can be installed with :command:`install(TARGETS)` and exported with :command:`install(EXPORT)` and :command:`export`. -This property is normally only set by :command:`target_sources(FILE_SET)` -rather than being manipulated directly. +Header sets may be defined using the :command:`target_sources` command +``FILE_SET`` option with type ``HEADERS``. See also :prop_tgt:`HEADER_SETS`. diff --git a/Help/release/3.22.rst b/Help/release/3.22.rst index 1f773e66c..00e93f62a 100644 --- a/Help/release/3.22.rst +++ b/Help/release/3.22.rst @@ -143,12 +143,17 @@ Other Changes * The :cpack_gen:`CPack NSIS Generator` now requires NSIS 3.03 or later. +Updates +======= + +Changes made since CMake 3.22.0 include the following. + 3.22.1 ------ -This version made no changes to documented features or interfaces. -Some implementation updates were made to support ecosystem changes -and/or fix regressions. +* This version made no changes to documented features or interfaces. + Some implementation updates were made to support ecosystem changes + and/or fix regressions. 3.22.2 ------ @@ -164,3 +169,10 @@ and/or fix regressions. errors in existing projects. The fix has been reverted to restore compatibility. The fix may be restored in a future version of CMake via a policy. + +3.22.4 +------ + +* This version made no changes to documented features or interfaces. + Some implementation updates were made to support ecosystem changes + and/or fix regressions. diff --git a/Help/release/3.23.rst b/Help/release/3.23.rst index 1a3f53ecc..2febbec3c 100644 --- a/Help/release/3.23.rst +++ b/Help/release/3.23.rst @@ -114,8 +114,8 @@ Variables Properties ---------- -* The :prop_tgt:`HEADER_SETS` and :prop_tgt:`INTERFACE_HEADER_SETS` target - properties were added to list header sets associated with a target. +* The :prop_tgt:`HEADER_SETS` and :prop_tgt:`INTERFACE_HEADER_SETS` read-only + target properties were added to list header sets associated with a target. * The :prop_tgt:`HEADER_SET` and :prop_tgt:`HEADER_SET_` target properties were added to list files in the default header set @@ -264,3 +264,21 @@ Other Changes * :manual:`ccmake(1)` may now be enabled on Windows when building CMake from source. This is experimental, and so is not included in official distributions. + +Updates +======= + +Changes made since CMake 3.23.0 include the following. + +3.23.1 +------ + +* The :command:`target_sources` ``FILE_SET`` feature added in CMake 3.23.0 + does not yet place header files properly in Apple :prop_tgt:`FRAMEWORK` + targets. Pending further work in a future version of CMake, it is now + an error to add a ``FILE_SET`` of type ``HEADERS`` to such targets on + Apple platforms. + +* The :prop_tgt:`HEADER_SETS` and :prop_tgt:`INTERFACE_HEADER_SETS` target + properties added in CMake 3.23.0 are now read-only records of the header + sets created by the :command:`target_sources` command. diff --git a/Help/variable/CMAKE_CACHEFILE_DIR.rst b/Help/variable/CMAKE_CACHEFILE_DIR.rst index 8604d0e8c..3fee09f37 100644 --- a/Help/variable/CMAKE_CACHEFILE_DIR.rst +++ b/Help/variable/CMAKE_CACHEFILE_DIR.rst @@ -1,7 +1,6 @@ CMAKE_CACHEFILE_DIR ------------------- -The directory with the ``CMakeCache.txt`` file. - -This is the full path to the directory that has the ``CMakeCache.txt`` -file in it. This is the same as :variable:`CMAKE_BINARY_DIR`. +This variable is used internally by CMake, and may not be set during +the first configuration of a build tree. When it is set, it has the +same value as :variable:`CMAKE_BINARY_DIR`. Use that variable instead. diff --git a/Modules/CMakeDependentOption.cmake b/Modules/CMakeDependentOption.cmake index b7c478f64..ac0e2624a 100644 --- a/Modules/CMakeDependentOption.cmake +++ b/Modules/CMakeDependentOption.cmake @@ -16,13 +16,18 @@ conditions are true. cmake_dependent_option(