cmake target_sources指令详解

target_sources 指令用于为 CMake 目标添加源文件。这种方法的优点在于它可以将源文件添加到目标中,并且可以在 CMake 的生成阶段自动更新。

语法

target_sources(<target> [INTERFACE|PUBLIC|PRIVATE] <source1> <source2> ...)
  • target: 要添加源文件的目标,通常是通过 add_executable 或 add_library 定义的目标。
  • INTERFACE: 指定这些源文件对其他目标是可见的,但不会包含在目标本身的构建中。这通常用于接口库。
  • PUBLIC: 指定这些源文件对其他链接到该目标的目标是可见的,同时也包含在目标本身的构建中。
  • PRIVATE: 指定这些源文件仅对目标本身可见,不会传播到链接到该目标的其他目标。

示例

  1. 为库添加源文件:
add_library(my_library STATIC lib1.cpp lib2.cpp)

# 添加更多源文件到 my_library
target_sources(my_library PRIVATE lib3.cpp lib4.cpp)

在这个例子中,lib3.cpp 和 lib4.cpp 被添加到 my_library 目标中,而 lib1.cpp 和 lib2.cpp 是在 add_library 中最初定义的。

  1. 使用生成的源文件:
add_library(my_library STATIC lib1.cpp)

# 假设生成了额外的源文件,例如通过某些预处理操作
file(GLOB GENERATED_SOURCES "generated/*.cpp")

# 将生成的源文件添加到目标
target_sources(my_library PRIVATE ${GENERATED_SOURCES})

这个例子中,GENERATED_SOURCES 是通过 file(GLOB …) 生成的一组源文件,它们被添加到 my_library 目标中。

  1. 为接口库添加源文件:
add_library(my_interface_library INTERFACE)

# 添加源文件到接口库
target_sources(my_interface_library INTERFACE interface_file.cpp)

接口库通常不直接编译源文件,但你可以使用 target_sources 为它定义源文件,以便使用该库的其他目标能够访问这些源文件。

使用场景

  • 动态更新源文件列表: 使用 target_sources 可以动态地管理源文件列表,这在自动生成文件时特别有用。
  • 清晰的目标组织: 通过 target_sources 可以更清晰地组织目标的源文件,而不必在 add_library 或 add_executable 中定义所有源文件。
  • 跨目标源文件共享: 可以将公共源文件添加到多个目标中,使源文件的管理更加集中。

通过 target_sources,你可以更灵活地管理目标的源文件,并在 CMake 配置过程中更好地控制构建逻辑。

  • 9
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值