2014-08-03 19:52:23 +02:00
|
|
|
add_dependencies
|
|
|
|
----------------
|
|
|
|
|
|
|
|
Add a dependency between top-level targets.
|
|
|
|
|
2019-11-11 23:01:05 +01:00
|
|
|
.. code-block:: cmake
|
2014-08-03 19:52:23 +02:00
|
|
|
|
|
|
|
add_dependencies(<target> [<target-dependency>]...)
|
|
|
|
|
2019-11-11 23:01:05 +01:00
|
|
|
Makes a top-level ``<target>`` depend on other top-level targets to
|
2015-08-17 11:37:30 +02:00
|
|
|
ensure that they build before ``<target>`` does. A top-level target
|
|
|
|
is one created by one of the :command:`add_executable`,
|
|
|
|
:command:`add_library`, or :command:`add_custom_target` commands
|
|
|
|
(but not targets generated by CMake like ``install``).
|
2014-08-03 19:52:23 +02:00
|
|
|
|
2015-08-17 11:37:30 +02:00
|
|
|
Dependencies added to an :ref:`imported target <Imported Targets>`
|
|
|
|
or an :ref:`interface library <Interface Libraries>` are followed
|
|
|
|
transitively in its place since the target itself does not build.
|
|
|
|
|
2021-09-14 00:13:48 +02:00
|
|
|
.. versionadded:: 3.3
|
|
|
|
Allow adding dependencies to interface libraries.
|
|
|
|
|
2024-07-09 14:46:46 +02:00
|
|
|
.. versionadded:: 3.8
|
|
|
|
Dependencies will populate the :prop_tgt:`MANUALLY_ADDED_DEPENDENCIES`
|
|
|
|
property of ``<target>``.
|
|
|
|
|
|
|
|
.. versionchanged:: 3.9
|
|
|
|
The :ref:`Ninja Generators` use weaker ordering than
|
|
|
|
other generators in order to improve available concurrency.
|
|
|
|
They only guarantee that the dependencies' custom commands are
|
|
|
|
finished before sources in ``<target>`` start compiling; this
|
|
|
|
ensures generated sources are available.
|
|
|
|
|
2023-05-23 16:38:00 +02:00
|
|
|
See Also
|
|
|
|
^^^^^^^^
|
|
|
|
|
|
|
|
* The ``DEPENDS`` option of :command:`add_custom_target` and
|
|
|
|
:command:`add_custom_command` commands for adding file-level
|
|
|
|
dependencies in custom rules.
|
|
|
|
|
|
|
|
* The :prop_sf:`OBJECT_DEPENDS` source file property to add
|
|
|
|
file-level dependencies to object files.
|