CMake中target_compile_definitions的使用

      CMake中的target_compile_definitions命令用于向target添加编译定义,其格式如下:

target_compile_definitions(<target>
  <INTERFACE|PUBLIC|PRIVATE> [items1...]
  [<INTERFACE|PUBLIC|PRIVATE> [items2...] ...])

      指定在编译给定的<target>时要使用的编译定义命名的<target>必须由诸如add_executable或add_library之类的命令创建,并且不能为ALIAS target
      需要INTERFACE, PUBLIC和PRIVATE关键字来指定以下参数(following arguments)的作用域(scope).PRIVATE和PUBLIC项将填充<target>的COMPILE_DEFINITIONS属性。PUBLIC和INTERFACE项将填充<target>的INTERFACE_COMPILE_DEFINITIONS属性。以下参数指定编译定义。重复调用相同的<target>会按调用顺序追加项
      允许在IMPORTED target上设置INTERFACE项。
      target_compile_definitions的参数可以使用语法为$<...>的"生成器表达式"。
      项(item)上的任何前导-D都将被删除忽略空项(Empty items are ignored).
      定义可以选择有值
      注意:许多编译器将-DFOO等同于-DFOO=1,但是其它工具可能无法在所有情况下都识别出此情况(例如IntelliSense)。

include_directories(include)
add_library(add STATIC source/add.cpp)
add_executable(main samples/sample_add.cpp)
target_link_libraries(main add)

target_compile_definitions(main PUBLIC SAMPLE_ADD)
target_compile_definitions(main PRIVATE SAMPLE_ADD_VALUE=10)

# 以下各项都是等效的
target_compile_definitions(main PUBLIC FOO)
target_compile_definitions(main PUBLIC -DFOO)  # -D removed
target_compile_definitions(main PUBLIC "" FOO) # "" ignored
target_compile_definitions(main PUBLIC -D FOO) # -D becomes "", then ignored

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

      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 \
		add_subdirectory aux_source_directory \
		set_property set_target_properties define_property \
		add_definitions target_compile_definitions)

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_compile_definitions.cmake内容为上面的所有测试代码段

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

      其中samples/sample_add.cpp内容如下:

#include <iostream>
#include <add.hpp>

int main()
{
#ifdef SAMPLE_ADD
    fprintf(stdout, "**** defined SAMPLE_ADD ****\n");
#endif
#if SAMPLE_ADD_VALUE == 10
    fprintf(stdout, "#### defined SAMPLE_ADD_VALUE 10 ####\n");
#endif

    int a = 2, b = 3;
    fprintf(stdout, "%d+%d=%d\n", a, b, add(a,b));
    return 0;
}

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

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

  • 4
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
target_compile_definitions()是CMake用于为指定目标文件添加编译选项的函数。其原型如下: ```cmake target_compile_definitions(<target> <INTERFACE|PUBLIC|PRIVATE> <definition>...) ``` 其,\<target\>表示目标文件的名称,可以是可执行文件或库文件。\<INTERFACE|PUBLIC|PRIVATE\>表示编译选项的作用域,可以取以下值: - INTERFACE:表示该编译选项将应用于目标文件的所有依赖项和使用该库的项目。 - PUBLIC:表示该编译选项将应用于目标文件、其依赖项和使用该库的项目。 - PRIVATE:表示该编译选项将仅应用于目标文件。 \<definition\>表示需要添加的编译选项,可以添加多个,每个选项之间用空格隔开。 该函数的作用是为指定的目标文件添加编译选项,可以针对特定目标文件添加编译选项,而不是像add_definitions()函数一样添加到所有目标文件。 例如,我们可以在CMakeLists.txt文件添加以下代码来为特定的目标文件添加编译选项: ```cmake add_executable(myapp main.cpp) target_compile_definitions(myapp PRIVATE DEBUG) ``` 上述代码将为名为myapp的可执行文件添加编译选项DEBUG。 在使用target_compile_definitions()函数时,我们需要注意以下几点: 1. 可以在同一个目标文件多次调用target_compile_definitions()函数,以添加多个编译选项。 2. target_compile_definitions()函数只能添加编译选项,不能添加链接选项。 3. 如果需要添加链接选项,可以使用target_link_libraries()函数。 4. target_compile_definitions()函数添加的编译选项将会覆盖CMakeLists.txt文件使用add_definitions()函数定义的编译选项。 5. target_compile_definitions()函数只对当前目标文件生效,不会影响到其他目标文件。 总之,target_compile_definitions()函数是CMake非常常用的函数之一,可以方便地为指定的目标文件添加编译选项,提高代码的可维护性和可移植性。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值