diff options
author | Brad King <brad.king@kitware.com> | 2024-10-23 13:59:18 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2024-10-23 14:09:22 (GMT) |
commit | 1e2b2b7fd291d3deb6db1dcd1a1e4d11babb1ed8 (patch) | |
tree | 36c0dee3574d8aeebbd0bb770df8357a2e07ed89 /Help | |
parent | 5b2351fb39f02a033ade4ab9fa2d2e9f3e58afbe (diff) | |
download | CMake-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.rst | 36 |
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``. |