summaryrefslogtreecommitdiffstats
path: root/Help/variable/CMAKE_LINK_LIBRARIES_STRATEGY.rst
blob: 1ba6b27b9b4c8bfc8f1afaff8e8375e7cf599244 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
CMAKE_LINK_LIBRARIES_STRATEGY
-----------------------------

.. versionadded:: 3.31

Specify a strategy for ordering targets' direct link dependencies
on linker command lines.

The value of this variable initializes the :prop_tgt:`LINK_LIBRARIES_STRATEGY`
target property of targets as they are created.  Set that property directly
to specify a strategy for a single target.

CMake generates a target's link line using its :ref:`Target Link Properties`.
In particular, the :prop_tgt:`LINK_LIBRARIES` target property records the
target's direct link dependencies, typically populated by calls to
:command:`target_link_libraries`.  Indirect link dependencies are
propagated from those entries of :prop_tgt:`LINK_LIBRARIES` that name
library targets by following the transitive closure of their
:prop_tgt:`INTERFACE_LINK_LIBRARIES` properties.  CMake supports multiple
strategies for passing direct and indirect link dependencies to the linker.

Consider this example for the strategies below:

.. code-block:: cmake

  add_library(A STATIC ...)
  add_library(B STATIC ...)
  add_library(C STATIC ...)
  add_executable(main ...)
  target_link_libraries(B PRIVATE A)
  target_link_libraries(C PRIVATE A)
  target_link_libraries(main PRIVATE A B C)

The supported strategies are:

``PRESERVE_ORDER``
  Entries of :prop_tgt:`LINK_LIBRARIES` always appear first and in their
  original order.  Indirect link dependencies not satisfied by the
  original entries may be reordered and de-duplicated with respect to
  one another, but are always appended after the original entries.
  This may result in less efficient link lines, but gives projects
  control of ordering among independent entries.  Such control may be
  important when intermixing link flags with libraries, or when multiple
  libraries provide a given symbol.

  This is the default.

  In the above example, this strategy computes a link line for ``main``
  by starting with its original entries ``A B C``, and then appends
  another ``A`` to satisfy the dependencies of ``B`` and ``C`` on ``A``.
  The final order is ``A B C A``.

``REORDER``
  Entries of :prop_tgt:`LINK_LIBRARIES` may be reordered, de-duplicated,
  and intermixed with indirect link dependencies.  This may result in
  more efficient link lines, but does not give projects any control of
  ordering among independent entries.

  In the above example, this strategy computes a link line for ``main``
  by re-ordering its original entries ``A B C`` to satisfy the
  dependencies of ``B`` and ``C`` on ``A``.
  The final order is ``B C A``.

.. note::

  Regardless of the strategy used, the actual linker invocation for
  some platforms may de-duplicate entries based on linker capabilities.
  See policy :policy:`CMP0156`.