导航

  • 索引
  • 下一页 |
  • 上一页 |
  • CMake 4.2.0 »
  • 文档 »
  • cmake-properties(7) »
  • LINK_LIBRARY_OVERRIDE

LINK_LIBRARY_OVERRIDE¶

在 3.24 版本中添加。

覆盖来自 LINK_LIBRARY 生成器表达式的库相关联的库特性。这可用于解决在不同 LINK_LIBRARY 生成器表达式中为同一个库指定不同特性所导致的库特性不兼容问题。

此属性支持覆盖多个库和特性。它需要一个 分号分隔的列表,其中每个列表项的格式如下:

feature[,link-item]*

对于每个逗号分隔的 link-item,在此属性设置的目标上,它现有的任何库特性都将被忽略。该项将改为与指定的 feature 相关联。每个 link-item 可以是任何在 LINK_LIBRARY 生成器表达式中被接受为 library-list 的一部分的内容。

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 "feature2,lib1,external")

# lib1 and external will now be associated with feature2 instead when linking lib3

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

# When linking lib3, discard any library feature for lib1, and use feature2 for external
set_property(TARGET lib3 PROPERTY LINK_LIBRARY_OVERRIDE
  "DEFAULT,lib1"
  "feature2,external"
)

上面的示例还演示了如何为不同的链接项指定不同的特性覆盖。有关覆盖单个库的库特性的替代方法,请参阅 LINK_LIBRARY_OVERRIDE_<LIBRARY> 目标属性,在某些情况下可能更简单。如果同时定义了这两个属性并为同一个链接项指定了覆盖,则 LINK_LIBRARY_OVERRIDE_<LIBRARY> 优先于 LINK_LIBRARY_OVERRIDE。

LINK_LIBRARY_OVERRIDE 的内容可以使用 生成器表达式。

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

上一主题

LINK_LIBRARIES_STRATEGY

下一主题

LINK_LIBRARY_OVERRIDE_<LIBRARY>

本页

  • 显示源

快速搜索

导航

  • 索引
  • 下一页 |
  • 上一页 |
  • CMake 4.2.0 »
  • 文档 »
  • cmake-properties(7) »
  • LINK_LIBRARY_OVERRIDE
© Copyright 2000-2025 Kitware, Inc. and Contributors. 使用 Sphinx 8.2.3 创建。