包含程序输出目录

博客介绍了CMAKE_CFG_INTDIR变量,它可用于引用每个配置输出子目录,适用于支持多配置的本机构建系统。在构建时评估的命令行中使用,不过现在add_custom_command()可替代它。该变量只读,在多配置系统中其值会作为符号传递给源文件编译。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

有时,我们希望include包含程序输出目录,则${CMAKE_OUTPUT_DIRECTORIES}只能获取输出路径,无法获取当前的Config,经过查找,发现CMAKE_CFG_INTDIR 变量正好可以做此时。

CMAKE_CFG_INTDIR 

对每个配置输出子目录的构建时引用。

对于支持构建树中的多个配置的本机构建系统(例如Visual Studio和Xcode),该值是对构建时变量的引用,该变量指定每个配置输出子目录的名称。在Makefile生成器上,它的计算结果为“。”,因为构建树中只有一个配置。示例值:

$(IntDir)        = Visual Studio 6
$(OutDir)        = Visual Studio 7, 8, 9
$(Configuration) = Visual Studio 10
$(CONFIGURATION) = Xcode
.                = Make-based tools

由于这些值是由本机构建系统评估的,因此该变量仅适用于将在构建时评估的命令行。预期用途示例:

add_executable(mytool mytool.c)
add_custom_command(
  OUTPUT out.txt
  COMMAND ${CMAKE_CURRENT_BINARY_DIR}/${CMAKE_CFG_INTDIR}/mytool
          ${CMAKE_CURRENT_SOURCE_DIR}/in.txt out.txt
  DEPENDS mytool in.txt
  )
add_custom_target(drive ALL DEPENDS out.txt)

请注意,为此目的不再需要CMAKE_CFG_INTDIR,而是为了与现有项目兼容。相反,add_custom_command()在其COMMAND选项中识别可执行目标名称,因此“$ {CMAKE_CURRENT_BINARY_DIR} / $ {CMAKE_CFG_INTDIR} / mytool”可以仅由“mytool”替换。

此变量是只读的。设置它是未定义的行为。在多配置构建系统中,此变量的值作为预处理程序符号“CMAKE_INTDIR”的值传递给所有源文件的编译。

 包含程序输出目录
# include tlb directory CMAKE_CFG_INTDIR 可以在VS中生成$(Configuration) 宏
INCLUDE_DIRECTORIES(${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/${CMAKE_CFG_INTDIR})
MESSAGE(${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/${CMAKE_CFG_INTDIR})

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值