target_compile_definitions

向目标添加编译定义。

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

指定在编译给定的 <target> 时使用的编译定义。命名的 <target> 必须已通过诸如 add_executable()add_library() 之类的命令创建,并且不得为 ALIAS 目标

INTERFACEPUBLICPRIVATE 关键字是必需的,用于指定以下参数的 作用域PRIVATEPUBLIC 项将填充 COMPILE_DEFINITIONS 属性。PUBLICINTERFACE 项将填充 INTERFACE_COMPILE_DEFINITIONS 属性。以下参数指定编译定义。对同一 <target> 的重复调用会按调用顺序追加项。

3.11 版本新增: 允许在 IMPORTED 目标 上设置 INTERFACE 项。

target_compile_definitions 的参数可以使用生成器表达式,语法为 $<...>。请参阅 cmake-generator-expressions(7) 手册以获取可用的表达式。请参阅 cmake-buildsystem(7) 手册以获取有关定义构建系统属性的更多信息。

任何项上开头的 -D 都将被删除。空项将被忽略。例如,以下所有内容都是等效的

target_compile_definitions(foo PUBLIC FOO)
target_compile_definitions(foo PUBLIC -DFOO)  # -D removed
target_compile_definitions(foo PUBLIC "" FOO) # "" ignored
target_compile_definitions(foo PUBLIC -D FOO) # -D becomes "", then ignored

定义可以选择性地具有值

target_compile_definitions(foo PUBLIC FOO=1)

请注意,许多编译器将 -DFOO 视为等同于 -DFOO=1,但其他工具可能并非在所有情况下都识别这一点(例如 IntelliSense)。

参见