导航

  • 索引
  • 下一页 |
  • 上一页 |
  • CMake »
  • 3.26.4 Documentation »
  • cmake-属性(7) »
  • LINK_LIBRARY_OVERRIDE_<LIBRARY>

LINK_LIBRARY_OVERRIDE_<LIBRARY>¶

在 3.24 版本加入.

从 LINK_LIBRARY 生成器表达式覆盖与 <LIBRARY> 关联的库功能。这可用于解决由于在不同的 LINK_LIBRARY 生成器表达式中为``<LIBRARY>`` 指定不同的特性而导致的不兼容的库特性。

当在目标上设置时,此属性包含一个库功能名称,在链接该目标时将应用于“<LIBRARY>”。

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

也可以使用预定义的 DEFAULT 库功能覆盖任何功能。这有效地丢弃了该链接项的任何功能,仅针对该目标(本例中为 lib3):

# When linking lib3, discard any library feature for lib1
set_property(TARGET lib3 PROPERTY LINK_LIBRARY_OVERRIDE_lib1 DEFAULT)

请参阅 LINK_LIBRARY_OVERRIDE 目标属性,了解一次覆盖多个库的库功能的替代方法。如果定义了两个属性并为同一链接项指定了覆盖,则 LINK_LIBRARY_OVERRIDE_<LIBRARY>`` 优先于 LINK_LIBRARY_OVERRIDE。

LINK_LIBRARY_OVERRIDE_<LIBRARY> 的内容可以使用 generator expressions。

有关库功能的更多信息,请参阅 CMAKE_<LANG>_LINK_LIBRARY_USING_<FEATURE> 和 CMAKE_LINK_LIBRARY_USING_<FEATURE> 变量。

上一主题

LINK_LIBRARY_OVERRIDE

下一主题

LINK_OPTIONS

本页

  • 显示源代码

快速搜索

导航

  • 索引
  • 下一页 |
  • 上一页 |
  • CMake »
  • 3.26.4 Documentation »
  • cmake-属性(7) »
  • LINK_LIBRARY_OVERRIDE_<LIBRARY>
© 版权所有 2000-2023 Kitware, Inc. and Contributors. 由 Sphinx 6.2.1创建。