parent
9a372f80f7
commit
5a50c91527
@ -0,0 +1,41 @@
|
||||
Specify which registry views must be queried. This option is only meaningful
|
||||
on ``Windows`` platform and will be ignored on other ones. When not
|
||||
specified, |FIND_XXX_REGISTRY_VIEW_DEFAULT| view is used when :policy:`CMP0134`
|
||||
policy is ``NEW``. Refer to :policy:`CMP0134` policy for default view when
|
||||
policy is ``OLD`` or undefined.
|
||||
|
||||
``64``
|
||||
Query the 64bit registry. On ``32bit Windows``, returns always the string
|
||||
``/REGISTRY-NOTFOUND``.
|
||||
|
||||
``32``
|
||||
Query the 32bit registry.
|
||||
|
||||
``64_32``
|
||||
Query both views (``64`` and ``32``) and generate a path for each.
|
||||
|
||||
``32_64``
|
||||
Query both views (``32`` and ``64``) and generate a path for each.
|
||||
|
||||
``HOST``
|
||||
Query the registry matching the architecture of the host: ``64`` on ``64bit
|
||||
Windows`` and ``32`` on ``32bit Windows``.
|
||||
|
||||
``TARGET``
|
||||
Query the registry matching the architecture specified by
|
||||
:variable:`CMAKE_SIZEOF_VOID_P` variable. If not defined, fallback to
|
||||
``HOST`` view.
|
||||
|
||||
``BOTH``
|
||||
Query both views (``32`` and ``64``). The order depends of the following
|
||||
rules: If :variable:`CMAKE_SIZEOF_VOID_P` variable is defined. Use the
|
||||
following view depending of the content of this variable:
|
||||
|
||||
* ``8``: ``64_32``
|
||||
* ``4``: ``32_64``
|
||||
|
||||
If :variable:`CMAKE_SIZEOF_VOID_P` variable is not defined, rely on
|
||||
architecture of the host:
|
||||
|
||||
* ``64bit``: ``64_32``
|
||||
* ``32bit``: ``32``
|
@ -1,16 +1,18 @@
|
||||
option
|
||||
------
|
||||
|
||||
Provide an option that the user can optionally select.
|
||||
Provide a boolean option that the user can optionally select.
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
option(<variable> "<help_text>" [value])
|
||||
|
||||
Provides an option for the user to select as ``ON`` or ``OFF``.
|
||||
If no initial ``<value>`` is provided, ``OFF`` is used.
|
||||
If no initial ``<value>`` is provided, boolean ``OFF`` is the default value.
|
||||
If ``<variable>`` is already set as a normal or cache variable,
|
||||
then the command does nothing (see policy :policy:`CMP0077`).
|
||||
|
||||
If you have options that depend on the values of other options, see
|
||||
For options that depend on the values of other options, see
|
||||
the module help for :module:`CMakeDependentOption`.
|
||||
|
||||
In CMake project mode, a boolean cache variable is created with the option
|
||||
value. In CMake script mode, a boolean variable is set with the option value.
|
||||
|
@ -1,87 +1,7 @@
|
||||
CPack PackageMaker Generator
|
||||
----------------------------
|
||||
|
||||
PackageMaker CPack generator (macOS).
|
||||
|
||||
.. deprecated:: 3.17
|
||||
|
||||
Xcode no longer distributes the PackageMaker tools.
|
||||
This CPack generator will be removed in a future version of CPack.
|
||||
|
||||
Variables specific to CPack PackageMaker generator
|
||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
The following variable is specific to installers built on Mac
|
||||
macOS using PackageMaker:
|
||||
|
||||
.. variable:: CPACK_OSX_PACKAGE_VERSION
|
||||
|
||||
The version of macOS that the resulting PackageMaker archive should be
|
||||
compatible with. Different versions of macOS support different
|
||||
features. For example, CPack can only build component-based installers for
|
||||
macOS 10.4 or newer, and can only build installers that download
|
||||
components on-the-fly for macOS 10.5 or newer. If left blank, this value
|
||||
will be set to the minimum version of macOS that supports the requested
|
||||
features. Set this variable to some value (e.g., 10.4) only if you want to
|
||||
guarantee that your installer will work on that version of macOS, and
|
||||
don't mind missing extra features available in the installer shipping with
|
||||
later versions of macOS.
|
||||
|
||||
Background Image
|
||||
""""""""""""""""
|
||||
|
||||
.. versionadded:: 3.17
|
||||
|
||||
This group of variables controls the background image of the generated
|
||||
installer.
|
||||
|
||||
.. variable:: CPACK_PACKAGEMAKER_BACKGROUND
|
||||
|
||||
Adds a background to Distribution XML if specified. The value contains the
|
||||
path to image in ``Resources`` directory.
|
||||
|
||||
.. variable:: CPACK_PACKAGEMAKER_BACKGROUND_ALIGNMENT
|
||||
|
||||
Adds an ``alignment`` attribute to the background in Distribution XML.
|
||||
Refer to Apple documentation for valid values.
|
||||
|
||||
.. variable:: CPACK_PACKAGEMAKER_BACKGROUND_SCALING
|
||||
|
||||
Adds a ``scaling`` attribute to the background in Distribution XML.
|
||||
Refer to Apple documentation for valid values.
|
||||
|
||||
.. variable:: CPACK_PACKAGEMAKER_BACKGROUND_MIME_TYPE
|
||||
|
||||
Adds a ``mime-type`` attribute to the background in Distribution XML.
|
||||
The option contains MIME type of an image.
|
||||
|
||||
.. variable:: CPACK_PACKAGEMAKER_BACKGROUND_UTI
|
||||
|
||||
Adds an ``uti`` attribute to the background in Distribution XML.
|
||||
The option contains UTI type of an image.
|
||||
|
||||
.. variable:: CPACK_PACKAGEMAKER_BACKGROUND_DARKAQUA
|
||||
|
||||
Adds a background for the Dark Aqua theme to Distribution XML if
|
||||
specified. The value contains the path to image in ``Resources``
|
||||
directory.
|
||||
|
||||
.. variable:: CPACK_PACKAGEMAKER_BACKGROUND_DARKAQUA_ALIGNMENT
|
||||
|
||||
Does the same as :variable:`CPACK_PACKAGEMAKER_BACKGROUND_ALIGNMENT` option,
|
||||
but for the dark theme.
|
||||
|
||||
.. variable:: CPACK_PACKAGEMAKER_BACKGROUND_DARKAQUA_SCALING
|
||||
|
||||
Does the same as :variable:`CPACK_PACKAGEMAKER_BACKGROUND_SCALING` option,
|
||||
but for the dark theme.
|
||||
|
||||
.. variable:: CPACK_PACKAGEMAKER_BACKGROUND_DARKAQUA_MIME_TYPE
|
||||
|
||||
Does the same as :variable:`CPACK_PACKAGEMAKER_BACKGROUND_MIME_TYPE` option,
|
||||
but for the dark theme.
|
||||
|
||||
.. variable:: CPACK_PACKAGEMAKER_BACKGROUND_DARKAQUA_UTI
|
||||
|
||||
Does the same as :variable:`CPACK_PACKAGEMAKER_BACKGROUND_UTI` option,
|
||||
but for the dark theme.
|
||||
Removed. This once generated PackageMaker installers, but the
|
||||
generator has been removed since CMake 3.24. Xcode no longer distributes
|
||||
the PackageMaker tools. Use the :cpack_gen:`CPack productbuild Generator`
|
||||
instead.
|
||||
|
@ -0,0 +1,10 @@
|
||||
ADSP_ROOT
|
||||
---------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
.. include:: ENV_VAR.txt
|
||||
|
||||
The ``ADSP_ROOT`` environment variable specifies a default value
|
||||
for the :variable:`CMAKE_ADSP_ROOT` variable when there is no explicit
|
||||
configuration given on the first run while creating a new build tree.
|
@ -0,0 +1,9 @@
|
||||
CMAKE_COLOR_DIAGNOSTICS
|
||||
-----------------------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
.. include:: ENV_VAR.txt
|
||||
|
||||
Specifies a default value for the :variable:`CMAKE_COLOR_DIAGNOSTICS` variable
|
||||
when there is no explicit value given on the first run.
|
File diff suppressed because it is too large
Load Diff
@ -1,4 +0,0 @@
|
||||
CPackPackageMaker
|
||||
-----------------
|
||||
|
||||
The documentation for the CPack PackageMaker generator has moved here: :cpack_gen:`CPack PackageMaker Generator`
|
@ -0,0 +1,32 @@
|
||||
CMP0130
|
||||
-------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
:command:`while` diagnoses condition evaluation errors.
|
||||
|
||||
CMake 3.23 and below accidentally tolerated errors encountered while
|
||||
evaluating the condition passed to the :command:`while` command
|
||||
(but not the :command:`if` command). For example, the code
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
set(paren "(")
|
||||
while(${paren})
|
||||
endwhile()
|
||||
|
||||
creates an unbalanced parenthesis during condition evaluation.
|
||||
|
||||
CMake 3.24 and above prefer to diagnose such errors. This policy
|
||||
provides compatibility for projects that have not been updated to
|
||||
fix their condition errors.
|
||||
|
||||
The ``OLD`` behavior for this policy is to ignore errors in
|
||||
:command:`while` conditions. The ``NEW`` behavior for this
|
||||
policy is to diagnose errors in :command:`while` conditions.
|
||||
|
||||
This policy was introduced in CMake version 3.24. CMake version |release|
|
||||
warns when the policy is not set and uses ``OLD`` behavior. Use the
|
||||
:command:`cmake_policy` command to set it to ``OLD`` or ``NEW`` explicitly.
|
||||
|
||||
.. include:: DEPRECATED.txt
|
@ -0,0 +1,31 @@
|
||||
CMP0131
|
||||
-------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
:prop_tgt:`LINK_LIBRARIES` supports the :genex:`$<LINK_ONLY:...>`
|
||||
generator expression.
|
||||
|
||||
CMake 3.23 and below documented the :genex:`$<LINK_ONLY:...>` generator
|
||||
expression only for use in :prop_tgt:`INTERFACE_LINK_LIBRARIES`.
|
||||
When used in :prop_tgt:`LINK_LIBRARIES`, the content guarded inside
|
||||
:genex:`$<LINK_ONLY:...>` was always used, even when collecting non-linking
|
||||
usage requirements such as :prop_tgt:`INTERFACE_COMPILE_DEFINITIONS`.
|
||||
|
||||
CMake 3.24 and above prefer to support :genex:`$<LINK_ONLY:...>`, when
|
||||
used in :prop_tgt:`LINK_LIBRARIES`, by using the guarded content only
|
||||
for link dependencies and not other usage requirements. This policy
|
||||
provides compatibility for projects that have not been updated to
|
||||
account for this change.
|
||||
|
||||
The ``OLD`` behavior for this policy is to use :prop_tgt:`LINK_LIBRARIES`
|
||||
content guarded by :genex:`$<LINK_ONLY:...>` even for non-linking
|
||||
usage requirements. The ``NEW`` behavior for this policy is to use
|
||||
the guarded content only for link dependencies.
|
||||
|
||||
This policy was introduced in CMake version 3.24. Use the
|
||||
:command:`cmake_policy` command to set this policy to ``OLD`` or ``NEW``
|
||||
explicitly. Unlike many policies, CMake version |release| does *not*
|
||||
warn when this policy is not set, and simply uses ``OLD`` behavior.
|
||||
|
||||
.. include:: DEPRECATED.txt
|
@ -0,0 +1,26 @@
|
||||
CMP0132
|
||||
-------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
Apart from when using the Xcode generator and some Visual Studio generators,
|
||||
CMake 3.23 and below will set environment variables like :envvar:`CC`,
|
||||
:envvar:`CXX`, etc. when the corresponding language is enabled.
|
||||
This only occurs on the very first time CMake is run in a build directory,
|
||||
and the environment variables are only defined at configure time, not build
|
||||
time. On subsequent CMake runs, these environment variables are not set,
|
||||
opening up the opportunity for different behavior between the first and
|
||||
subsequent CMake runs. CMake 3.24 and above prefer to not set these
|
||||
environment variables when a language is enabled, even on the first run in
|
||||
a build directory.
|
||||
|
||||
The ``OLD`` behavior for this policy sets the relevant environment variable
|
||||
on the first run when a language is enabled. The ``NEW`` behavior for this
|
||||
policy does not set any such environment variables.
|
||||
|
||||
This policy was introduced in CMake version 3.24. Use the
|
||||
:command:`cmake_policy` command to set it to ``OLD`` or ``NEW`` explicitly.
|
||||
Unlike many policies, CMake version |release| does *not* warn
|
||||
when this policy is not set and simply uses ``OLD`` behavior.
|
||||
|
||||
.. include:: DEPRECATED.txt
|
@ -0,0 +1,32 @@
|
||||
CMP0133
|
||||
-------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
The :module:`CPack` module disables SLA by default in the
|
||||
:cpack_gen:`CPack DragNDrop Generator`.
|
||||
|
||||
The :cpack_gen:`CPack DragNDrop Generator` in CMake 3.22 and below attach a
|
||||
Software License Agreement (SLA) to ``.dmg`` files using the file specified
|
||||
by :variable:`CPACK_RESOURCE_FILE_LICENSE`, if set to a non-default value.
|
||||
macOS 12.0 deprecated the tools used to do this, so CMake 3.23 added
|
||||
the :variable:`CPACK_DMG_SLA_USE_RESOURCE_FILE_LICENSE` option to
|
||||
control the behavior. CMake 3.23 enables that option by default for
|
||||
compatibility with older versions. CMake 3.24 and above prefer to *not*
|
||||
enable the :variable:`CPACK_DMG_SLA_USE_RESOURCE_FILE_LICENSE` option by
|
||||
default. This policy provides compatibility with projects that have not
|
||||
been updated to account for the lack of a SLA in their ``.dmg`` packages.
|
||||
|
||||
The ``OLD`` behavior for this policy is to enable
|
||||
:variable:`CPACK_DMG_SLA_USE_RESOURCE_FILE_LICENSE` by default.
|
||||
The ``NEW`` behavior for this policy is to not enable it by default.
|
||||
|
||||
This policy was introduced in CMake version 3.24. Use the
|
||||
:command:`cmake_policy` command to set this policy to ``OLD`` or ``NEW``
|
||||
explicitly. Unlike many policies, CMake version |release| does *not* warn
|
||||
by default when this policy is not set and simply uses ``OLD`` behavior.
|
||||
See documentation of the
|
||||
:variable:`CMAKE_POLICY_WARNING_CMP0133 <CMAKE_POLICY_WARNING_CMP<NNNN>>`
|
||||
variable to control the warning.
|
||||
|
||||
.. include:: DEPRECATED.txt
|
@ -0,0 +1,39 @@
|
||||
CMP0134
|
||||
-------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
The default registry view is ``TARGET`` for the :command:`find_file`,
|
||||
:command:`find_path`, :command:`find_library`, and :command:`find_package`
|
||||
commands and ``BOTH`` for the :command:`find_program` command.
|
||||
|
||||
The default registry views in CMake 3.23 and below are selected using the
|
||||
following rules:
|
||||
|
||||
* if :variable:`CMAKE_SIZEOF_VOID_P` has value ``8``:
|
||||
|
||||
* Use view ``64`` for all ``find_*`` commands except :command:`find_program`
|
||||
command.
|
||||
* Use view ``64_32`` for :command:`find_program` command.
|
||||
|
||||
* if :variable:`CMAKE_SIZEOF_VOID_P` has value ``4`` or is undefined:
|
||||
|
||||
* Use view ``32`` for all ``find_*`` commands except :command:`find_program`
|
||||
command.
|
||||
* Use view ``32_64`` for :command:`find_program` command.
|
||||
|
||||
The ``OLD`` behavior for this policy is to use registry views ``64`` and
|
||||
``64_32`` or ``32_64`` and ``32`` as default, depending of
|
||||
:variable:`CMAKE_SIZEOF_VOID_P` variable value.
|
||||
The ``NEW`` behavior for this policy is to use registry views ``TARGET`` and
|
||||
``BOTH`` as default.
|
||||
|
||||
This policy was introduced in CMake version 3.24. Use the
|
||||
:command:`cmake_policy` command to set this policy to ``OLD`` or ``NEW``
|
||||
explicitly. Unlike many policies, CMake version |release| does *not* warn
|
||||
by default when this policy is not set and simply uses ``OLD`` behavior.
|
||||
See documentation of the
|
||||
:variable:`CMAKE_POLICY_WARNING_CMP0133 <CMAKE_POLICY_WARNING_CMP<NNNN>>`
|
||||
variable to control the warning.
|
||||
|
||||
.. include:: DEPRECATED.txt
|
@ -0,0 +1,29 @@
|
||||
CMP0135
|
||||
-------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
When using the ``URL`` download method with the :command:`ExternalProject_Add`
|
||||
command, CMake 3.23 and below sets the timestamps of the extracted contents
|
||||
to the same as the timestamps in the archive. When the ``URL`` changes, the
|
||||
new archive is downloaded and extracted, but the timestamps of the extracted
|
||||
contents might not be newer than the previous contents. Anything that depends
|
||||
on the extracted contents might not be rebuilt, even though the contents may
|
||||
change.
|
||||
|
||||
CMake 3.24 and above prefers to set the timestamps of all extracted contents
|
||||
to the time of the extraction. This ensures that anything that depends on the
|
||||
extracted contents will be rebuilt whenever the ``URL`` changes.
|
||||
|
||||
The ``DOWNLOAD_EXTRACT_TIMESTAMP`` option to the
|
||||
:command:`ExternalProject_Add` command can be used to explicitly specify how
|
||||
timestamps should be handled. When ``DOWNLOAD_EXTRACT_TIMESTAMP`` is not
|
||||
given, this policy controls the default behavior. The ``OLD`` behavior for
|
||||
this policy is to restore the timestamps from the archive. The ``NEW``
|
||||
behavior sets the timestamps of extracted contents to the time of extraction.
|
||||
|
||||
This policy was introduced in CMake version 3.24. CMake version |release|
|
||||
warns when the policy is not set and uses ``OLD`` behavior. Use the
|
||||
:command:`cmake_policy` command to set it to ``OLD`` or ``NEW`` explicitly.
|
||||
|
||||
.. include:: DEPRECATED.txt
|
@ -0,0 +1,50 @@
|
||||
CMP0136
|
||||
-------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
Watcom runtime library flags are selected by an abstraction.
|
||||
|
||||
Compilers targeting the Watcom ABI have flags to select the Watcom runtime
|
||||
library.
|
||||
|
||||
In CMake 3.23 and below, Watcom runtime library selection flags are added to
|
||||
the default :variable:`CMAKE_<LANG>_FLAGS_<CONFIG>` cache entries by CMake
|
||||
automatically. This allows users to edit their cache entries to adjust the
|
||||
flags. However, the presence of such default flags is problematic for
|
||||
projects that want to choose a different runtime library programmatically.
|
||||
In particular, it requires string editing of the
|
||||
:variable:`CMAKE_<LANG>_FLAGS_<CONFIG>` variables with knowledge of the
|
||||
CMake builtin defaults so they can be replaced.
|
||||
|
||||
CMake 3.24 and above prefer to leave the Watcom runtime library selection flags
|
||||
out of the default :variable:`CMAKE_<LANG>_FLAGS_<CONFIG>` values and instead
|
||||
offer a first-class abstraction. The :variable:`CMAKE_WATCOM_RUNTIME_LIBRARY`
|
||||
variable and :prop_tgt:`WATCOM_RUNTIME_LIBRARY` target property may be set to
|
||||
select the Watcom runtime library. If they are not set then CMake uses the
|
||||
default value ``MultiThreadedDLL`` on Windows and ``SingleThreaded`` on other
|
||||
platforms, which is equivalent to the original flags.
|
||||
|
||||
This policy provides compatibility with projects that have not been updated
|
||||
to be aware of the abstraction. The policy setting takes effect as of the
|
||||
first :command:`project` or :command:`enable_language` command that enables
|
||||
a language whose compiler targets the Watcom ABI.
|
||||
|
||||
.. note::
|
||||
|
||||
Once the policy has taken effect at the top of a project, that choice
|
||||
must be used throughout the tree. In projects that have nested projects
|
||||
in subdirectories, be sure to convert everything together.
|
||||
|
||||
The ``OLD`` behavior for this policy is to place Watcom runtime library
|
||||
flags in the default :variable:`CMAKE_<LANG>_FLAGS_<CONFIG>` cache
|
||||
entries and ignore the :variable:`CMAKE_WATCOM_RUNTIME_LIBRARY` abstraction.
|
||||
The ``NEW`` behavior for this policy is to *not* place Watcom runtime
|
||||
library flags in the default cache entries and use the abstraction instead.
|
||||
|
||||
This policy was introduced in CMake version 3.24. Use the
|
||||
:command:`cmake_policy` command to set it to ``OLD`` or ``NEW`` explicitly.
|
||||
Unlike many policies, CMake version |release| does *not* warn
|
||||
when this policy is not set and simply uses ``OLD`` behavior.
|
||||
|
||||
.. include:: DEPRECATED.txt
|
@ -0,0 +1,33 @@
|
||||
CMP0137
|
||||
-------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
:command:`try_compile` passes platform variables in project mode.
|
||||
|
||||
The :command:`try_compile` command :ref:`source file <Try Compiling Source
|
||||
Files>` signature propagates CMake variables containing platform settings,
|
||||
and those specified by the :variable:`CMAKE_TRY_COMPILE_PLATFORM_VARIABLES`
|
||||
variable, into the generated test project. This helps the test project drive
|
||||
the toolchain the same way the calling project will. In CMake 3.23 and below,
|
||||
the :ref:`whole-project <Try Compiling Whole Projects>` signature does not
|
||||
propagate platform variables automatically. CMake 3.24 and above prefer to
|
||||
propagate platform variables in the :ref:`whole-project <Try Compiling Whole
|
||||
Projects>` signature. This policy provides compatibility with projects that
|
||||
have not been updated to expect the behavior.
|
||||
|
||||
The ``OLD`` behavior for this policy is to not pass any additional variables to
|
||||
the :ref:`whole-project <Try Compiling Whole Projects>` signature.
|
||||
The ``NEW`` behavior for this policy is to pass the same variables that the
|
||||
:ref:`source file <Try Compiling Source Files>` signature does.
|
||||
|
||||
Regardless of the policy setting, the
|
||||
:variable:`CMAKE_TRY_COMPILE_NO_PLATFORM_VARIABLES` variable may be set
|
||||
to suppress passing the platform variables through either signature.
|
||||
|
||||
This policy was introduced in CMake version 3.24. Use the
|
||||
:command:`cmake_policy` command to set this policy to ``OLD`` or ``NEW``
|
||||
explicitly. Unlike many policies, CMake version |release| does *not* warn
|
||||
by default when this policy is not set and simply uses ``OLD`` behavior.
|
||||
|
||||
.. include:: DEPRECATED.txt
|
@ -0,0 +1,31 @@
|
||||
CMP0138
|
||||
-------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
:module:`CheckIPOSupported` uses flags from calling project.
|
||||
|
||||
The :module:`CheckIPOSupported` module :command:`check_ipo_supported`
|
||||
command compiles a test project to determine whether the toolchain
|
||||
supports :prop_tgt:`INTERPROCEDURAL_OPTIMIZATION`. CMake 3.23 and
|
||||
below run the check with the default values of the
|
||||
:variable:`CMAKE_<LANG>_FLAGS` and :variable:`CMAKE_<LANG>_FLAGS_<CONFIG>`
|
||||
variables for the current environment and toolchain settings.
|
||||
However, some projects may modify these flag variables to add
|
||||
flags that affect availability of the toolchain's IPO features.
|
||||
CMake 3.24 and above prefer to honor the calling project's values
|
||||
for these variables. This policy provides compatibility for projects
|
||||
that have not been updated to expect this behavior.
|
||||
|
||||
The ``OLD`` behavior for this policy is to ignore the calling
|
||||
project's values of :variable:`CMAKE_<LANG>_FLAGS` and
|
||||
:variable:`CMAKE_<LANG>_FLAGS_<CONFIG>`. The ``NEW`` behavior
|
||||
for this policy is to use the values of those variables as
|
||||
compiler flags in the test project.
|
||||
|
||||
This policy was introduced in CMake version 3.24. Use the
|
||||
:command:`cmake_policy` command to set it to ``OLD`` or ``NEW`` explicitly.
|
||||
Unlike many policies, CMake version |release| does *not* warn
|
||||
when this policy is not set and simply uses ``OLD`` behavior.
|
||||
|
||||
.. include:: DEPRECATED.txt
|
@ -0,0 +1,17 @@
|
||||
CMP0139
|
||||
-------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
The :command:`if` command supports path comparisons using ``PATH_EQUAL``
|
||||
operator.
|
||||
|
||||
The ``OLD`` behavior for this policy is to ignore the ``PATH_EQUAL`` operator.
|
||||
The ``NEW`` behavior is to interpret the ``PATH_EQUAL`` operator.
|
||||
|
||||
This policy was introduced in CMake version 3.24.
|
||||
CMake version |release| warns when the policy is not set and uses
|
||||
``OLD`` behavior. Use the :command:`cmake_policy` command to set
|
||||
it to ``OLD`` or ``NEW`` explicitly.
|
||||
|
||||
.. include:: DEPRECATED.txt
|
@ -0,0 +1,10 @@
|
||||
COMPILE_WARNING_AS_ERROR
|
||||
------------------------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
Specify whether to treat warnings on compile as errors.
|
||||
If enabled, adds a flag to treat warnings on compile as errors.
|
||||
|
||||
This property is initialized by the value of the variable
|
||||
:variable:`CMAKE_COMPILE_WARNING_AS_ERROR` if it is set when a target is created.
|
@ -0,0 +1,13 @@
|
||||
INTERFACE_HEADER_SETS_TO_VERIFY
|
||||
-------------------------------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
Used to specify which ``PUBLIC`` and ``INTERFACE`` header sets of a target
|
||||
should be verified.
|
||||
|
||||
This property contains a semicolon-separated list of header sets which
|
||||
should be verified if :prop_tgt:`VERIFY_INTERFACE_HEADER_SETS` is set to
|
||||
``TRUE``. If the list is empty, all ``PUBLIC`` and ``INTERFACE`` header sets
|
||||
are verified. (If the project does not want to verify any header sets on the
|
||||
target, simply set :prop_tgt:`VERIFY_INTERFACE_HEADER_SETS` to ``FALSE``.)
|
@ -0,0 +1,236 @@
|
||||
INTERFACE_LINK_LIBRARIES_DIRECT
|
||||
-------------------------------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
List of libraries that consumers of this library should treat
|
||||
as direct link dependencies.
|
||||
|
||||
This target property may be set to *include* items in a dependent
|
||||
target's final set of direct link dependencies. See the
|
||||
:prop_tgt:`INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE` target property
|
||||
to exclude items.
|
||||
|
||||
The initial set of a dependent target's direct link dependencies is
|
||||
specified by its :prop_tgt:`LINK_LIBRARIES` target property. Indirect
|
||||
link dependencies are specified by the transitive closure of the direct
|
||||
link dependencies' :prop_tgt:`INTERFACE_LINK_LIBRARIES` properties.
|
||||
Any link dependency may specify additional direct link dependencies
|
||||
using the ``INTERFACE_LINK_LIBRARIES_DIRECT`` target property.
|
||||
The set of direct link dependencies is then filtered to exclude items named
|
||||
by any dependency's :prop_tgt:`INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE`
|
||||
target property.
|
||||
|
||||
.. |INTERFACE_PROPERTY_LINK_DIRECT| replace:: ``INTERFACE_LINK_LIBRARIES_DIRECT``
|
||||
.. include:: INTERFACE_LINK_LIBRARIES_DIRECT.txt
|
||||
|
||||
Direct Link Dependencies as Usage Requirements
|
||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
The ``INTERFACE_LINK_LIBRARIES_DIRECT`` and
|
||||
``INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE`` target properties
|
||||
are :ref:`usage requirements <Target Usage Requirements>`.
|
||||
Their effects propagate to dependent targets transitively, and can
|
||||
therefore affect the direct link dependencies of every target in a
|
||||
chain of dependent libraries. Whenever some library target ``X`` links
|
||||
to another library target ``Y`` whose direct or transitive usage
|
||||
requirements contain ``INTERFACE_LINK_LIBRARIES_DIRECT`` or
|
||||
``INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE``, the properties may affect
|
||||
``X``'s list of direct link dependencies:
|
||||
|
||||
* If ``X`` is a shared library or executable, its dependencies are linked.
|
||||
They also affect the usage requirements with which ``X``'s sources are
|
||||
compiled.
|
||||
|
||||
* If ``X`` is a static library or object library, it does not actually
|
||||
link, so its dependencies at most affect the usage requirements with
|
||||
which ``X``'s sources are compiled.
|
||||
|
||||
The properties may also affect the list of direct link dependencies
|
||||
on ``X``'s dependents:
|
||||
|
||||
* If ``X`` links ``Y`` publicly:
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
target_link_libraries(X PUBLIC Y)
|
||||
|
||||
then ``Y`` is placed in ``X``'s :prop_tgt:`INTERFACE_LINK_LIBRARIES`,
|
||||
so ``Y``'s usage requirements, including ``INTERFACE_LINK_LIBRARIES_DIRECT``,
|
||||
``INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE``, and the usage requirements
|
||||
declared by the direct link dependencies they add, are propagated to
|
||||
``X``'s dependents.
|
||||
|
||||
* If ``X`` is a static library or object library, and links ``Y`` privately:
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
target_link_libraries(X PRIVATE Y)
|
||||
|
||||
then ``$<LINK_ONLY:Y>`` is placed in ``X``'s
|
||||
:prop_tgt:`INTERFACE_LINK_LIBRARIES`. ``Y``'s linking requirements,
|
||||
including ``INTERFACE_LINK_LIBRARIES_DIRECT``,
|
||||
``INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE``, and the transitive link
|
||||
dependencies declared by the direct link dependencies they add, are
|
||||
propagated to ``X``'s dependents. However, ``Y``'s non-linking
|
||||
usage requirements are blocked by the :genex:`LINK_ONLY` generator
|
||||
expression, and are not propagated to ``X``'s dependents.
|
||||
|
||||
* If ``X`` is a shared library or executable, and links ``Y`` privately:
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
target_link_libraries(X PRIVATE Y)
|
||||
|
||||
then ``Y`` is not placed in ``X``'s :prop_tgt:`INTERFACE_LINK_LIBRARIES`,
|
||||
so ``Y``'s usage requirements, even ``INTERFACE_LINK_LIBRARIES_DIRECT``
|
||||
and ``INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE``, are not propagated to
|
||||
``X``'s dependents.
|
||||
|
||||
* In all cases, the content of ``X``'s :prop_tgt:`INTERFACE_LINK_LIBRARIES`
|
||||
is not affected by ``Y``'s ``INTERFACE_LINK_LIBRARIES_DIRECT`` or
|
||||
``INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE``.
|
||||
|
||||
One may limit the effects of ``INTERFACE_LINK_LIBRARIES_DIRECT`` and
|
||||
``INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE`` to a subset of dependent
|
||||
targets by using the :genex:`TARGET_PROPERTY` generator expression.
|
||||
For example, to limit the effects to executable targets, use an
|
||||
entry of the form::
|
||||
|
||||
"$<$<STREQUAL:$<TARGET_PROPERTY:TYPE>,EXECUTABLE>:...>"
|
||||
|
||||
Similarly, to limit the effects to specific targets, use an entry
|
||||
of the form::
|
||||
|
||||
"$<$<BOOL:$<TARGET_PROPERTY:USE_IT>>:...>"
|
||||
|
||||
This entry will only affect targets that set their ``USE_IT``
|
||||
target property to a true value.
|
||||
|
||||
Direct Link Dependency Ordering
|
||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
The list of direct link dependencies for a target is computed from an
|
||||
initial ordered list in its :prop_tgt:`LINK_LIBRARIES` target property.
|
||||
For each item, additional direct link dependencies are discovered from
|
||||
its direct and transitive ``INTERFACE_LINK_LIBRARIES_DIRECT`` usage
|
||||
requirements. Each discovered item is injected before the item that
|
||||
specified it. However, a discovered item is added at most once,
|
||||
and only if it did not appear anywhere in the initial list.
|
||||
This gives :prop_tgt:`LINK_LIBRARIES` control over ordering of
|
||||
those direct link dependencies that it explicitly specifies.
|
||||
|
||||
Once all direct link dependencies have been collected, items named by
|
||||
all of their :prop_tgt:`INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE`
|
||||
usage requirements are removed from the final list. This does not
|
||||
affect the order of the items that remain.
|
||||
|
||||
Example: Static Plugins
|
||||
^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
Consider a static library ``Foo`` that provides a static plugin
|
||||
``FooPlugin`` to consuming application executables, where the
|
||||
implementation of the plugin depends on ``Foo`` and other things.
|
||||
In this case, the application should link to ``FooPlugin`` directly,
|
||||
before ``Foo``. However, the application author only knows about ``Foo``.
|
||||
We can express this as follows:
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
# Core library used by other components.
|
||||
add_library(Core STATIC core.cpp)
|
||||
|
||||
# Foo is a static library for use by applications.
|
||||
# Implementation of Foo depends on Core.
|
||||
add_library(Foo STATIC foo.cpp foo_plugin_helper.cpp)
|
||||
target_link_libraries(Foo PRIVATE Core)
|
||||
|
||||
# Extra parts of Foo for use by its static plugins.
|
||||
# Implementation of Foo's extra parts depends on both Core and Foo.
|
||||
add_library(FooExtras STATIC foo_extras.cpp)
|
||||
target_link_libraries(FooExtras PRIVATE Core Foo)
|
||||
|
||||
# The Foo library has an associated static plugin
|
||||
# that should be linked into the final executable.
|
||||
# Implementation of the plugin depends on Core, Foo, and FooExtras.
|
||||
add_library(FooPlugin STATIC foo_plugin.cpp)
|
||||
target_link_libraries(FooPlugin PRIVATE Core Foo FooExtras)
|
||||
|
||||
# An app that links Foo should link Foo's plugin directly.
|
||||
set_property(TARGET Foo PROPERTY INTERFACE_LINK_LIBRARIES_DIRECT FooPlugin)
|
||||
|
||||
# An app does not need to link Foo directly because the plugin links it.
|
||||
set_property(TARGET Foo PROPERTY INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE Foo)
|
||||
|
||||
An application ``app`` only needs to specify that it links to ``Foo``:
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
add_executable(app main.cpp)
|
||||
target_link_libraries(app PRIVATE Foo)
|
||||
|
||||
The ``INTERFACE_LINK_LIBRARIES_DIRECT`` target property on ``Foo`` tells
|
||||
CMake to pretend that ``app`` also links directly to ``FooPlugin``.
|
||||
The ``INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE`` target property on ``Foo``
|
||||
tells CMake to pretend that ``app`` did *not* link directly to ``Foo``.
|
||||
Instead, ``Foo`` will be linked as a dependency of ``FooPlugin``. The
|
||||
final link line for ``app`` will link the libraries in the following
|
||||
order:
|
||||
|
||||
* ``FooPlugin`` as a direct link dependency of ``app``
|
||||
(via ``Foo``'s usage requirements).
|
||||
* ``FooExtras`` as a dependency of ``FooPlugin``.
|
||||
* ``Foo`` as a dependency of ``FooPlugin`` and ``FooExtras``.
|
||||
* ``Core`` as a dependency of ``FooPlugin``, ``FooExtras``, and ``Foo``.
|
||||
|
||||
Note that without the ``INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE`` target
|
||||
property, ``Foo`` would be linked twice: once as a direct dependency
|
||||
of ``app``, and once as a dependency of ``FooPlugin``.
|
||||
|
||||
Example: Opt-In Static Plugins
|
||||
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
||||
|
||||
In the above `Example: Static Plugins`_, the ``app`` executable specifies
|
||||
that it links directly to ``Foo``. In a real application, there might
|
||||
be an intermediate library:
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
add_library(app_impl STATIC app_impl.cpp)
|
||||
target_link_libraries(app_impl PRIVATE Foo)
|
||||
|
||||
add_executable(app main.cpp)
|
||||
target_link_libraries(app PRIVATE app_impl)
|
||||
|
||||
In this case we do not want ``Foo``'s ``INTERFACE_LINK_LIBRARIES_DIRECT``
|
||||
and ``INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE`` target properties to affect
|
||||
the direct dependencies of ``app_impl``. To avoid this, we can revise
|
||||
the property values to make their effects opt-in:
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
# An app that links Foo should link Foo's plugin directly.
|
||||
set_property(TARGET Foo PROPERTY INTERFACE_LINK_LIBRARIES_DIRECT
|
||||
"$<$<BOOL:$<TARGET_PROPERTY:FOO_STATIC_PLUGINS>>:FooPlugin>"
|
||||
)
|
||||
|
||||
# An app does not need to link Foo directly because the plugin links it.
|
||||
set_property(TARGET Foo PROPERTY INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE
|
||||
"$<$<BOOL:$<TARGET_PROPERTY:FOO_STATIC_PLUGINS>>:Foo>"
|
||||
)
|
||||
|
||||
Now, the ``app`` executable can opt-in to get ``Foo``'s plugin(s):
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
set_property(TARGET app PROPERTY FOO_STATIC_PLUGINS 1)
|
||||
|
||||
The final link line for ``app`` will now link the libraries in the following
|
||||
order:
|
||||
|
||||
* ``FooPlugin`` as a direct link dependency of ``app``
|
||||
(via ``Foo``'s usage requirements).
|
||||
* ``app_impl`` as a direct link dependency of ``app``.
|
||||
* ``FooExtras`` as a dependency of ``FooPlugin``.
|
||||
* ``Foo`` as a dependency of ``app_impl``, ``FooPlugin``, and ``FooExtras``.
|
||||
* ``Core`` as a dependency of ``FooPlugin``, ``FooExtras``, and ``Foo``.
|
@ -0,0 +1,9 @@
|
||||
The value of |INTERFACE_PROPERTY_LINK_DIRECT| may use
|
||||
:manual:`generator expressions <cmake-generator-expressions(7)>`.
|
||||
|
||||
.. note::
|
||||
|
||||
The |INTERFACE_PROPERTY_LINK_DIRECT| target property is intended for
|
||||
advanced use cases such as injection of static plugins into a consuming
|
||||
executable. It should not be used as a substitute for organizing
|
||||
normal calls to :command:`target_link_libraries`.
|
@ -0,0 +1,34 @@
|
||||
INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE
|
||||
---------------------------------------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
List of libraries that consumers of this library should *not* treat
|
||||
as direct link dependencies.
|
||||
|
||||
This target property may be set to *exclude* items from a dependent
|
||||
target's final set of direct link dependencies. This property is
|
||||
processed after the :prop_tgt:`INTERFACE_LINK_LIBRARIES_DIRECT`
|
||||
target property of all other dependencies of the dependent target, so
|
||||
exclusion from direct link dependence takes priority over inclusion.
|
||||
|
||||
The initial set of a dependent target's direct link dependencies is
|
||||
specified by its :prop_tgt:`LINK_LIBRARIES` target property. Indirect
|
||||
link dependencies are specified by the transitive closure of the direct
|
||||
link dependencies' :prop_tgt:`INTERFACE_LINK_LIBRARIES` properties.
|
||||
Any link dependency may specify additional direct link dependencies
|
||||
using the :prop_tgt:`INTERFACE_LINK_LIBRARIES_DIRECT` target property.
|
||||
The set of direct link dependencies is then filtered to exclude items named
|
||||
by any dependency's ``INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE`` target
|
||||
property.
|
||||
|
||||
Excluding an item from a dependent target's direct link dependencies
|
||||
does not mean the dependent target won't link the item. The item
|
||||
may still be linked as an indirect link dependency via the
|
||||
:prop_tgt:`INTERFACE_LINK_LIBRARIES` property on other dependencies.
|
||||
|
||||
.. |INTERFACE_PROPERTY_LINK_DIRECT| replace:: ``INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE``
|
||||
.. include:: INTERFACE_LINK_LIBRARIES_DIRECT.txt
|
||||
|
||||
See the :prop_tgt:`INTERFACE_LINK_LIBRARIES_DIRECT` target property
|
||||
documentation for more details and examples.
|
@ -0,0 +1,65 @@
|
||||
LINK_LIBRARY_OVERRIDE
|
||||
---------------------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
Override the library features associated with libraries from
|
||||
:genex:`LINK_LIBRARY` generator expressions. This can be used to resolve
|
||||
incompatible library features that result from specifying different features
|
||||
for the same library in different :genex:`LINK_LIBRARY` generator expressions.
|
||||
|
||||
This property supports overriding multiple libraries and features. It expects
|
||||
a :ref:`semicolon-separated list <CMake Language Lists>`, where each list item
|
||||
has the following form::
|
||||
|
||||
feature[,link-item]*
|
||||
|
||||
For each comma-separated ``link-item``, any existing library feature associated
|
||||
with it will be ignored for the target this property is set on. The item
|
||||
will instead be associated with the specified ``feature``. Each ``link-item``
|
||||
can be anything that would be accepted as part of a ``library-list`` in a
|
||||
:genex:`LINK_LIBRARY` generator expression.
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
add_library(lib1 ...)
|
||||
add_library(lib2 ...)
|
||||
add_library(lib3 ...)
|
||||
|
||||
target_link_libraries(lib1 PUBLIC "$<LINK_LIBRARY:feature1,external>")
|
||||
target_link_libraries(lib2 PUBLIC "$<LINK_LIBRARY:feature2,lib1>")
|
||||
target_link_libraries(lib3 PRIVATE lib1 lib2)
|
||||
|
||||
# lib1 is associated with both feature2 and no feature. Without any override,
|
||||
# this would result in a fatal error at generation time for lib3.
|
||||
# Define an override to resolve the incompatible feature associations.
|
||||
set_property(TARGET lib3 PROPERTY LINK_LIBRARY_OVERRIDE "feature2,lib1,external")
|
||||
|
||||
# lib1 and external will now be associated with feature2 instead when linking lib3
|
||||
|
||||
It is also possible to override any feature with the pre-defined ``DEFAULT``
|
||||
library feature. This effectively discards any feature for that link item,
|
||||
for that target only (``lib3`` in this example):
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
# When linking lib3, discard any library feature for lib1, and use feature2 for external
|
||||
set_property(TARGET lib3 PROPERTY LINK_LIBRARY_OVERRIDE
|
||||
"DEFAULT,lib1"
|
||||
"feature2,external"
|
||||
)
|
||||
|
||||
The above example also demonstrates how to specify different feature overrides
|
||||
for different link items. See the :prop_tgt:`LINK_LIBRARY_OVERRIDE_<LIBRARY>`
|
||||
target property for an alternative way of overriding library features for
|
||||
individual libraries, which may be simpler in some cases. If both properties
|
||||
are defined and specify an override for the same link item,
|
||||
:prop_tgt:`LINK_LIBRARY_OVERRIDE_<LIBRARY>` takes precedence over
|
||||
``LINK_LIBRARY_OVERRIDE``.
|
||||
|
||||
Contents of ``LINK_LIBRARY_OVERRIDE`` may use
|
||||
:manual:`generator expressions <cmake-generator-expressions(7)>`.
|
||||
|
||||
For more information about library features, see the
|
||||
:variable:`CMAKE_<LANG>_LINK_LIBRARY_USING_<FEATURE>` and
|
||||
:variable:`CMAKE_LINK_LIBRARY_USING_<FEATURE>` variables.
|
@ -0,0 +1,51 @@
|
||||
LINK_LIBRARY_OVERRIDE_<LIBRARY>
|
||||
-------------------------------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
Override the library feature associated with ``<LIBRARY>`` from
|
||||
:genex:`LINK_LIBRARY` generator expressions. This can be used to resolve
|
||||
incompatible library features that result from specifying different features
|
||||
for ``<LIBRARY>`` in different :genex:`LINK_LIBRARY` generator expressions.
|
||||
|
||||
When set on a target, this property holds a single library feature name, which
|
||||
will be applied to ``<LIBRARY>`` when linking that target.
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
add_library(lib1 ...)
|
||||
add_library(lib2 ...)
|
||||
add_library(lib3 ...)
|
||||
|
||||
target_link_libraries(lib1 PUBLIC "$<LINK_LIBRARY:feature1,external>")
|
||||
target_link_libraries(lib2 PUBLIC "$<LINK_LIBRARY:feature2,lib1>")
|
||||
target_link_libraries(lib3 PRIVATE lib1 lib2)
|
||||
|
||||
# lib1 is associated with both feature2 and no feature. Without any override,
|
||||
# this would result in a fatal error at generation time for lib3.
|
||||
# Define an override to resolve the incompatible feature associations.
|
||||
set_property(TARGET lib3 PROPERTY LINK_LIBRARY_OVERRIDE_lib1 feature2)
|
||||
|
||||
# lib1 will now be associated with feature2 instead when linking lib3
|
||||
|
||||
It is also possible to override any feature with the pre-defined ``DEFAULT``
|
||||
library feature. This effectively discards any feature for that link item,
|
||||
for that target only (``lib3`` in this example):
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
# When linking lib3, discard any library feature for lib1
|
||||
set_property(TARGET lib3 PROPERTY LINK_LIBRARY_OVERRIDE_lib1 DEFAULT)
|
||||
|
||||
See the :prop_tgt:`LINK_LIBRARY_OVERRIDE` target property for an alternative
|
||||
way of overriding library features for multiple libraries at once. If both
|
||||
properties are defined and specify an override for the same link item,
|
||||
``LINK_LIBRARY_OVERRIDE_<LIBRARY>`` takes precedence over
|
||||
:prop_tgt:`LINK_LIBRARY_OVERRIDE`.
|
||||
|
||||
Contents of ``LINK_LIBRARY_OVERRIDE_<LIBRARY>`` may use
|
||||
:manual:`generator expressions <cmake-generator-expressions(7)>`.
|
||||
|
||||
For more information about library features, see the
|
||||
:variable:`CMAKE_<LANG>_LINK_LIBRARY_USING_<FEATURE>` and
|
||||
:variable:`CMAKE_LINK_LIBRARY_USING_<FEATURE>` variables.
|
@ -0,0 +1,38 @@
|
||||
VERIFY_INTERFACE_HEADER_SETS
|
||||
----------------------------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
Used to verify that all headers in a target's ``PUBLIC`` and ``INTERFACE``
|
||||
header sets can be included on their own.
|
||||
|
||||
When this property is set to true, and the target is an object library, static
|
||||
library, shared library, interface library, or executable with exports enabled,
|
||||
and the target has one or more ``PUBLIC`` or ``INTERFACE`` header sets, an
|
||||
object library target named ``<target_name>_verify_interface_header_sets`` is
|
||||
created. This verification target has one source file per header in the
|
||||
``PUBLIC`` and ``INTERFACE`` header sets. Each source file only includes its
|
||||
associated header file. The verification target links against the original
|
||||
target to get all of its usage requirements. The verification target has its
|
||||
:prop_tgt:`EXCLUDE_FROM_ALL` and :prop_tgt:`DISABLE_PRECOMPILE_HEADERS`
|
||||
properties set to true, and its :prop_tgt:`AUTOMOC`, :prop_tgt:`AUTORCC`,
|
||||
:prop_tgt:`AUTOUIC`, and :prop_tgt:`UNITY_BUILD` properties set to false.
|
||||
|
||||
If the header's :prop_sf:`LANGUAGE` property is set, the value of that property
|
||||
is used to determine the language with which to compile the header file.
|
||||
Otherwise, if the target has any C++ sources, the header is compiled as C++.
|
||||
Otherwise, if the target has any C sources, the header is compiled as C.
|
||||
Otherwise, if C++ is enabled globally, the header is compiled as C++.
|
||||
Otherwise, if C is enabled globally, the header is compiled as C. Otherwise,
|
||||
the header file is not compiled.
|
||||
|
||||
If any verification targets are created, a top-level target called
|
||||
``all_verify_interface_header_sets`` is created which depends on all
|
||||
verification targets.
|
||||
|
||||
This property is initialized by the value of the
|
||||
:variable:`CMAKE_VERIFY_INTERFACE_HEADER_SETS` variable if it is set when
|
||||
a target is created.
|
||||
|
||||
If the project wishes to control which header sets are verified by this
|
||||
property, it can set :prop_tgt:`INTERFACE_HEADER_SETS_TO_VERIFY`.
|
@ -0,0 +1,21 @@
|
||||
VS_DOTNET_STARTUP_OBJECT
|
||||
------------------------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
Sets the startup object property in Visual Studio .NET targets.
|
||||
The property value defines a full qualified class name (including package
|
||||
name), for example: ``MyCompany.Package.MyStarterClass``.
|
||||
|
||||
If the property is unset, Visual Studio uses the first matching
|
||||
``static void Main(string[])`` function signature by default. When more
|
||||
than one ``Main()`` method is available in the current project, the property
|
||||
becomes mandatory for building the project.
|
||||
|
||||
This property only works for Visual Studio 2010 and above;
|
||||
it is ignored on other generators.
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
set_property(TARGET ${TARGET_NAME} PROPERTY
|
||||
VS_DOTNET_STARTUP_OBJECT "MyCompany.Package.MyStarterClass")
|
@ -0,0 +1,24 @@
|
||||
VS_NO_COMPILE_BATCHING
|
||||
----------------------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
Turn off compile batching for the target. Usually MSBuild calls the compiler
|
||||
with multiple c/cpp files and compiler starts subprocesses for each file to
|
||||
make the build parallel. If you want compiler to be invoked with one file at
|
||||
a time set ``VS_NO_COMPILE_BATCHING`` to ON. If this flag is set MSBuild will
|
||||
call compiler with one c/cpp file at a time. Useful when you want to use tool
|
||||
that replaces the compiler, for example some build caching tool.
|
||||
|
||||
This property is initialized by the :variable:`CMAKE_VS_NO_COMPILE_BATCHING`
|
||||
variable if it is set when a target is created.
|
||||
|
||||
Example
|
||||
^^^^^^^
|
||||
|
||||
This shows setting the property for the target ``foo``.
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
add_library(foo SHARED foo.cpp)
|
||||
set_property(TARGET foo PROPERTY VS_NO_COMPILE_BATCHING ON)
|
@ -0,0 +1,20 @@
|
||||
``SingleThreaded``
|
||||
Compile without additional flags to use a single-threaded
|
||||
statically-linked runtime library.
|
||||
``SingleThreadedDLL``
|
||||
Compile with ``-br`` or equivalent flag(s) to use a single-threaded
|
||||
dynamically-linked runtime library. This is not available for Linux
|
||||
targets.
|
||||
``MultiThreaded``
|
||||
Compile with ``-bm`` or equivalent flag(s) to use a multi-threaded
|
||||
statically-linked runtime library.
|
||||
``MultiThreadedDLL``
|
||||
Compile with ``-bm -br`` or equivalent flag(s) to use a multi-threaded
|
||||
dynamically-linked runtime library. This is not available for Linux
|
||||
targets.
|
||||
|
||||
The value is ignored on non-Watcom compilers but an unsupported value will
|
||||
be rejected as an error when using a compiler targeting the Watcom ABI.
|
||||
|
||||
The value may also be the empty string (``""``) in which case no runtime
|
||||
library selection flag will be added explicitly by CMake.
|
@ -0,0 +1,34 @@
|
||||
WATCOM_RUNTIME_LIBRARY
|
||||
----------------------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
Select the Watcom runtime library for use by compilers targeting the Watcom ABI.
|
||||
|
||||
The allowed values are:
|
||||
|
||||
.. include:: WATCOM_RUNTIME_LIBRARY-VALUES.txt
|
||||
|
||||
Use :manual:`generator expressions <cmake-generator-expressions(7)>` to
|
||||
support per-configuration specification.
|
||||
|
||||
For example, the code:
|
||||
|
||||
.. code-block:: cmake
|
||||
|
||||
add_executable(foo foo.c)
|
||||
set_property(TARGET foo PROPERTY
|
||||
WATCOM_RUNTIME_LIBRARY "MultiThreaded")
|
||||
|
||||
selects for the target ``foo`` a multi-threaded statically-linked runtime
|
||||
library.
|
||||
|
||||
If this property is not set then CMake uses the default value
|
||||
``MultiThreadedDLL`` on Windows and ``SingleThreaded`` on other
|
||||
platforms to select a Watcom runtime library.
|
||||
|
||||
.. note::
|
||||
|
||||
This property has effect only when policy :policy:`CMP0136` is set to ``NEW``
|
||||
prior to the first :command:`project` or :command:`enable_language` command
|
||||
that enables a language using a compiler targeting the Watcom ABI.
|
@ -0,0 +1,14 @@
|
||||
XCODE_XCCONFIG
|
||||
--------------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
If set, the :generator:`Xcode` generator will register the specified
|
||||
file as a target-level XCConfig file. For global XCConfig files see
|
||||
the :variable:`CMAKE_XCODE_XCCONFIG` variable.
|
||||
|
||||
This feature is intended to ease migration from native Xcode projects
|
||||
to CMake projects.
|
||||
|
||||
Contents of ``XCODE_XCCONFIG`` may use
|
||||
:manual:`generator expressions <cmake-generator-expressions(7)>`.
|
@ -0,0 +1,350 @@
|
||||
CMake 3.24 Release Notes
|
||||
************************
|
||||
|
||||
.. only:: html
|
||||
|
||||
.. contents::
|
||||
|
||||
Changes made since CMake 3.23 include the following.
|
||||
|
||||
New Features
|
||||
============
|
||||
|
||||
Presets
|
||||
-------
|
||||
|
||||
* :manual:`cmake-presets(7)` files now support schema version ``5``.
|
||||
|
||||
* :manual:`cmake-presets(7)` files now support a ``${pathListSep}`` macro,
|
||||
which expands to ``:`` or ``;`` based on the platform.
|
||||
|
||||
* :manual:`cmake-presets(7)` files gained support for specifying a
|
||||
``testOutputTruncation`` field in test presets, which specifies the
|
||||
truncation mode once the maximum test output size has been reached.
|
||||
|
||||
Generators
|
||||
----------
|
||||
|
||||
* The :generator:`Green Hills MULTI` generator now generates build
|
||||
rules to re-run CMake if any CMake files are updated.
|
||||
|
||||
* The :ref:`Visual Studio Generators` now support ``SYSTEM`` headers
|
||||
when using VS 2019 Update 11 or later.
|
||||
|
||||
Command-Line
|
||||
------------
|
||||
|
||||
* :manual:`cmake(1)` gained the ``--fresh`` command-line option to remove
|
||||
any existing ``CMakeCache.txt`` file and associated ``CMakeFiles/``
|
||||
directory, when configuring a build tree, thus starting a new configuration
|
||||
as if the build tree were freshly created.
|
||||
|
||||
* :manual:`cmake(1)` gained the ``--compile-no-warning-as-error`` command-line
|
||||
option which causes the effects of the :prop_tgt:`COMPILE_WARNING_AS_ERROR`
|
||||
target property and :variable:`CMAKE_COMPILE_WARNING_AS_ERROR` variable
|
||||
to be ignored.
|
||||
|
||||
* The :manual:`cmake(1)` ``--trace=json-v1`` trace format gained fields
|
||||
``global_frame`` and ``line_end``.
|
||||
|
||||
* The :manual:`cmake(1)` ``-E`` commands ``cat`` and ``env`` learned to respect
|
||||
a double dash (``--``) argument that acts as a delimiter indicating the end of
|
||||
options. Any following arguments are treated as operands/positional arguments,
|
||||
even if they begin with a dash ``-`` character.
|
||||
|
||||
* The :manual:`cmake(1)` ``-E tar`` command gained the ``--touch`` option
|
||||
to keep the current local timestamp instead of extracting file timestamps
|
||||
from the archive.
|
||||
|
||||
Compilers
|
||||
---------
|
||||
|
||||
* LLVM's `flang`_ Fortran compiler is now supported on some platforms,
|
||||
with compiler id ``LLVMFlang``.
|
||||
|
||||
.. _`flang`: https://github.com/llvm/llvm-project/tree/main/flang
|
||||
|
||||
* ADSP compiler support (SHARC and Blackfin) now covers both CCES and
|
||||
VDSP++ installations, with required configuration now done in the
|
||||
compiler module itself rather than the ``Generic-ADSP`` platform module.
|
||||
|
||||
Platforms
|
||||
---------
|
||||
|
||||
* A dedicated ``ADSP`` platform has been added
|
||||
to replace the existing ``Generic-ADSP`` implementation.
|
||||
This features automatic detection of the latest CCES/VDSP++ install
|
||||
and compiler selection (``cc21k`` vs. ``ccblkfn``)
|
||||
based off of the :variable:`CMAKE_SYSTEM_PROCESSOR` variable.
|
||||
|
||||
Commands
|
||||
--------
|
||||
|
||||
* The :command:`cmake_host_system_information` command, on Windows,
|
||||
gained a ``QUERY WINDOWS_REGISTRY`` mode.
|
||||
See its :ref:`Query Windows registry` section.
|
||||
|
||||
* The :command:`cmake_language` command gained a new
|
||||
``SET_DEPENDENCY_PROVIDER`` sub-command. When a dependency provider is set,
|
||||
calls to :command:`find_package` and :command:`FetchContent_MakeAvailable`
|
||||
can be redirected through a custom command, which can choose to fulfill the
|
||||
request directly, modify how the request is processed, or leave it to be
|
||||
fulfilled by the built-in implementation. See :ref:`dependency_providers`.
|
||||
|
||||
* The :command:`file(DOWNLOAD)` command gained options ``RANGE_START`` and
|
||||
``RANGE_END`` to specify a range of bytes to download. This can be
|
||||
useful for downloading parts of big binary files.
|
||||
|
||||
* The :command:`find_file`, :command:`find_path`, :command:`find_library`,
|
||||
:command:`find_program`, and :command:`find_package` commands gained the
|
||||
``NO_CMAKE_INSTALL_PREFIX`` option to control searching
|
||||
:variable:`CMAKE_INSTALL_PREFIX`.
|
||||
|
||||
* The :command:`find_file`, :command:`find_path`, :command:`find_library`,
|
||||
:command:`find_program`, and :command:`find_package` commands gained the
|
||||
ability to specify which Windows Registry views must be queried.
|
||||
|
||||
* The :command:`find_package` command gained a ``GLOBAL`` option that
|
||||
allows for the promotion of imported targets to global scope for the
|
||||
duration of the :command:`find_package` call.
|
||||
|
||||
* The :command:`if` command gained the capability to compare paths by
|
||||
using the ``PATH_EQUAL`` operator. See policy :policy:`CMP0139`.
|
||||
|
||||
Variables
|
||||
---------
|
||||
|
||||
* The :variable:`CMAKE_COLOR_DIAGNOSTICS` variable was added to control
|
||||
color diagnostics generated by compilers. This variable also controls
|
||||
color build system messages with :ref:`Makefile Generators`, replacing
|
||||
:variable:`CMAKE_COLOR_MAKEFILE`.
|
||||
|
||||
The :envvar:`CMAKE_COLOR_DIAGNOSTICS` environment variable was added to set
|
||||
a default value for :variable:`CMAKE_COLOR_DIAGNOSTICS`.
|
||||
|
||||
* The :variable:`CMAKE_COMPILE_WARNING_AS_ERROR` variable and corresponding
|
||||
:prop_tgt:`COMPILE_WARNING_AS_ERROR` target property were added to enable
|
||||
compilation with a compiler-specific flag to treat warnings as errors,
|
||||
such as ``-Werror``.
|
||||
|
||||
* The :variable:`CMAKE_CUDA_ARCHITECTURES` variable and associated
|
||||
:prop_tgt:`CUDA_ARCHITECTURES` target property now support the
|
||||
special ``native`` value to compile for the architectures(s)
|
||||
of the host's GPU(s).
|
||||
|
||||
* The :variable:`CMAKE_FIND_PACKAGE_TARGETS_GLOBAL` variable was added to
|
||||
toggle behavior of the :command:`find_package` command's new ``GLOBAL``
|
||||
option.
|
||||
|
||||
* The :variable:`CMAKE_FIND_USE_INSTALL_PREFIX` variable was added to toggle
|
||||
behavior of the :command:`find_file`, :command:`find_library`,
|
||||
:command:`find_path`, :command:`find_package`, and :command:`find_program`
|
||||
commands' new ``NO_CMAKE_INSTALL_PREFIX`` option.
|
||||
|
||||
* The :variable:`CMAKE_PROJECT_TOP_LEVEL_INCLUDES` variable was added to allow
|
||||
injecting custom code at the site of the first :command:`project` call,
|
||||
after the host and target platform details have been determined.
|
||||
|
||||
* The :variable:`CMAKE_TRY_COMPILE_NO_PLATFORM_VARIABLES` variable
|
||||
was added to tell the :command:`try_compile` command not to
|
||||
pass any platform variables to the test project.
|
||||
|
||||
* The :variable:`CMAKE_VERIFY_INTERFACE_HEADER_SETS` variable and
|
||||
corresponding :prop_tgt:`VERIFY_INTERFACE_HEADER_SETS` target property
|
||||
were added to enable build rules that verify all headers in header sets
|
||||
can be used on their own.
|
||||
|
||||
* The :variable:`CMAKE_VS_NO_COMPILE_BATCHING` variable and corresponding
|
||||
:prop_tgt:`VS_NO_COMPILE_BATCHING` target property were added to
|
||||
tell :ref:`Visual Studio Generators` whether to disable compiler
|
||||
parallelism and call the compiler with one source file at a time.
|
||||
|
||||
* The :variable:`CMAKE_WATCOM_RUNTIME_LIBRARY` variable and
|
||||
:prop_tgt:`WATCOM_RUNTIME_LIBRARY` target property were introduced to
|
||||
select the runtime library used by compilers targeting the Watcom ABI.
|
||||
See policy :policy:`CMP0136`.
|
||||
|
||||
* The :variable:`CMAKE_XCODE_XCCONFIG` variable and corresponding
|
||||
:prop_tgt:`XCODE_XCCONFIG` target property were added to tell
|
||||
the :generator:`Xcode` generator to handle ``xcconfig`` files.
|
||||
|
||||
Properties
|
||||
----------
|
||||
|
||||
* The :prop_tgt:`INTERFACE_LINK_LIBRARIES_DIRECT` and
|
||||
:prop_tgt:`INTERFACE_LINK_LIBRARIES_DIRECT_EXCLUDE` target properties
|
||||
were added to express usage requirements affecting a consumer's
|
||||
direct link dependencies.
|
||||
|
||||
* The :prop_tgt:`INTERFACE_HEADER_SETS_TO_VERIFY` target property was
|
||||
added to specify which header sets should be verified by
|
||||
:prop_tgt:`VERIFY_INTERFACE_HEADER_SETS`.
|
||||
|
||||
* The :prop_tgt:`LINK_LIBRARIES` target property now supports
|
||||
the :genex:`$<LINK_ONLY:...>` generator expression.
|
||||
See policy :policy:`CMP0131`.
|
||||
|
||||
* The :prop_tgt:`VS_DOTNET_STARTUP_OBJECT` target property was added to
|
||||
tell :ref:`Visual Studio Generators` which startup class shall be used
|
||||
when the program or project is executed. This is necessary when more
|
||||
than one ``static void Main(string[])`` function signature is available
|
||||
in a managed .NET project.
|
||||
|
||||
Modules
|
||||
-------
|
||||
|
||||
* The :module:`ExternalProject` module :command:`ExternalProject_Add`
|
||||
command gained a new ``DOWNLOAD_EXTRACT_TIMESTAMP`` option for
|
||||
controlling whether the timestamps of extracted contents are set to
|
||||
match those in the archive when the ``URL`` download method is used.
|
||||
Policy :policy:`CMP0135` was added to enable the option by default.
|
||||
|
||||
* The :module:`FetchContent` module and the :command:`find_package` command
|
||||
now support integration capabilities:
|
||||
|
||||
* :command:`FetchContent_MakeAvailable` can now try to satisfy a dependency
|
||||
by calling :command:`find_package` first. A new
|
||||
:variable:`FETCHCONTENT_TRY_FIND_PACKAGE_MODE` variable controls whether
|
||||
this is done by default for all dependencies, is opt-in per dependency,
|
||||
or is disabled entirely.
|
||||
|
||||
* :command:`find_package` can be re-routed to call
|
||||
:command:`FetchContent_MakeAvailable` instead. A new read-only
|
||||
:variable:`CMAKE_FIND_PACKAGE_REDIRECTS_DIR` variable points to a
|
||||
directory where config package files can be located to facilitate these
|
||||
re-routed calls.
|
||||
|
||||
* The :module:`FindJNI` module now provides imported targets.
|
||||
|
||||
* The :module:`FindMatlab` module :command:`matlab_add_mex` function
|
||||
gained a ``NO_IMPLICIT_LINK_TO_MATLAB_LIBRARIES`` option to disable
|
||||
automatic linking of MATLAB libraries.
|
||||
|
||||
* The :module:`FindVulkan` module now supports components to select which
|
||||
VulkanSDK tool and libraries to find in addition to the Vulkan SDK headers
|
||||
and library.
|
||||
|
||||
* The :module:`FindZLIB` gained a new ``ZLIB_USE_STATIC_LIBS`` variable to
|
||||
search only for static libraries.
|
||||
|
||||
Generator Expressions
|
||||
---------------------
|
||||
|
||||
* The :genex:`LINK_LIBRARY` generator expression was added to manage how
|
||||
libraries are specified during the link step.
|
||||
The :variable:`CMAKE_<LANG>_LINK_LIBRARY_USING_<FEATURE>` and
|
||||
:variable:`CMAKE_LINK_LIBRARY_USING_<FEATURE>` variables are used to define
|
||||
features usable by the :genex:`LINK_LIBRARY` generator expression.
|
||||
Moreover, the :prop_tgt:`LINK_LIBRARY_OVERRIDE` and
|
||||
:prop_tgt:`LINK_LIBRARY_OVERRIDE_<LIBRARY>` target properties are
|
||||
available to resolve incompatible features.
|
||||
|
||||
The :genex:`LINK_LIBRARY` generator expression can link frameworks in
|
||||
various ways when targeting ``Apple`` platforms.
|
||||
The following features were added:
|
||||
|
||||
* ``FRAMEWORK``
|
||||
* ``NEEDED_FRAMEWORK``
|
||||
* ``REEXPORT_FRAMEWORK``
|
||||
* ``WEAK_FRAMEWORK``
|
||||
|
||||
The :genex:`LINK_LIBRARY` generator expression can link libraries in
|
||||
various ways when targeting ``Apple`` platforms.
|
||||
The following features were added:
|
||||
|
||||
* ``NEEDED_LIBRARY``
|
||||
* ``REEXPORT_LIBRARY``
|
||||
* ``WEAK_LIBRARY``
|
||||
|
||||
The :genex:`LINK_LIBRARY` generator expression gained the feature
|
||||
``WHOLE_ARCHIVE`` to force load of all members in a static library.
|
||||
This feature is supported on the following target platforms:
|
||||
|
||||
* all ``Apple`` variants
|
||||
* ``Linux``
|
||||
* all ``BSD`` variants
|
||||
* ``SunOS``
|
||||
* ``Windows``
|
||||
* ``CYGWIN``
|
||||
* ``MSYS``
|
||||
|
||||
* The :genex:`LINK_GROUP` generator expression was added to manage the
|
||||
grouping of libraries during the link step. The
|
||||
:variable:`CMAKE_<LANG>_LINK_GROUP_USING_<FEATURE>` and
|
||||
:variable:`CMAKE_LINK_GROUP_USING_<FEATURE>` variables are used to define
|
||||
features usable with the :genex:`LINK_GROUP` generator expression.
|
||||
This release defines the ``RESCAN`` feature, which can be used to handle
|
||||
circular references among static libraries when using toolchains for
|
||||
Linux, BSD, SunOS and GNU toolchains for Windows.
|
||||
|
||||
* The :genex:`PATH` generator expression was added to manage paths.
|
||||
|
||||
* The :genex:`PATH_EQUAL` generator expression was added to manage path
|
||||
comparisons.
|
||||
|
||||
* The :genex:`TARGET_BUNDLE_DIR_NAME` generator expression
|
||||
was added to evaluate to the name of the bundle directory
|
||||
for a given bundle target.
|
||||
|
||||
CTest
|
||||
-----
|
||||
|
||||
* :manual:`ctest(1)` gained a ``--test-output-truncation`` option (and
|
||||
corresponding :variable:`CTEST_CUSTOM_TEST_OUTPUT_TRUNCATION` variable) to
|
||||
specify the truncation mode once the maximum test output size has been
|
||||
reached. Possible values are ``tail`` (default), ``middle`` or ``head``.
|
||||
|
||||
CPack
|
||||
-----
|
||||
|
||||
* The :cpack_gen:`CPack WIX Generator` gained a new variable,
|
||||
:variable:`CPACK_WIX_ARCHITECTURE`, to specify the installer architecture
|
||||
in order to support computers running Windows for ARM.
|
||||
|
||||
* CPack now supports the :variable:`CPACK_THREADS` option for ``zstd``
|
||||
compression when compiled with libarchive 3.6 or higher. It is
|
||||
supported by official CMake binaries available on `cmake.org`_.
|
||||
|
||||
Deprecated and Removed Features
|
||||
===============================
|
||||
|
||||
* The :module:`CPack` module no longer enables the SLA by default in the
|
||||
:cpack_gen:`CPack DragNDrop Generator`. See policy :policy:`CMP0133`
|
||||
and the :variable:`CPACK_DMG_SLA_USE_RESOURCE_FILE_LICENSE` variable.
|
||||
|
||||
* The deprecated :cpack_gen:`CPack PackageMaker Generator` has been removed.
|
||||
|
||||
* The :module:`FindGLUT` module no longer provides the undocumented
|
||||
``GLUT_LIBRARY`` and ``GLUT_INCLUDE_PATH`` result variables.
|
||||
|
||||
Other Changes
|
||||
=============
|
||||
|
||||
* CMake no longer sets environment variables like :envvar:`CC`, :envvar:`CXX`,
|
||||
etc. when enabling the corresponding language during the first CMake run in
|
||||
a build directory. See policy :policy:`CMP0132`.
|
||||
|
||||
* The :module:`CheckIPOSupported` module :command:`check_ipo_supported`
|
||||
command now uses the caller's :variable:`CMAKE_<LANG>_FLAGS`
|
||||
and :variable:`CMAKE_<LANG>_FLAGS_<CONFIG>` values.
|
||||
See policy :policy:`CMP0138`.
|
||||
|
||||
* The :generator:`MSYS Makefiles` and :generator:`MinGW Makefiles`
|
||||
generators, when a compiler is not explicitly specified, now select
|
||||
the first compiler (of any name) found in directories listed by the
|
||||
``PATH`` environment variable.
|
||||
|
||||
* The :command:`try_compile` command
|
||||
:ref:`whole-project <Try Compiling Whole Projects>` signature
|
||||
now propagates platform variables. See policy :policy:`CMP0137`.
|
||||
|
||||
* The :command:`while` command now diagnoses errors during condition
|
||||
evaluation. See policy :policy:`CMP0130`.
|
||||
|
||||
* The precompiled macOS binaries provided on `cmake.org`_ no longer attach a
|
||||
SLA to the ``.dmg`` packages. This was removed because macOS 12 deprecated
|
||||
the tools used to attach ``.dmg`` resources.
|
||||
|
||||
* A precompiled Windows ``arm64`` binary is now provided on `cmake.org`_.
|
||||
|
||||
.. _`cmake.org`: https://cmake.org/download/
|
@ -0,0 +1,11 @@
|
||||
CMAKE_ADSP_ROOT
|
||||
---------------
|
||||
|
||||
.. versionadded:: 3.24
|
||||
|
||||
When :ref:`Cross Compiling for ADSP SHARC/Blackfin`,
|
||||
this variable holds the absolute path to the latest CCES or VDSP++ install.
|
||||
The directory is expected to contain the ``cc21k.exe`` and ``ccblkfn.exe`` compilers.
|
||||
This will be set automatically if a default install of CCES or VDSP++ can be found.
|
||||
|
||||
See also the :envvar:`ADSP_ROOT` environment variable.
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in new issue