CMake中target_sources的使用

      CMake中的target_sources命令用于将源添加到target,其格式如下:

target_sources(<target>
  <INTERFACE|PUBLIC|PRIVATE> [items1...]
  [<INTERFACE|PUBLIC|PRIVATE> [items2...] ...]) # general form

target_sources(<target>
  [<INTERFACE|PUBLIC|PRIVATE>
   [FILE_SET <set> [TYPE <type>] [BASE_DIRS <dirs>...] [FILES <files>...]]...
  ]...) # File Sets

      1.指定构建target和/或其依赖项时要使用的源(sources)。命名的<target>必须由诸如add_executable或add_library或add_custom_target之类的命令创建,并且不能是ALIAS target。<items>可以使用生成器表达式(generator expressions)。
      <target>可以是自定义(custom)target。
      需要INTERFACE, PUBLIC和PRIVATE关键字来指定它们后面的源文件路径(<items>)的范围。PRIVATE和PUBLIC项将填充<target>的SOURCES属性,这些属性在构建target本身时使用。PUBLIC和INTERFACE项将填充<target>的INTERFACE_SOURCES属性,这些属性在构建依赖性时使用。由add_custom_target命令创建的target只能具有PRIVATE范围。
      对相同<target>的重复调用按调用顺序追加项(append items).
      允许使用INTERFACE_SOURCES导出targets.
      允许在IMPORTED targets上设置INTERFACE项。
      相对源文件路径被解释为相对于当前源目录(即CMAKE_CURRENT_SOURCE_DIR)。
      以生成器表达式开头的路径保持不变。当target的SOURCE_DIR属性不同于CMAKE_CURRENT_SOURCE_DIR时,在生成器表达式中使用绝对路径以确保将sources正确分配给target。

include_directories(${CMAKE_CURRENT_SOURCE_DIR}/include)
add_library(add STATIC) # 在build目录下会生成libadd.a
target_sources(add PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/source/add.cpp)

      2.File Sets: 3.23版本中新增内容。将文件集(file set)添加到target,或将文件添加到现有文件集。target具有零个或多个命名文件集。每个文件集都有name, type, INTERFACE, PUBLIC或PRIVATE范围,一个或多个基本目录以及这些目录中的文件。
      可接受的type包括:
      (1).HEADERS:通过语言的#include机制使用的源。
      (2).CXX_MODULES:实验性的。
      (3).CXX_MODULE_HEADER_UNITS:实验性的。
      INTERFACE或PUBLIC文件集中的文件可以使用install(TARGETS)命令安装,并使用install(EXPORT)和export命令导出。
      每个target_sources(FILE_SET)条目都以INTERFACE, PUBLIC或RIVATE开头,并接受以下参数:
      (1).FILE_SET <set>:要创建或添加到的文件集的name.它只能包含字母、数字和下划线。
      (2).TYPE <type>:每个文件集都与特定类型的文件相关联。只能使用上面指定的type,指定任何其它type都是错误的。
      (3).BASE_DIRS <dirs>...:文件集的基本目录的可选列表。任何相对路径都被视为相对于当前源目录(即CMAKE_CURRENT_SOURCE_DIR).
      (4).FILES <files>...:要添加到文件集中的可选文件列表。

      执行测试代码需要多个文件

      build.sh内容如下:

#! /bin/bash

# supported input parameters(cmake commands)
params=(function macro cmake_parse_arguments \
		find_library find_path find_file find_program find_package \
		cmake_policy cmake_minimum_required project include \
		string list set foreach message option if while return \
		math file configure_file \
		include_directories add_executable add_library target_link_libraries install \
		target_sources add_custom_command add_custom_target)

usage()
{
	echo "Error: $0 needs to have an input parameter"

	echo "supported input parameters:"
	for param in ${params[@]}; do
		echo "  $0 ${param}"
	done

	exit -1
}

if [ $# != 1 ]; then
	usage
fi

flag=0
for param in ${params[@]}; do
	if [ $1 == ${param} ]; then
		flag=1
		break
	fi
done

if [ ${flag} == 0 ]; then
	echo "Error: parameter \"$1\" is not supported"
	usage
	exit -1
fi

if [[ ! -d "build" ]]; then
	mkdir build
	cd build
else
	cd build
fi

echo "==== test $1 ===="

# test_set.cmake: cmake -DTEST_CMAKE_FEATURE=$1 --log-level=verbose ..
# test_option.cmake: cmake -DTEST_CMAKE_FEATURE=$1 -DBUILD_PYTORCH=ON ..
cmake -DTEST_CMAKE_FEATURE=$1 ..
# It can be executed directly on the terminal, no need to execute build.sh, for example: cmake -P test_set.cmake
make
# make install # only used in cmake files with install command

      CMakeLists.txt内容如下:

cmake_minimum_required(VERSION 3.22)
project(cmake_feature_usage)

message("#### current cmake version: ${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION}.${CMAKE_PATCH_VERSION}")
include(test_${TEST_CMAKE_FEATURE}.cmake)
message("==== test finish ====")

      test_target_sources.cmake内容为上面的所有测试代码段。

      另外还包括三个目录:include,source,samples,它们都是非常简单的实现,仅用于测试,如下:

      可能的执行结果如下图所示: 

 

      GitHub: http://github.com/fengbingchun/Linux_Code_Test

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CMaketarget_sources命令用于向target添加源文件,其格式如下: ```cmake target_sources(<target> [PRIVATE|PUBLIC|INTERFACE] [items1...] [<PRIVATE|PUBLIC|INTERFACE> [items2...] ...]) ``` 这个命令可以将源文件直接添加到指定的target。源文件可以是C、C++、Objective-C、Objective-C++等类型的文件。 例如,假设我们有一个名为myapp的目标,并且我们想将两个源文件main.cpp和helper.cpp添加到该目标,可以使用以下代码: ```cmake add_executable(myapp) target_sources(myapp PRIVATE main.cpp helper.cpp) ``` target_link_libraries命令用于将目标与库文件进行链接,其格式如下: ```cmake target_link_libraries(<target> [item1] [item2] [...]) ``` 这个命令可以将库文件链接到指定的target,以便在编译和链接过程使用这些库。 例如,假设我们有一个名为myapp的目标,并且我们想将名为mylib的库文件链接到该目标,可以使用以下代码: ```cmake add_executable(myapp) target_link_libraries(myapp mylib) ``` target_include_directories命令用于向target添加包含目录,其格式如下: ```cmake target_include_directories(<target> [SYSTEM] [BEFORE|AFTER] <INTERFACE|PUBLIC|PRIVATE> [items1...] [<INTERFACE|PUBLIC|PRIVATE> [items2...] ...]) ``` 这个命令可以将包含目录添加到指定的target,以便在编译过程可以找到所需的头文件。 例如,假设我们有一个名为myapp的目标,并且我们想将名为include的目录添加到该目标的包含目录,可以使用以下代码: ```cmake add_executable(myapp) target_include_directories(myapp PRIVATE include) ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值