summaryrefslogtreecommitdiffstats
path: root/Help
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2024-10-23 13:59:18 (GMT)
committerBrad King <brad.king@kitware.com>2024-10-23 14:09:22 (GMT)
commit1e2b2b7fd291d3deb6db1dcd1a1e4d11babb1ed8 (patch)
tree36c0dee3574d8aeebbd0bb770df8357a2e07ed89 /Help
parent5b2351fb39f02a033ade4ab9fa2d2e9f3e58afbe (diff)
downloadCMake-1e2b2b7fd291d3deb6db1dcd1a1e4d11babb1ed8.zip
CMake-1e2b2b7fd291d3deb6db1dcd1a1e4d11babb1ed8.tar.gz
CMake-1e2b2b7fd291d3deb6db1dcd1a1e4d11babb1ed8.tar.bz2
Help: Clarify LINK_LIBRARIES_STRATEGY follow-up de-duplication
Extend discussion of the ``PRESERVE_ORDER`` example to prominently explain how platform-specific behavior can affect generated link lines. Closes: #26388
Diffstat (limited to 'Help')
-rw-r--r--Help/prop_tgt/LINK_LIBRARIES_STRATEGY.rst36
1 files changed, 26 insertions, 10 deletions
diff --git a/Help/prop_tgt/LINK_LIBRARIES_STRATEGY.rst b/Help/prop_tgt/LINK_LIBRARIES_STRATEGY.rst
index 7668366..13a5d52 100644
--- a/Help/prop_tgt/LINK_LIBRARIES_STRATEGY.rst
+++ b/Help/prop_tgt/LINK_LIBRARIES_STRATEGY.rst
@@ -4,7 +4,9 @@ LINK_LIBRARIES_STRATEGY
.. versionadded:: 3.31
Specify a strategy for ordering a target's direct link dependencies
-on linker command lines.
+on linker command lines. This property is initialized by the value of the
+:variable:`CMAKE_LINK_LIBRARIES_STRATEGY` variable if it is set when a
+target is created.
CMake generates a target's link line using its :ref:`Target Link Properties`.
In particular, the :prop_tgt:`LINK_LIBRARIES` target property records the
@@ -44,7 +46,11 @@ The supported strategies are:
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``.
+ The final order produced by this strategy is ``A B C A``.
+
+ Note that additional filtering for `Toolchain-Specific Behavior`_
+ may de-duplicate ``A`` on the actual linker invocation in the
+ generated build system, resulting in either ``A B C`` or ``B C A``.
``REORDER``
Entries of :prop_tgt:`LINK_LIBRARIES` may be reordered, de-duplicated,
@@ -55,14 +61,24 @@ The supported strategies are:
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``.
+ The final order produced by this strategy is ``B C A``.
-.. note::
+Toolchain-Specific Behavior
+^^^^^^^^^^^^^^^^^^^^^^^^^^^
- Regardless of the strategy used, the actual linker invocation for
- some platforms may de-duplicate entries based on linker capabilities.
- See policies :policy:`CMP0156` and :policy:`CMP0179`.
+Regardless of the strategy used, the actual linker invocation for
+some platforms may de-duplicate entries based on linker capabilities.
+See policy :policy:`CMP0156`.
-This property is initialized by the value of the
-:variable:`CMAKE_LINK_LIBRARIES_STRATEGY` variable if it is set when a
-target is created.
+For example, if the ``PRESERVE_ORDER`` strategy produces ``A B C A``,
+the actual link line may de-duplicate ``A`` as follows:
+
+* If ``A`` is a static library and the linker re-scans automatically,
+ the first occurrence is kept, resulting in ``A B C``.
+ See policy :policy:`CMP0179`
+
+* If ``A`` is a shared library on Windows, the first
+ occurrence is kept, resulting in ``A B C``.
+
+* If ``A`` is a shared library on macOS or UNIX platforms, the last
+ occurrence is kept, resulting in ``B C A``.