条件传递链接库
Conditional transitive link libraries
当使用两个依赖于上游包具有可选链接库的包时,我正在努力使用CMake"配置"为基础的包描述。
假设您有libA
可选地使用zip功能(例如通过libA
的CMakeLists.txt
中的某些选项USE_ZLIB
)。这意味着libA
在其INTERFACE_LINK_LIBRARIES
(导出到liba-config.cmake
)中将有-lz
。现在,如果你有一个libB
使用libA
通过find_package(libA)
,你怎么知道如果libA
已经构建与或不支持zlib当两个库安装和导出与CMake的包配置系统?
我知道链接库信息被传递处理,并将传播到libB
的链接库,因此每当链接到libB
时,-lz
就会出现。然而,PATH
到libz没有包括在内;因此,除非您神奇地知道libz
是libA
的一个链接库,并且知道从哪里包含它,否则链接失败并显示"无法找到库z"。在libA
的配置中包含libz
的绝对路径也是不可取的,因为它会破坏不同系统之间的可移植性。
target_link_libraries(libA PRIVATE z)
,例如声明(实际上是libA内部)libz为私有库。不幸的是,这并不能解决这个问题,因为CMake会自动通过$<LINK_ONLY:z>
将任何PRIVATE
标记的链接库添加到INTERFACE_LINK_LIBRARIES
列表。这显示了以另一种方式在导出的链接库列表中出现-lz
的必要性(并且CMake导出脚本作者理解传递问题)。
这样做的规范方法是使您的liba-config.cmake
成为模板,并将configure_file()用于填充有关构建选项的信息。
例如,您的CMakeLists.txt
看起来像这样:
if(ZLIB_FOUND)
... # link with ZLIB
set(BUILT_WITH_ZLIB 1)
endif()
... # more options
configure_file(alib-config.cmake.in alib-config.cmake)
现在,liba-config.cmake.in
应该有
set(BUILT_WITH_ZLIB @BUILT_WITH_ZLIB@)
if(BUILT_WTH_ZLIB)
# append lz to ALIB_LIBRARIES or whetever you variable is called
endif()
配置后,alib-config.cmake
将包含set(BUILT_WITH_ZLIB 0)
或set(BUILT_WITH_ZLIB 1)
,具体取决于其在CMake中的值。
相关文章:
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- CMake-按正确顺序将项目与C运行时对象文件链接
- 从链接列表c++中删除一个项目
- 有根的二进制搜索树.保留与其父级的链接
- 读取文件的最后一行并输入到链接列表时出错
- 静态数据成员的问题-修复链接错误会导致编译器错误
- node-gyp 在 macOS 上未正确链接库
- 基于boost的程序的静态链接——zlib问题
- 无法链接 CMake 中的本地库
- 内联函数中具有内部链接的全局变量
- 链接阶段在Ubuntu上失败,但在MacOS上失败
- 使用gcc从静态链接的文件中查找可选符号
- 我可以将一个用clang c++11编译的对象与另一个用c++17编译的对象链接起来吗
- 将--whole archive链接器选项与CMake和具有其他库依赖项的库一起使用
- 带有预处理器的可视化C++条件链接
- 如何链接范围::有条件地查看
- CMake 条件库链接取决于平台
- 如何在visual studio中有条件地链接静态库
- 比较交换原子操作vs加载链接/存储条件操作
- 条件传递链接库